@charset "utf-8";
body {
  font-family: 'Noto Sans JP', 'メイリオ', Meiryo, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif;
  color: #222;
  margin: 0;
  padding: 0;
  letter-spacing: 0.02em;
}
figure {
    margin-block-start: 0;
    margin-block-end: 0;
    margin-inline-start: 0;
    margin-inline-end: 0;
}
.pc{ display: block; }
.sp{ display: none; }
.tab{ display: none; }
.caption{ font-size:14px; }
main {
  width: 100%;
  text-align: center;
  margin: 0;
  padding: 0 0 50px 0;
  background-color: #FFF1C2;
  font-feature-settings: "palt";
}
main img { width: 100%; }

#kv {
  width: 100%;
  text-align: center;
}
  #kv .kv-inner {
    margin: 0 auto;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 0;
  }
  #kv .kv-inner picture {
    width: 100%;
    position: relative;
  }
  #kv .kv-inner img {
    width: 100%;
    height: auto;
  }

.catch {
    width: 100%;
    background-color: #fff;
    padding: 40px 0 35px 0;
    margin-bottom: 60px;
}
    .catch p {
        color: #000;
        text-align: center;
        font-size: 30px;
        font-weight: 400;
        line-height: 48px;
        margin-bottom: 20px;
    }
        .catch p em {
            color: #21A564;
            font-weight: 700;
        }
    .catch p:nth-child(2) {
        position: relative;
        color: #fff;
        text-align: center;
        font-size: 27px;
        font-weight: 400;
        line-height: 48px;
        background-color: #21A564;
        padding: 20px 35px 30px 35px;
        display: inline-block;
        border-radius: 15px;
    }
        .catch p:nth-child(2)::after {
            content: "";
            position: absolute;
            left: 50%;
            transform: translateX(-50%);
            bottom: -17px;
            width: 32px;
            height: 18px;
            background: transparent;
            clip-path: polygon(50% 100%, 0 0, 100% 0);
            background: #21A564;
        }
        .catch p:nth-child(2) .highlight {
            color: #fff;
            font-weight: 700;
            background: linear-gradient(transparent 75%, #9CCB3E 75%, #9CCB3E 100%);
            font-weight: bold;
            padding: 0 4px;
        }

.drecorder {
    display: flex;
}
    .image {
        width: 400px;
        margin-right: 40px;
        flex-shrink: 0;
    }
    .desc-block {
        text-align: left;
    }
    .head {
        font-size: 24px;
        font-weight: 600;
        margin-bottom: 15px;
        color: #222;
        line-height: 36px;
    }
    .desc {
        font-size: 16px;
        color: #444;
        margin-bottom: 20px;
        line-height: 32px;
    }
    .merit ul {
        margin-bottom: 20px;
    }
    .merit ul li {
        font-size: 17px;
        line-height: 26px;
        margin-bottom: 5px;
        padding-left: 1em;
        text-indent: -1em;
    }
    .merit ul li:nth-child(1)::before {
        content: "①";
        margin-right: 5px;
    }
    .merit ul li:nth-child(2)::before {
        content: "②";
        margin-right: 5px;
    }
    .merit ul li:nth-child(3)::before {
        content: "③";
        margin-right: 5px;
    }
    .desc-block a {
        position: relative;
        display: inline-block;
        background: #00A29A;
        color: #fff;
        font-size: 20px;
        line-height: 20px;
        font-weight: 500;
        padding: 20px 50px 20px 30px;
        border-radius: 8px;
    }
    .desc-block a::after {
        position: absolute;
        width: 16px;
        height: 12px;
        content: "";
        background-image: url(../_images/btn_arrow.svg);
        background-repeat: no-repeat;
        background-size: contain;
        top: 50%;
        right: 2%;
        transform: translate(0%, -50%);
    }
    .desc-block a:hover {
        background: #04a394;
        text-decoration: none;
    }
    .desc-block a .arrow {
        margin-left: 12px;
        font-size: 1.25em;
        vertical-align: middle;
    }

.abc-section {
    padding: 0;
    margin: 0 auto 50px auto;
    max-width: 1100px;
    border-radius: 12px;
    border: 2px solid #62AA46;
    background: #FFF;
}
    .abc-section:last-child{
        margin: 0 auto;
    }
    h2 {
        text-align: center;
        background: #62AA46;
        color: #fff;
        font-size: 28px;
        font-style: normal;
        font-weight: 600;
        padding: 10px 0 13px 0;
        letter-spacing: 0.05em;
        border-radius: 8px 8px 0px 0px;
    }
    .section-lead, .section-lead-main {
    text-align: center;
    font-size: 1.17rem;
    font-weight: 600;
    margin-bottom: 7px;
    }
    .section-note {
    text-align: center;
    font-size: 0.97rem;
    color: #555;
    margin-bottom: 25px;
    }

.content {
    margin: 0 auto;
    padding: 40px;
}

.product-item {
    display: flex;
    justify-content: center;
    align-items: center;
}
.product-item.bm {
    align-items: flex-start;
    margin-bottom: 40px;
}
    .product-item .bm-group {
        width: 50%;
    }
        .product-item .bm-group figure {
            width: 100%;
            max-width: 500px;
            margin-bottom: 20px;
        }
        .product-item .bm-group ul {
            font-size: 18px;
            line-height: 32px;
        }
        .product-item .bm-group ul li {
            padding-left: 1em;
            text-indent: -1em;
        }
        .product-item .bm-group ul li::before {
            content: "・";
            margin-right: 8px;
        }
    .product-item .bm-img {
        width: 47%;
        margin-left: 3%;
    }
.product-item.bc {
    margin: 45px 0 80px 0;
}
.product-item.an {
    margin: 30px 0 10px 0;
}

.product-image {
  max-width: 280px;
}
    .product-image img {
    width: 100%;
    }

.product-image01 {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 70%;
}
    .product-image01 img:first-child {
        max-width: 390px;
        margin-right: 15px;
    }
    .product-image01 img:nth-child(2) {
        max-width: 267px;
    }
.product-image02 {
    max-width: 580px;
    margin: 10px 0 30px 0;
}
    .product-image02 img {
    width: 100%;
    }
    .product-image02 figcaption {
        text-align: center;
        font-size: 14px;
    }
    
.product-info {
    text-align: left;
    width: 45%;
    margin-left: 50px;
}
    .product-info h3 {
        font-weight: 600;
        margin-bottom: 20px;
        font-size: 22px;
        line-height: 30px;
        letter-spacing: 0.04em;
    }
    .product-info p {
        font-size: 17px;
        margin: 10px 0 20px 0;
    }

.product-info a {
    width: 80%;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #00A29A;
    color: #fff;
    font-size: 20px;
    line-height: 20px;
    font-weight: 500;
    padding: 25px 20px;
    border-radius: 8px;
}
    .product-info a:hover {
        text-decoration: none;
    }
    .product-info a::after {
        position: absolute;
        content:"";
        background-image: url(../_images/btn_icon.svg);
        background-repeat: no-repeat;
        background-size: contain;
        right: 0;
        width: 60px;
        height: 52px;
    }
.product-info.w3 {
    width: 30%;
    margin-left: 30px;
}
    .product-info.w3 a {
        font-size: 18px;
    }

.btn-icon img {
    max-width: 60px;
}

.product-ai-group {
  background: #f6f7f9;
  border-radius: 6px;
  padding: 22px 18px 28px 18px;
  margin-bottom: 18px;
}
.product-ai-title {
    background: linear-gradient(90deg, #FFF 0%, #999 30%, #999 70%, #FFF 100%);
    color: #fff;
    padding: 10px 20px;
    text-align: center;
    margin: 0 auto 30px auto;
    max-width: 400px;
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    line-height: 36px;
}
.aibc-images-row {
    display: flex;
    gap: 32px;
    margin-bottom: 20px;
    justify-content: center;
}
    .aibc-images-row .ai-image:first-child {
        max-width: 606px;
    }
    .aibc-images-row .ai-image:nth-child {
        max-width: 395px;
    }
    .aibc-images-row .ai-image img {
        width: 100%;
    }
    .aibc-images-row .ai-image figcaption {
        text-align: right;
        font-size: 14px;
    }
.ai-images-row {
    display: flex;
    gap: 32px;
    margin-bottom: 20px;
    justify-content: center;
}
    .ai-images-row .ai-image {
        max-width: 400px;
    }
    .ai-images-row .ai-image img {
        width: 100%;
    }
    .ai-images-row .ai-image figcaption {
        text-align: center;
        font-size: 14px;
    }

.frontblind-visuals {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  margin-bottom: 16px;
}
    .frontblind-mainimg {
        max-width: 670px;
        margin: 40px 0 20px 0;
    }
    .frontblind-subimgs {
    display: flex;
    gap: 28px;
    }
    .img-small {
    width: 150px;
    height: 75px;
    background: #cccccc;
    border-radius: 8px;
    }
    .frontblind-caption {
    text-align: center;
    font-size: 0.92rem;
    color: #444;
    margin-top: 4px;
    }

.leaveprevent-mainrow {
    display: flex;
    gap: 26px;
    justify-content: center;
    align-items: center;
    margin: 30px 0 40px 0;
}
    .leaveprevent-mainimg {
        max-width: 350px;
    }
    .leaveprevent-steps {
        display: flex;
        flex-direction: column;
        gap: 16px;
        margin-left: 10px;
    }
    .leaveprevent-step01,
    .leaveprevent-step02 {
        border: 2px solid #00A8C4;
        border-radius: 10px;
        background: #fff;
        padding: 20px 30px;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
        .leaveprevent-step01 img {
            max-width: 280px;
            margin: 0 auto 10px auto;
        }
        .leaveprevent-step02 img {
            max-width: 350px;
            margin: 0 auto 10px auto;
        }
        .leaveprevent-steps figcaption {
            font-size: 16px;
            line-height: 26px;
            font-weight: 600;
        }

    .leaveprevent-group {
        display: flex;
        justify-content: center;
        align-items: end;
    }
        .leaveprevent-lowerrow {
            display: block;
            max-width: 330px;
            margin-right: 35px;
        }
        .leaveprevent-lowerrow .product-info.w2 {
            width: auto;
            margin-left: 0;
        }
            .leaveprevent-lowerrow .product-info.w2 a {
                width: 75%;
                font-size: 18px;
            }

    .youtube iframe {
        border-radius: 10px;
        width: 300px;
        height: 533px;
    }
    .lower-img {
        width: 125px;
        height: 140px;
        background: #cccccc;
        border-radius: 8px;
    }
    .leaveprevent-info {
        flex: 1;
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-end;
        margin-left: 12px;
    }
    .leaveprevent-title {
        font-weight: 700;
        font-size: 1.08rem;
        margin-bottom: 10px;
    }

.intruder-points {
    margin-bottom: 40px;
}
    .intruder-points li {
        font-size: 18px;
        line-height: 32px;
        padding-left: 1em;
        text-indent: -1em;
    }
    .intruder-points li::marker {
        content: none;
    }
    .intruder-points li::before {
        content: "・";
        margin-right: 8px;
    }

.intruder-upperrow {
  display: flex;
  gap: 22px;
  justify-content: center;
  margin-bottom: 22px;
}
    .upper-img {
    width: 185px;
    height: 90px;
    background: #cccccc;
    border-radius: 10px;
    }
    .intruder-products {
        display: grid;
        grid-template-columns: 1fr 1fr;
        margin: 0 auto;
    }
    .intruder-products article {
    display: flex;
    gap: 20px;
    align-items: center;
    padding: 20px;
    }
    .intruder-products figure {
    margin: 0;
    max-width: 200px;
    flex-shrink: 0;
    }
    .intruder-products img {
    width: 100%;
    height: auto;
    display: block;
    }

.product-detail {
    text-align: left;
    width: 100%;
}
    .product-detail h4 {
        font-size: 22px;
        line-height: 30px;
        font-weight: 700;
        margin: 0 0 12px 0;
    }
    .product-detail a {
        position: relative;
        display: flex;
        justify-content: center;
        align-items: center;
        width: auto;
        background: #00A29A;
        color: #fff;
        font-size: 18px;
        line-height: 20px;
        font-weight: 500;
        padding: 20px 30px;
        border-radius: 8px;
        text-indent: -2em;
    }
    .product-detail a::after {
        position: absolute;
        content: "";
        background-image: url(../_images/btn_icon.svg);
        background-repeat: no-repeat;
        background-size: contain;
        right: 0;
        top: 10%;
        width: 60px;
        height: 52px;
    }
    .product-detail a:hover {
        background: #139b91;
        text-decoration: none;
    }

@media only screen and (max-width: 1160px) {
    .tab{ display: block; }
    .abc-section {
        max-width: initial;
        width: 94%;
    }
    .desc-block a {
        padding: 4% 8%;
        width: 84%;
        line-height: 26px;
    }
    .product-item.an {
        display: block;
    }
        .product-image01 {
            margin: 0 auto;
        }
        .product-info.w3 {
            width: 50%;
            margin: 30px auto 0 auto;
        }
    .intruder-products article {
        display: block;
    }
    .intruder-products figure {
        margin: 0 auto 20px auto;
    }
    .product-info a {
        text-indent: -1em;
    }
    .product-info.w3 a {
        width: 90%;
        padding: 25px 5%;
    }
}

/* ---- Responsive SP ---- */
@media only screen and (max-width: 767px) {
    .pc{ display: none; }
    .sp{ display: block; }
    .caption{
        font-size: 3.6vw;
        line-height: 5.6vw;
        text-align: left;
    }
    main {
        margin: 0;
        padding: 0 0 3vw;
    }

    #kv {
        padding:0;
    }
        #kv .kv-inner {
            margin: 0 auto;
        }
        #kv .kv-inner img {
            width: 100%;
        }

    .catch {
        padding: 6vw 0 4vw 0;
        margin: 0 0 8vw 0;
    }
        .catch p {
            font-size: 5.2vw;
            line-height: 8.6vw;
            margin-bottom: 4vw;
        }
        .catch p:nth-child(2) {
            font-size: 5vw;
            line-height: 8.6vw;
            padding: 4vw 4vw 5vw;
            border-radius: 3vw;
        }

    .abc-section {
        width: auto;
        margin: 0 3vw 5vw 3vw;
        border-radius: 2vw;
    }
    .abc-section.backcamera .caption {
        text-align: left;
        display: block;
    }
        h2 {
            font-size: 5.4vw;
            padding: 2vw 0px 2.4vw;
            border-radius: 1vw 1vw 0px 0px;
            font-weight: bold;
        }
        .content {
            padding: 5vw;
        }
            .drecorder {
                display: block;
            }
            .image {
                width: 100%;
                margin-right: 0;
                margin-bottom: 2vw;
            }
            .head {
                font-size: 4.7vw;
                margin-bottom: 2vw;
                line-height: 8vw;
                text-align: left;
                font-weight: bold;
            }
            .desc {
                font-size: 4.2vw;
                margin-bottom: 4vw;
                line-height: 7vw;
            }
                .desc-block a {
                    line-height: 7vw;
                    font-size: 5vw;
                    text-align: center;
                    border-radius: 2vw;
                    font-weight: bold;
                }
                    .desc-block a::after {
                        width: 4.3vw;
                        height: 3.2vw;
                    }
            .merit ul {
                margin-bottom: 4vw;
            }
                .merit ul li {
                    font-size: 4.0vw;
                    line-height: 6.2vw;
                    margin-bottom: 1vw;
                    padding-left: 1.3em;
                    text-indent: -1.3em;
                }

            .product-item {
                display: block;
            }
                .product-item.bc {
                    margin: 4vw 0 9vw 0;
                }
                .product-image {
                    max-width: initial;
                }
                .product-info {
                    width: 100%;
                    margin-left: 0;
                    margin-top: 2vw;
                }
                .product-info h3 {
                    font-weight: 700;
                    margin-bottom: 3vw;
                    font-size: 5vw;
                    line-height: 7vw;
                    text-align: center;
                }
                .product-info p {
                    font-size: 4.6vw;
                    text-align: center;
                    margin: 0 0 4vw 0;
                }
                .product-info a {
                    width: 96%;
                    padding: 8% 2%;
                    font-size: 5vw;
                    line-height: 5vw;
                    border-radius: 2vw;
                    font-weight: bold;
                }
                .product-info.w3 {
                    margin: 3vw auto 0 auto!important;
                }
                    .product-info.w3 a {
                        width: 96%;
                        padding: 8% 2%;
                        font-size: 5vw;
                        line-height: 5vw;
                        border-radius: 2vw;
                    }
                    .product-info a::after {
                        width: 13.5vw;
                        height: 12vw;
                    }
                .product-ai-title {
                    padding: 4vw 0;
                    margin: 0 auto 4vw auto;
                    max-width: initial;
                    font-size: 5.2vw;
                    font-weight: 600;
                    line-height: 5.2vw;
                }

            .aibc-images-row {
                display: block;
                gap: 0;
                margin-bottom: 0;
            }
                .aibc-images-row .ai-image:first-child {
                    max-width: 100%;
                    margin-bottom: 3vw;
                }
                .aibc-images-row .ai-image figcaption {
                    font-size: 3.5vw;
                }

            .frontblind-visuals,
            .device {
                display: block;
                gap: 0;
            }
                .frontblind .head,
                .device .head {
                    text-align: center;
                }
                .frontblind p {
                    background-color: #D7E6D2;
                    text-align: center;
                    padding: 3vw;
                    border-radius: 2vw;
                    font-weight: 600;
                    font-size: 4vw;
}
                .device .caption {
                    text-align: center;
                }
                .device .product-info p {
                    margin: 0 0 3vw 0;
                }
                .frontblind-mainimg {
                    max-width: initial;
                    margin: 5vw 0 5vw 0;
                }
                .ai-images-row {
                    display: block;
                    gap: 0;
                    margin-bottom: 4vw;
                }
                .ai-images-row .ai-image {
                    max-width: initial;
                    margin-bottom: 4vw;
                }
                .ai-images-row .ai-image figcaption {
                    text-align: right;
                    font-size: 3.5vw;
                }
                .product-image02 {
                    max-width: initial;
                    margin: 0 0 3vw 0;
                }
                    .product-image02 figcaption {
                        font-size: 3.5vw;
                    }

                .leaveprevent .head {
                    text-align: center;
                }
                .leaveprevent-mainrow {
                    display: block;
                    gap: 0;
                    margin: 5vw 0 6vw 0;
                }
                .leaveprevent-mainimg {
                    max-width: initial;
                    margin-bottom: 3vw;
                }
                .leaveprevent-steps {
                    gap: 3vw;
                    margin-left: 0;
                }
                .leaveprevent-steps figcaption {
                    font-size: 4.1vw;
                    line-height: 6vw;
                }
                .leaveprevent-step01, .leaveprevent-step02 {
                    border-radius: 3vw;
                    padding: 4vw 5vw;
                }
                    .leaveprevent-step01 img {
                        max-width: initial;
                        margin: 0 auto 3vw auto;
                        width: 85%;
                    }
                    .leaveprevent-step02 img {
                        max-width: initial;
                        margin: 0 auto 3vw auto;
                        width: 85%;
                    }
                .leaveprevent-group {
                    display: flex;
                    flex-direction: column-reverse;
                }
                .leaveprevent-lowerrow {
                    display: block;
                    max-width: initial;
                    margin-right: 0;
                }
                .leaveprevent-lowerrow .product-info.w2 a {
                    width: 96%;
                    padding: 8% 2%;
                    font-size: 5vw;
                    line-height: 5vw;
                    border-radius: 2vw;
                }
                .youtube {
                    margin: 0 auto;
                }
                    .youtube iframe {
                        border-radius: 3vw;
                        width: 72vw;
                        height: 127.12vw;
                        margin-left: 3vw;
                        margin-right: 3vw;
                    }

            .product-item .bm-group {
                width: 100%;
            }
                .product-item .bm-group figure {
                    max-width: initial;
                }
                .product-item .bm-group ul {
                    font-size: 4vw;
                    line-height: 6vw;
                    margin-bottom: 5vw;
                }
                .product-item .bm-group ul li {
                    margin-bottom: 1.5vw;
                }
                .product-item .bm-img {
                    width: 100%;
                    margin-left: 0;
                }
                .product-item.bm {
                    margin-bottom: 4vw;
                }
                .product-item.an {
                    margin: 3vw 0 2vw 0;
                }

                .dozingoff .head {
                    text-align: center;
                }
                .product-image01 {
                    display: block;
                    width: 100%;
                }
                .product-image01 img:first-child {
                    max-width: initial;
                    margin-right: 0;
                }
                .product-image01 img:nth-child(2) {
                    max-width: initial;
                    width: 86%;
                    margin: 10% 0 0 0;
                }
                .product-info.w3 {
                    width: 100%;
                    margin: 30px auto 0 auto;
                }

            .abc-section:last-child {
                width: auto;
                margin: 0 3vw 5vw 3vw;
            }

            .intruder-points {
                margin-bottom: 0;
            }
                .intruder-upperrow {
                    display: block;
                    gap: 0;
                    margin-bottom: 2vw;
                }
                .intruder-points li {
                    font-size: 4vw;
                    line-height: 6vw;
                    margin-bottom: 3vw;
                }
                .intruder-products {
                    display: block;
                }
                .intruder-products article {
                    gap: 0;
                    padding: 0;
                    margin-bottom: 10vw;
                }
                    .intruder-products article:last-child {
                        margin-bottom: 0;
                    }
                    .intruder-products figure {
                        width: 80%;
                        max-width: initial;
                        margin: 0 auto 5vw;
                    }
                    .product-detail a {
                        width: 96%;
                        padding: 8% 2%;
                        font-size: 5vw;
                        line-height: 5vw;
                        border-radius: 2vw;
                        font-weight: bold;
                    }
                        .product-detail a::after {
                            width: 13.5vw;
                            height: 12vw;
                            top: initial;
                        }
                    .product-detail h4 {
                        margin: 0 0 4vw;
                        font-size: 5vw;
                        line-height: 7vw;
                        text-align: center;
                    }
}
