@charset "UTF-8";

.sitewrap,
body {
    box-sizing: border-box
}

html {
    background: #fff;
    color: #282828;
    font-family: メイリオ, Meiryo, "Noto Sans JP", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-size: 16px;
    line-height: 1.4
}

html .goti,
html .goti form * {
    font-family: "Noto Sans JP", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif
}

html .min,
html .min form * {
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "Times New Roman", "HG明朝B", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif
}

body {
    width: 100%;
    font-size: 100%;
    text-align: center
}

/** PCでは消す **/
@media screen and (min-width: 769px) {
    .is-hide-pc {
        display: none;
    }
}

/** スマホでは消す **/
@media screen and (max-width: 768px) {
    .is-hide-sp {
        display: none;
    }
}

.sitewrap {
    width: 1200px;
    min-width: 1200px;
    overflow: hidden;
    margin: 0 auto;
    text-align: left;
    -webkit-box-sizing: border-box
}

.products_wrap .sitewrap {
    margin: 2em auto
}

.common_page .article_body .sitewrap {
    width: 1000px;
    min-width: 1000px;
}

.pref_page .article_body .sitewrap {
    width: 1000px;
    min-width: 1000px;
}

.pref_page .article_body .contact_wrap {
    margin: 3em auto;
}

.pref_page .article_body .contact_wrap .sitewrap {
    width: 1200px;
    min-width: 1200px;
    margin-bottom: 0
}

.shop_wrap .sitewrap,
.sitewrap.ovf_vi {
    overflow: visible
}

header {
    width: 100%;
    box-sizing: border-box;
    height: 110px
}

header .menu_top {
    position: relative;
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap
}

header .menu_top div {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: center
}

header .menu_top #site_ttl {
    white-space: nowrap;
    height: 100%;
    width: auto
}

header .menu_top #site_ttl a,
header .menu_top #site_ttl p {
    display: inline-block;
    vertical-align: middle
}

header .menu_top #site_ttl a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: auto
}

header .menu_top #site_ttl .col2 {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1.5em;
    width: auto
}

header .menu_top #site_ttl img {
    width: auto;
    height: 4.5em;
    -o-object-fit: contain;
    object-fit: contain
}

header .menu_top #site_ttl .edon {
    height: 3em
}

header .menu_top #site_ttl p {
    margin-left: 10px;
    font-size: 12px
}

header .menu_top .right_menu {
    padding: 1.5em 0;
    width: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
    gap: .5em;
    height: 100%
}

header .menu_top .right_menu li {
    display: block;
    height: 100%
}

header .menu_top .right_menu li a,
header .menu_top .right_menu li a span img {
    height: 100%
}

header .menu_top .right_menu li a div {
    display: flex;
    align-items: flex-start;
    flex-direction: column;
    justify-content: flex-start
}

.product-items .item .info .info-wrapper .normal-price-wrap .normal-price span,
header .menu_top .right_menu li a div span:first-child {
    font-size: 1.3em
}

header .menu_top .right_menu li.pref_dial a p+p {
    margin-top: 5px
}

header .menu_top .right_menu li.pref_dial a p>img {
    display: inline-block;
    margin-right: 5px
}

header .menu_top .right_menu li.pref_dial a b {
    display: inline-block;
    font-size: 30px;
    color: #d4002d;
    line-height: 1
}

header .menu_top .right_menu li.pref_dial a b img {
    display: block
}

header .menu_top .right_menu .contact_btn {
    width: auto
}

header .menu_top .right_menu .contact_btn a {
    border-radius: .3em;
    padding: .5em 1em;
    box-sizing: border-box;
    color: #fff;
    text-align: left;
    line-height: 1.2;
    transition: background 0.4s, color 0.4s;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: nowrap;
    gap: .5em
}

header .menu_top .right_menu .contact_btn a::before {
    display: inline-block;
    content: "";
    width: 2.5em;
    height: 2.5em;
    background-image: url(../img/common/icon_ctt_mail.svg);
    background-repeat: no-repeat;
    background-size: contain;
    top: 10px;
    left: 0;
    right: 0;
    transition: 0.2s
}

header .menu_top .right_menu .contact_btn a::after {
    content: "";
    height: .3em;
    width: .3em;
    border-top: .2em solid #fff;
    border-right: .2em solid #fff;
    transform: translateX(.3em) rotate(45deg);
    transition: 0.2s
}

header .menu_top .right_menu .contact_btn a:hover {
    opacity: 1;
    background: #ffff2b;
    text-decoration: none;
    color: #282828;
    border: 2px solid #182e78
}

.contact_wrap .col3 .mail_items dd .btn_links a:hover span:before,
.contact_wrap .col3 .mail_items dd .btn_links_red a:hover span:before,
header .menu_top .right_menu .contact_btn a:hover::before {
    background-image: url(../img/common/icon_ctt_mail_blu.svg)
}

header .menu_top .right_menu .contact_btn a:hover::after {
    border-top: .2em solid #182e78;
    border-right: .2em solid #182e78;
    transform: translateX(.6em) rotate(45deg)
}

header .menu_top .right_menu .contact_btn a span {
    font-weight: 700
}

.caution_wrap:after,
.drop_menu #NavWrap li .drop_wrap i,
.drop_menu #NavWrap li a span br,
.drop_menu #NavWrap ul::after,
.drop_menu #NavWrap ul>li.display_sp,
.shop_wrap .shop_area .shop_tit span .sub_tit:after,
.shop_wrap .shop_area .shop_tit span .sub_tit:before,
.strengths_wrap::after,
header .menu_top .right_menu .contact_btn a span::after {
    display: none
}

header .menu_top .right_menu .mail a {
    background: #2973d7;
    border: 2px solid #2973d7
}

header .menu_top .right_menu .line a {
    background: #00b900;
    border: 2px solid #00b900
}

header .menu_top .right_menu .line a:before {
    background-image: url(../img/common/icon_ctt_line.svg)
}

.contact_wrap .col3 .line_items dd .btn_links a:hover span:before,
.contact_wrap .col3 .line_items dd .btn_links_red a:hover span:before,
header .menu_top .right_menu .line a:hover::before {
    background-image: url(../img/common/icon_ctt_line_blu.svg)
}

/* スマホ（1000px以下）でメール・LINEボタンを非表示 */
@media screen and (max-width: 1000px) {

    header .menu_top .right_menu .contact_btn.mail,
    header .menu_top .right_menu .contact_btn.line {
        display: none !important;
    }

    /* スマホ用お問い合わせボタン */
    header .menu_top .right_menu .contact_btn.inquiry {
        display: flex;
        /* background: linear-gradient(180deg, #28a745 0%, #218838 100%); */
        border-radius: 4px;
        min-height: 75px;
        /* 高さを確保 */
    }

    header .menu_top .right_menu .contact_btn.inquiry a {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: space-between;
        width: 100%;
        height: 100%;
        padding: 20px 12px 10px;
        position: relative;
        text-decoration: none;
        color: #182e78;
        box-sizing: border-box;
    }

    header .menu_top .right_menu .contact_btn.inquiry a::before {
        display: block;
        content: "";
        width: 2em;
        height: 2em;
        background-image: url(../img/common/Estimate.svg);
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center;
        flex-shrink: 0;
        margin-bottom: 4px;
    }

    header .menu_top .right_menu .contact_btn.inquiry a div {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: flex-end;
    }

    header .menu_top .right_menu .contact_btn.inquiry a div span {
        font-size: 10px;
        font-weight: bold;
        line-height: 1.2;
        white-space: nowrap;
    }
}

/* PC（1001px以上）でお問い合わせボタンを非表示 */
@media screen and (min-width: 1001px) {
    header .menu_top .right_menu .contact_btn.inquiry {
        display: none !important;
    }
}

/* ========================================
   ハンバーガーメニュー下の「メニュー」テキスト（スマホのみ）
======================================== */

@media screen and (min-width: 1001px) {
    .drop_menu label div {
        display: none;
    }
}

/* スマホ（1000px以下）で「メニュー」テキストを表示 */
@media screen and (max-width: 1000px) {
    .drop_menu label div {
        display: block;
        text-align: center;
        font-size: 9px;
        color: #182e78;
        margin-top: 35px;
        font-weight: bold;
        line-height: 1;
    }
}

header#fix_menu {
    position: absolute;
    background: #fff;
    top: 0;
    left: 0;
    right: 0;
    z-index: 999;
    transform: none
}

#fix_menu.fixedMenu {
    position: fixed;
    top: -110px
}

.caution_wrap dt,
.menu_bottom {
    background: #182e78
}

.drop_menu {
    max-width: 1200px;
    margin: auto;
    z-index: 99
}

.drop_menu #site_ttl:hover {
    color: #337b3b
}

.drop_menu #NavWrap {
    padding: 0
}

.drop_menu #NavWrap ul {
    margin: 0;
    padding: 0;
    display: flex;
    /* table から flex に変更 */
    width: 100%;
    box-sizing: border-box;
}

.drop_menu #NavWrap ul>li {
    flex: 1;
    /* display: table-cell から flex: 1 に変更 */
    display: flex;
    /* 追加 */
    vertical-align: middle;
    box-sizing: border-box;
    /* width: 16% を削除 */
}

.drop_menu #NavWrap li a,
.drop_menu #NavWrap li p {
    display: block;
    padding: 14px 0;
    box-sizing: border-box;
    text-decoration: none;
    font-size: 14px;
    width: 100%;
    /* auto から 100% に変更 */
    line-height: 1;
    position: relative;
    color: #fff;
    text-align: center;
    transition: background 0.5s, color 0.5s, opacity 0.5s, color 0.5s;
}

.drop_menu #NavWrap li a span {
    padding: 4px 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    white-space: nowrap;
    font-weight: 700;
    position: relative;
    border-right: 1px solid #fff
}

.drop_menu #NavWrap li a span:after {
    content: "";
    width: 0;
    height: 2px;
    display: block;
    position: absolute;
    bottom: -10px;
    left: 0;
    transition: width 0.2s;
    background: #182e78
}

.drop_menu #NavWrap li a:hover {
    opacity: 1;
    background: #fff;
    color: #182e78
}

.drop_menu #NavWrap li a:hover span {
    opacity: 1
}

.drop_menu #NavWrap li a:hover span:after {
    width: 100%
}

.drop_menu #NavWrap li:first-of-type a span {
    border-left: 1px solid #fff
}

.drop_menu #NavWrap li .drop_wrap {
    position: relative
}

.drop_menu #NavWrap li:hover ul {
    opacity: 1;
    visibility: visible;
    z-index: 999
}

.drop_menu #NavWrap li ul a {
    min-width: 10em;
    padding: 10px;
    background: #ddd;
    color: #333
}

.drop_menu #NavWrap .freedial_wrap {
    margin-bottom: 30em
}

.drop_menu #NavWrap .freedial_wrap a span {
    font-size: 7em
}

.drop_menu #switch {
    position: absolute;
    display: none;
    opacity: 0
}

main {
    margin-top: 160px;
    display: block
}

@keyframes diagonal {
    100% {
        -webkit-clip-path: polygon(0 0, 200% 0, 0 200%);
        clip-path: polygon(0 0, 200% 0, 0 200%);
        transform: translateX(0) scale(1) skew(0)
    }
}

@keyframes slideInUp {
    0% {
        transform: translateY(100%)
    }

    100% {
        transform: translateY(0)
    }
}

.main-visual {
    animation: 1.5s fadeIn;
    width: 100%;
    height: auto;
    /* autoに変更 */
    position: relative;
    overflow: visible;
    /* hiddenからvisibleに変更 */
    font-size: 1vw;
    background-color: #182e78;
    display: flex;
    /* 追加 */
    flex-direction: column;
    /* 追加 */
}

.main-visual h1 {
    position: absolute
}

.common_visual .products-name,
.main-visual .products-name {
    position: static;
    margin: 0;
    width: 100%;
    z-index: 15;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.75em;
    font-weight: 700;
    font-style: normal;
    background-color: #fff;
    padding: 0.75em 0;
    flex-wrap: wrap;
    font-size: 1em;
}

.common_visual .products-name a,
.main-visual .products-name a {
    background-color: #fff;
    color: #182e78;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row;
    gap: 0.25em;
    padding: 0.3em;
    text-align: center;
    border-radius: 0;
    text-decoration: none;
    border: none;
    transition: 0.2s all;
    border: 0.15em solid #182e78;
    border-radius: 0.3em;
    box-shadow: 0 0.2em 0 #182e78;
    margin-top: -0.2em;
    background-color: #ebf4fe;
}

.common_visual .products-name a img,
.main-visual .products-name a img {
    width: 2.5em;
    height: 2.5em;
    object-fit: contain;
    margin: 0;
}

.common_visual .products-name a span,
.main-visual .products-name a span {
    font-weight: bold;
    text-align: center;
    white-space: nowrap;
    color: #1e3470;
    font-size: 1em;
}

.common_visual .products-name a::before,
.main-visual .products-name a::before {
    content: "";
    width: 1em;
    height: 1em;
    border-right: 0;
    order: 3;
    background-image: url(/img/common/btn-arrow.svg);
    background-repeat: no-repeat;
    background-size: 100%;
    background-position: center;
}

.common_visual .products-name a:hover,
.main-visual .products-name a:hover {
    box-shadow: 0 0em 0 #182e78;
    transform: translateY(0.2em);
    opacity: 1;
}

.about-btn-wrap .btn_links:hover,
.about-btn-wrap .btn_links-white:hover,
.about-btn-wrap .btn_links_red:hover {
    background-color: #ffff2b;
    color: #182e78;
    border: 1px solid #182e78;
}

.main-visual h1 {
    top: 55%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 20;
    font-size: 1.7em;
    text-align: left;
    color: #fff;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: stretch;
    gap: .1em;
    font-weight: 900;
    font-style: normal;
    white-space: nowrap;
    line-height: 1;
    background: #192E77;
    background: linear-gradient(90deg, rgba(25, 46, 119, 0) 0%, rgba(25, 46, 119, 1) 5%, rgba(25, 46, 119, 1) 95%, rgba(25, 46, 119, 0) 100%)
}

.main-visual h1 .h1-wrap {
    padding: .15em 1em .2em
}

.main-visual h1 .h1-wrap span {
    font-size: .9em;
    padding: 0
}

.main-visual picture,
.main-visual img{
	width: 100%;
}

.main-visual-img {
    display: block;
    line-height: 0;
    width: 100%;
}

.main-visual-img img {
    width: 100%;
    height: auto;
    object-fit: contain;
    display: block;
    vertical-align: bottom;
}

@keyframes loop-slide {
    from {
        transform: translateX(0)
    }

    to {
        transform: translateX(-100%)
    }
}

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

    .drop_menu #NavWrap,
    .drop_menu #switch~label,
    header .menu_top {
        position: fixed;
        box-sizing: border-box
    }

    header .menu_top {
        padding: 0;
        z-index: 150;
        max-height: 60px;
        background-color: #fff
    }

    .drop_menu #switch~label {
        display: block;
        cursor: pointer;
        top: 0;
        right: 0;
        transition: transform 0.5s, right 0.2s;
        text-align: center;
        z-index: 170
    }

    .drop_menu #switch~label p {
        z-index: 2;
        width: 100%;
        margin-bottom: 0
    }

    .drop_menu #switch~label span {
        cursor: -webkit-grabbing;
        display: block;
        background: #182e78;
        transition: transform 0.2s, background 0.5s;
        position: absolute;
        left: 0;
        right: 0;
        width: 23px;
        height: 2px;
        top: 28px;
        margin: auto
    }

    .drop_menu #switch~label span::after,
    .drop_menu #switch~label span::before {
        content: "";
        display: block;
        width: 60px;
        height: 3px;
        background: #182e78;
        position: absolute;
        margin-top: 0
    }

    .drop_menu #switch:checked~label span {
        transform: rotate(-45deg)
    }

    .drop_menu #switch:checked~label span:before {
        top: 0
    }

    .drop_menu #switch:checked~label span:after {
        transform: rotate(270deg);
        top: 0;
        margin-top: 0
    }

    .drop_menu #switch:checked~label+#NavWrap {
        visibility: visible;
        max-height: 100vh;
        top: 0;
        left: auto;
        right: 0
    }

    .drop_menu #NavWrap {
        z-index: 100;
        height: 100%;
        overflow: auto;
        visibility: hidden;
        transition: 0.25s;
        position: fixed;
        left: auto;
        top: -100%;
        padding: 20px 15px;
        margin: 60px 0 0;
        width: 100%;
        height: calc(100vh - 60px);
        background: #fff
    }

    .drop_menu #NavWrap::-webkit-scrollbar {
        height: 10px;
        width: 10px
    }

    .drop_menu #NavWrap::-webkit-scrollbar-track {
        border-radius: 10px;
        background: #b3b3b3
    }

    .drop_menu #NavWrap::-webkit-scrollbar-thumb {
        border-radius: 10px
    }

    .drop_menu #NavWrap>ul {
        width: 100%;
        margin-right: 0;
        margin-left: auto
    }

    .drop_menu #NavWrap li a span {
        border-left: none
    }

    body {
        padding-top: 60px
    }

    header#fix_menu,
    header#fix_menu.fixedMenu {
        top: 0;
        transition: none;
        position: fixed;
        position: 999999999
    }

    header {
        height: 3em
    }

    header .menu_top #site_ttl .col2 {
        padding: .5em;
        gap: .5em
    }

    header .menu_top #site_ttl img {
        height: min(3em, 11vw);
        margin-bottom: 0
    }

    header .menu_top #site_ttl .edon {
        height: min(3em, 8vw)
    }

    header .menu_top .right_menu {
        margin-right: 36px;
        gap: .5em;
        width: auto;
        padding: 0
    }

    header .menu_top .right_menu li a div {
        justify-content: center;
        text-align: center;
        align-items: center
    }

    header .menu_top .right_menu li a div span {
        font-size: .8em;
        white-space: nowrap
    }

    header .menu_top .right_menu li a div span:first-child {
        font-size: 1em
    }

    .drop_menu #NavWrap li a span:after,
    .drop_menu #NavWrap ul li.drop_wrap:after,
    .drop_menu #NavWrap ul>li.display_pc,
    header .menu_top .right_menu .contact_btn a::after,
    header .menu_top .right_menu .freedial {
        display: none
    }

    header .menu_top .right_menu .contact_btn {
        width: 5em;
        height: 4em
    }

    header .menu_top .right_menu .contact_btn a {
        padding: 0;
        gap: 0;
        flex-direction: column
    }

    header .menu_top .right_menu .contact_btn a::before {
        width: 1.5em;
        height: 1.5em
    }

    header .menu_top .right_menu .mail a {
        background: #2973d7;
        border: 2px solid #2973d7
    }

    header .menu_top .right_menu .line a {
        background: #00b900;
        border: 2px solid #00b900
    }

    header .menu_top .right_menu .line a:before {
        background-image: url(../img/common/icon_ctt_line.svg)
    }

    header .menu_top .right_menu .line a:hover::before {
        background-image: url(../img/common/icon_ctt_line_blu.svg)
    }

    .drop_menu #NavWrap li a:hover,
    .type_general .drop_menu #switch~label,
    .type_general header .menu_top {
        background: 0 0
    }

    header .menu_top .logo a+a {
        margin-left: 6px
    }

    header .menu_top .logo a img {
        width: 58px;
        height: auto;
        vertical-align: middle
    }

    header .menu_top .logo a+a img {
        width: 181px
    }

    header .menu_top .logo span {
        font-size: 8px;
        vertical-align: middle
    }

    header .menu_top .menu_fix {
        position: relative
    }

    header .menu_top .outwrap {
        padding: 5px 10px;
        height: 50px
    }

    .type_general header .menu_top .outwrap {
        background: #fff
    }

    .drop_menu #switch~label {
        padding: 12px;
        width: 60px;
        height: 60px;
        position: absolute
    }

    .drop_menu #switch~label span:after,
    .drop_menu #switch~label span:before {
        width: 23px;
        height: 2px;
        margin-top: 0
    }

    .drop_menu #switch~label span:before {
        top: -6px
    }

    .drop_menu #switch~label span:after {
        top: 6px
    }

    .type_general .drop_menu #switch~label span,
    .type_general .drop_menu #switch~label span:after,
    .type_general .drop_menu #switch~label span:before,
    .type_general .fixed .drop_menu #switch~label span,
    .type_general .fixed .drop_menu #switch~label span:after,
    .type_general .fixed .drop_menu #switch~label span:before {
        background: #1d3cc8
    }

    .drop_menu #NavWrap ul {
        display: block;
        border-left: none;
        width: 100%;
        padding: 0;
        margin: 20px 0
    }

    .drop_menu #NavWrap ul li {
        position: relative;
        display: block;
        padding: 0;
        border-top: 1px solid #c7c7c7;
        width: 100%
    }

    .drop_menu #NavWrap ul li:after {
        position: absolute;
        display: inline-block;
        content: "";
        width: 8px;
        height: 8px;
        border-top: 2px solid #182e78;
        border-right: 2px solid #182e78;
        transform: rotate(45deg);
        top: 0;
        bottom: 0;
        right: 10px;
        margin: auto
    }

    .drop_menu #NavWrap ul li:last-of-type {
        border-bottom: 1px solid #c7c7c7
    }

    .drop_menu #NavWrap li a span br,
    .drop_menu #NavWrap ul>li.display_sp {
        display: block
    }

    .drop_menu #NavWrap li a,
    .drop_menu #NavWrap li a:hover,
    .drop_menu #NavWrap li p {
        font-size: 14px;
        text-align: left;
        width: auto;
        padding: 0;
        text-decoration: none;
        background: 0 0;
        color: #282828;
        border: none
    }

    .drop_menu #NavWrap li a span,
    .drop_menu #NavWrap li p span {
        display: block;
        padding: 15px 20px 15px 4px;
        font-weight: 700;
        background: 0 0;
        line-height: 1.4;
        white-space: nowrap
    }

    .drop_menu #NavWrap li.drop_wrap i {
        display: block;
        width: 50px;
        height: 50px;
        cursor: pointer;
        position: absolute;
        top: 0;
        right: 0;
        z-index: 10
    }

    .drop_menu #NavWrap ul li.drop_wrap i:after,
    .drop_menu #NavWrap ul li.drop_wrap i:before {
        content: "";
        width: 16px;
        height: 2px;
        display: block;
        position: absolute;
        right: 4px;
        top: 0;
        bottom: 0;
        margin: auto;
        z-index: 20;
        background: #182e78;
        transition: transform 0.4s
    }

    .drop_menu #NavWrap li.drop_wrap ul,
    .drop_menu #NavWrap li.drop_wrap:hover ul {
        opacity: 0;
        visibility: hidden;
        display: block;
        position: static;
        transform: none;
        width: 100%;
        max-height: 0;
        overflow: hidden;
        transition: opacity 0.4s, visibility 0.4s, max-height 0.4s;
        margin: 0
    }

    .drop_menu #NavWrap ul li.drop_wrap.opened ul {
        opacity: 1;
        visibility: visible;
        max-height: 100vh
    }

    .drop_menu #NavWrap ul li.drop_wrap i:after {
        transform: rotate(90deg)
    }

    .drop_menu #NavWrap ul li.drop_wrap.opened i:before {
        transform: rotate(180deg)
    }

    .drop_menu #NavWrap ul li.drop_wrap.opened i:after {
        transform: rotate(-180deg)
    }

    .drop_menu #NavWrap li.drop_wrap ul li+li {
        border-top: 1px solid #ccc
    }

    .drop_menu #NavWrap li.drop_wrap ul li a {
        font-size: 12px;
        text-align: left;
        width: auto;
        padding: 0;
        text-decoration: none;
        background: #fff;
        color: #333;
        border: none
    }

    .drop_menu #NavWrap li.drop_wrap ul li a span {
        padding: 10px 20px;
        border: none;
        font-weight: 400;
        background: #e3f5ff
    }

    .drop_menu #NavWrap .col2 {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        gap: .5em;
        margin-top: 10px
    }

    #NavWrap .col2_btn {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: calc(50% - 0.25em);
        height: auto;
        background: linear-gradient(90deg, rgba(235, 244, 254, 1) 92%, rgba(25, 46, 119, 1) 92%);
        border-radius: .5em;
        border: .15em solid #192e77;
        box-sizing: border-box;
        overflow: hidden
    }

    .col2_btn div {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: .2em;
        width: 100%;
        padding: .3em
    }

    .col2_btn div img {
        height: 100%;
        width: 3em;
    }

    .col2_btn div span {
        font-size: 4vw;
        font-weight: 700;
        color: #192e77;
        text-align: left;
        width: 100%;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .col2_btn .arrow {
        content: "";
        height: 100%;
        width: 1em;
        display: flex;
        align-items: center;
        justify-content: center;
        position: relative
    }

    .col2_btn span::after {
        content: "";
        height: .35em;
        width: .35em;
        border-top: .2em solid #fff;
        border-right: .2em solid #fff;
        position: absolute;
        left: 45%;
        top: 50%;
        transform: translate(-50%, -50%) rotate(45deg)
    }

    .drop_menu #NavWrap .btn_links span,
    .drop_menu #NavWrap .btn_links_red span {
        position: relative;
        display: inline-block;
        padding-left: 30px
    }

    .drop_menu #NavWrap .btn_links span:before,
    .drop_menu #NavWrap .btn_links_red span:before {
        position: absolute;
        display: inline-block;
        content: "";
        top: 0;
        bottom: 0;
        left: 0;
        margin: auto
    }

    .drop_menu #NavWrap .btn_service span:before {
        width: 25px;
        height: 22px;
        background: url(../img/common/icon_crown.webp) 0 0 / cover
    }

    .drop_menu #NavWrap .btn_shop span:before {
        width: 21px;
        height: 22px;
        background: url(../img/common/icon_map.webp) 0 0 / cover
    }

    .drop_menu #NavWrap .btn_waterheater span:before {
        width: 22px;
        height: 22px;
        background: url(../img/common/icon_spanner.webp) 0 0 / cover
    }

    .drop_menu #NavWrap .btn_waterheater a {
        padding: 7px 20px 8px 10px;
        line-height: 1.2;
        text-align: left
    }

    .drop_menu #NavWrap>p {
        text-align: left;
        margin: 10px 0;
        font-size: 12px
    }

    .drop_menu #NavWrap .freedial_wrap {
        margin-top: 30px;
        width: 100%;
        min-width: auto
    }

    .common_visual,
    .main-visual {
        font-size: 1.5vw;
        height: 100%;
        width: 100%
    }

    /* .common_visual .products-name,
    .main-visual .products-name {
        position: static;
        box-sizing: border-box;
        width: 100%;
        margin: 0 auto;
        z-index: 15;
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        grid-template-rows: repeat(3, 1fr);
        gap: 10px;
        padding: 15px 10px;
        background-color: #fff;
    } */

    .common_visual .products-name,
    .main-visual .products-name {
        position: static;
        box-sizing: border-box;
        width: 100%;
        font-size: min(2.6em, 23px);
        margin: 0 auto;
        z-index: 15;
        display: grid;
        gap: .2em;
        padding: .2em;
        grid-template-areas: "waterheater ecocute stoveburner" " dishwasher ih rangefood";
        grid-template-columns: repeat(3, 1fr);
        grid-template-rows: 1fr 1fr;
        background-color: #182e78
    }

    .common_visual .products-name .waterheater,
    .main-visual .products-name .waterheater {
        grid-area: waterheater
    }

    .common_visual .products-name .stoveburner,
    .main-visual .products-name .stoveburner {
        grid-area: stoveburner
    }

    .common_visual .products-name .dishwasher,
    .main-visual .products-name .dishwasher {
        grid-area: dishwasher
    }

    .common_visual .products-name .rangefood,
    .main-visual .products-name .rangefood {
        grid-area: rangefood
    }

    .common_visual .products-name .ecocute,
    .main-visual .products-name .ecocute {
        grid-area: ecocute
    }

    .common_visual .products-name a,
    .main-visual .products-name a {
        background-color: #ebf4fe;
        color: #182e78;
        border-radius: 0;
        width: auto;
        border: none;
        white-space: nowrap;
        position: relative;
        font-weight: 900;
        font-size: 1.05em;
        padding: .3em 0
    }

    /* .common_visual .products-name a,
    .main-visual .products-name a {
        background-color: #ebf4fe;
        color: #182e78;
        border-radius: 10px;
        border: 2px solid #182e78;
        width: 100%;
        padding: 15px 10px;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        box-sizing: border-box;
        min-height: 120px;
    } */

    /* .common_visual .products-name a img,
    .main-visual .products-name a img {
        width: 60px;
        height: 60px;
        object-fit: contain;
        margin-bottom: 8px;
    }

    .common_visual .products-name a span,
    .main-visual .products-name a span {
        font-size: 12px;
        font-weight: bold;
        text-align: center;
        white-space: nowrap;
        color: #182e78;
        line-height: 1.3;
    } */

    /* 特定の順序を指定する場合
    .main-visual .products-name .waterheater {
        order: 1;
    }

    .main-visual .products-name .ecocute {
        order: 2;
    }

    .main-visual .products-name .stoveburner {
        order: 3;
    }

    .main-visual .products-name .dishwasher {
        order: 4;
    }

    .main-visual .products-name .ih {
        order: 5;
    }

    .main-visual .products-name .rangefood {
        order: 6;
    } */

    .common_visual .products-name a::before,
    .main-visual .products-name a::before {
        width: 1.5em;
        height: 1.5em;
        border-right: 0;
    }

    .main-visual h1 {
        font-size: 3.5em;
        top: 42%;
        transform: translate(-50%, -50%);
        gap: .3em;
        background: #192E77;
        background: linear-gradient(90deg, rgba(25, 46, 119, 0) 0%, rgba(25, 46, 119, 1) 5%, rgba(25, 46, 119, 1) 95%, rgba(25, 46, 119, 0) 100%)
    }

    .main-visual h1 .h1-wrap {
        padding: .15em 1em .2em;
        line-height: 1
    }

    .main-visual h1 .h1-wrap span {
        font-size: .9em;
        padding: 0
    }
}

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

    .common_visual .products-name,
    .main-visual .products-name {
        position: static;
        box-sizing: border-box;
        width: 100%;
        margin: 0 auto;
        z-index: 15;
        display: grid;
        grid-template-columns: 1fr 1fr 1fr;
        grid-auto-rows: 1fr;
        gap: 0.2em;
        padding: 0.2em;
        background-color: #182e78;
    }

    .common_visual .products-name a,
    .main-visual .products-name a {
        color: #182e78;
        border-radius: 0.2em;
        width: 100%;
        min-width: 0;
        max-width: 100%;
        padding: 0.3em 0.2em;
        justify-content: flex-start;
        box-sizing: border-box;
        height: 100%;
        text-decoration: none;
        min-height: 0;
        position: relative;
        gap: 0;
    }

    .products-name a::after {
        content: "";
        position: absolute;
        top: 50%;
        right: 1em;
        display: block;
        border-top: 0.15em solid #182e78;
        border-right: 0.15em solid #182e78;
        height: 0.3em;
        width: 0.3em;
        transform: translateY(-50%) rotate(45deg);
        z-index: 9999999999;
    }


    .common_visual .products-name a img,
    .main-visual .products-name a img {
        width: 2em;
        height: 2em;
        object-fit: contain;
        margin-bottom: 0;
        flex-shrink: 0;
        margin-right: 0;
    }

    .common_visual .products-name a span,
    .main-visual .products-name a span {
        font-size: 3.3vw;
        font-weight: bold;
        text-align: left;
        width: 100%;
        color: #182e78;
        line-height: 1.1;
        white-space: normal;
        word-break: break-word;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .common_visual .products-name a::after,
    .main-visual .products-name a::after {
        display: none;
    }

    /* PC版テキストを非表示 */
    .common_visual .products-name a .pc-text,
    .main-visual .products-name a .pc-text {
        display: none;
    }

    /* スマホ版テキストを表示 */
    .common_visual .products-name a .sp-text,
    .main-visual .products-name a .sp-text {
        display: block;
    }

    /* 明示的な配置 */
    .main-visual .products-name .waterheater {
        order: 1;
    }

    .main-visual .products-name .ecocute {
        order: 2;
    }

    .main-visual .products-name .stoveburner {
        order: 3;
    }

    .main-visual .products-name .dishwasher {
        order: 4;
    }

    .main-visual .products-name .ih {
        order: 5;
    }

    .main-visual .products-name .rangefood {
        order: 6;
    }

}

/* より小さい画面用（430px以下） */
@media screen and (max-width: 429px) {

    .common_visual .products-name a span,
    .main-visual .products-name a span {
        font-size: 3.3vw;
    }
}

.section01_wrap {
    margin: 0;
}

.strengths_wrap {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    margin-bottom: 1.5em;
    font-size: 1vw;
    box-sizing: border-box
}

.strengths_wrap .strengths_items {
    background: var(--base-collar);
    display: flex;
    flex-direction: column;
    padding: 1em;
    box-sizing: border-box;
    width: 100%;
    height: auto;
    font-size: .9em;
    font-weight: 700;
    color: #182e78;
    text-align: center;
    justify-content: center;
    align-items: center;
    border-left: .15em solid #182e78;
    border-right: .15em solid #182e78;
    border-top: .3em solid #182e78;
    border-bottom: .3em solid #182e78;
    white-space: nowrap
}

.strengths_wrap .strengths_items:last-child {
    border-right: .3em solid #182e78
}

.strengths_wrap .strengths_items:first-child {
    border-left: .3em solid #182e78
}

.strengths_wrap .strengths_items span {
    display: block;
    color: #182e78;
    font-size: 1.4em;
    line-height: 1.1;
    background: linear-gradient(transparent 40%, #ffff2b 0)
}

.side-note,
.side-note-b {
    width: 100%;
    text-align: left;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center
}

.side-note div,
.side-note-b div {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: #fff;
    padding: 1em;
    border-radius: .3em;
    margin: 0 1em;
    font-weight: 700;
    font-size: max(1em, 16px);
    width: auto;
    max-width: 50em
}

.side-note-b div {
    background-color: #ebf4fe
}

.about-btn-wrap .btn_links-white,
.about-btn-wrap .btn_links,
.about-btn-wrap .btn_links_red {
    position: relative;
    display: block;
    width: 100%;
    max-width: 333px;
    border: 1px solid #182e78;
    background: #182e78;
    border-radius: 100vw;
    color: #fff;
    text-align: center;
    padding: 18px 30px;
    box-sizing: border-box;
    font-weight: 700;
    transition: background 0.4s, color 0.4s;
    margin: 2em auto;
    font-size: 16px;
    text-decoration: none
}

.about-btn-wrap .btn_links_red {
    border: 1px solid #cc0018;
    background: #cc0018;
}

.about-btn-wrap .btn_links-white {
    border: 1px solid #fff;
    background: #fff;
    color: #182e78
}

.about-btn-wrap .btn_links-white::before,
.about-btn-wrap .btn_links::before,
.about-btn-wrap .btn_links_red::before {
    position: absolute;
    display: inline-block;
    content: "";
    width: 0.5em;
    height: 0.5em;
    border-top: 0.15em solid #fff;
    border-right: 0.15em solid #fff;
    top: 0;
    bottom: 0;
    right: 1em;
    margin: auto;
    transform: rotate(45deg);
    transition: border-color 0.4s
}

.about-btn-wrap .btn_links-white::before,
.about-btn-wrap .btn_links:hover::before,
.about-btn-wrap .btn_links_red:hover::before {
    border-top: 2px solid #182e78;
    border-right: 2px solid #182e78
}

.about-btn-wrap {
    margin-top: 16px;
    display: flex;
    gap: 2em;
    /* 1em から 2em に変更 */
    justify-content: center;
    flex-wrap: wrap;
}

.about-btn-wrap .btn_links-white {
    margin: 0 !important;
    min-width: 300px;
    /* 最小幅を設定 */
}

@media screen and (max-width: 768px) {
    .about-btn-wrap {
        flex-direction: column;
        gap: 1em;
        margin: 1em;
        align-items: center;
    }

    .about-btn-wrap .btn_links-white {
        width: 100%;
        max-width: 1200px;
        /* 追加 */
        margin: 0 auto;
        /* 追加 */
    }
}

/* reviewsページ専用のスタイル */
.reviews .step_wrap {
    /* reviewsページの.step_wrap用スタイル */
    background: #142e7a;
    padding: 60px 0;
}

.reviews .step_wrap .step_list {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    color: #fff;
    padding: 20px 0;
    gap: 10px;
    /* アイテム間の間隔 */
}

.reviews .step_wrap .step_list .step_items {
    flex: 1;
    /* 均等に幅を配分 */
    min-width: 0;
    /* flexの縮小を許可 */
    /* width: 220px; を削除 */
    /* flex-shrink: 0; を削除 */

    /* ===== menu_bottomのみを横スクロール可能に表示 ===== */

    /* menu_bottomを表示 */
    header .menu_bottom {
        display: block !important;
        position: fixed !important;
        top: 60px !important;
        left: 0;
        right: 0;
        width: 100%;
        z-index: 140;
        background: #182e78;
        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        -ms-overflow-style: none;
        height: auto;
        padding: 0;
    }

    header .menu_bottom::-webkit-scrollbar {
        display: none;
        width: 0;
        height: 0;
    }

    header .menu_bottom .menu_fix {
        min-width: max-content;
        width: auto;
        margin: 0;
        padding: 0;
    }

    header .menu_bottom .drop_menu {
        max-width: none;
        width: auto;
        margin: 0;
    }

    header .menu_bottom .drop_menu #NavWrap {
        position: static !important;
        visibility: visible !important;
        opacity: 1 !important;
        height: auto !important;
        width: auto !important;
        max-height: none !important;
        background: transparent !important;
        padding: 0 !important;
        margin: 0 !important;
        overflow: visible !important;
        transition: none !important;
        transform: none !important;
        top: auto !important;
        left: auto !important;
        right: auto !important;
    }

    header .menu_bottom .drop_menu #NavWrap>ul {
        display: flex !important;
        flex-wrap: nowrap !important;
        flex-direction: row !important;
        overflow-x: visible !important;
        overflow-y: hidden !important;
        white-space: nowrap;
        width: auto !important;
        min-width: max-content;
        padding: 0 !important;
        margin: 0 !important;
        border-left: none !important;
        border-top: none !important;
        border-bottom: none !important;
        background: #182e78;
    }

    header .menu_bottom .drop_menu #NavWrap>ul>li {
        flex-shrink: 0 !important;
        flex-grow: 0 !important;
        min-width: fit-content !important;
        width: auto !important;
        display: inline-block !important;
        padding: 0 !important;
        border-top: none !important;
        border-bottom: none !important;
        border-left: none !important;
        position: static !important;
        vertical-align: middle;
    }

    header .menu_bottom .drop_menu #NavWrap>ul>li>a {
        white-space: nowrap !important;
        padding: 14px 0 !important;
        font-size: 14px !important;
        display: block !important;
        text-align: center;
        background: #182e78 !important;
        color: #fff !important;
        width: 100%;
        line-height: 1;
        box-sizing: border-box;
        transition: background 0.5s, color 0.5s;
    }

    header .menu_bottom .drop_menu #NavWrap>ul>li>a>span {
        white-space: nowrap !important;
        font-size: 14px !important;
        padding: 4px 0;
        border-right: 1px solid #fff;
        border-left: none !important;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        font-weight: 700;
    }

    header .menu_bottom .drop_menu #NavWrap>ul>li:first-of-type>a>span {
        border-left: 1px solid #fff;
    }

    header .menu_bottom .drop_menu #NavWrap>ul>li:last-child>a>span {
        border-right: none;
    }

    header .menu_bottom .drop_menu #NavWrap>ul>li>a:hover {
        opacity: 1;
        background: #fff !important;
        color: #182e78 !important;
    }

    header .menu_bottom .drop_menu #NavWrap>ul>li.display_pc {
        display: inline-block !important;
    }

    header .menu_bottom .drop_menu #NavWrap>ul>li.display_sp {
        display: none !important;
    }

    header .menu_bottom .drop_menu #NavWrap .col2,
    header .menu_bottom .drop_menu #NavWrap .btn_links,
    header .menu_bottom .drop_menu #NavWrap .btn_links_red,
    header .menu_bottom .drop_menu #NavWrap>.display_sp {
        display: none !important;
    }

    body {
        padding-top: 110px !important;
    }

    main {
        margin-top: 0 !important;
    }

    /* ===== menu_bottom表示ここまで ===== */
}

/* スマホ対応 */
@media screen and (max-width:768px) {
    .reviews .step_wrap .step_list {
        flex-direction: column;
        gap: 20px;
    }

    .reviews .step_wrap .step_list .step_items {
        width: 100%;
    }
}

.crowns_wrap,
.waterheater_contents {
    margin: 60px 0
}

.contact_wrap .sitewrap,
.crowns_wrap .crowns_tit,
.no_txt {
    text-align: center
}

.crowns_wrap .crowns_tit span,
.shop_wrap .shop_area .shop_tit span {
    position: relative;
    display: inline-block;
    font-size: 28px;
    font-weight: 700;
    padding: 0 70px
}

.crowns_wrap .crowns_tit span:after,
.crowns_wrap .crowns_tit span:before {
    position: absolute;
    display: inline-block;
    content: "";
    background-image: url(../img/common/dec_blu_l.webp);
    background-repeat: no-repeat;
    top: 0;
    left: 0;
    width: 68px;
    height: 97px
}

.crowns_wrap .crowns_tit span:after,
.shop_wrap .shop_area .shop_tit span:after {
    background-image: url(../img/common/dec_blu_r.webp);
    left: auto;
    right: 0
}

.crowns_wrap .crowns_tit span b {
    display: block;
    font-size: 48px;
    color: #d4002d
}

.crowns_wrap .img_wrap {
    margin-top: 20px
}

.crowns_wrap .img_wrap img {
    display: block;
    margin: auto
}

.caution_wrap,
.caution_wrap_2 {
    display: flex;
    border: 2px solid #182e78;
    border-radius: 10px;
    overflow: hidden;
    max-width: 1000px;
    margin: 0 auto
}

.caution_wrap {
    margin-bottom: 3em;
    background-color: #fff
}

.caution_wrap_2 {
    background: #fff;
    margin: 1em auto
}

.news_wrap,
.products_wrap {
    background: #ebf4fe
}

.caution_wrap dt,
.caution_wrap_2 dt {
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    width: 11em;
    min-width: 11em;
    font-size: 1.3em;
    font-weight: 700;
    box-sizing: border-box;
    padding: .5em
}

.caution_wrap dd,
.caution_wrap_2 dd {
    font-size: 16px;
    padding: 5px 20px;
    box-sizing: border-box;
    text-align: left;
    display: flex;
    align-items: center
}

.caution_wrap dd span,
.caution_wrap_2 dd span {
    font-size: 18px;
    font-weight: 700;
    color: #182e78
}

.caution_wrap_2 dt {
    background: #3578d2;
    background: linear-gradient(203deg, #3578d2 0, #142e7a 100%)
}

.lineup * {
    box-sizing: border-box;
}

.lineup .sitewrap {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 2em;
}

.lineup .lineup_items {
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    justify-content: center;
    gap: 3em;
    margin-bottom: 0.3em;
}

.lineup_tit {
    font-size: 3em;
    color: #182e78;
    font-weight: bold;
}

.lineup .lineup_item {
    background-color: white;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    border: 0.15em solid #182e78;
    border-radius: 1em;
    overflow: hidden;
    box-shadow: 0 0.3em 0 #182e78;
    text-decoration: none;
    width: 17em;
    transition: 0.2s all;
}

.lineup .lineup_item img {
    width: 100%;
    aspect-ratio: 300/240;
}

.lineup_item_text {
    padding: 0.5em 1em;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.lineup_item_text::after {
    content: '';
    height: 2em;
    width: 2em;
    background-image: url(/img/common/btn-arrow.svg);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
}

.lineup_item_text p {
    font-weight: bold;
    font-size: 1.7em;
    color: #182e78;
    line-height: 1.2;
}

.lineup .lineup_item:hover {
    box-shadow: 0 0em 0 #182e78;
    transform: translateY(0.3em);
}

@media screen and (max-width: 768px) {
    .lineup .sitewrap {
        padding: 0;
    }

    .lineup_tit {
        font-size: 10vw;
    }

    .lineup .lineup_items {
        gap: 1.5em;
    }

    .lineup .lineup_item {
        width: calc(100% / 2 - 1em);
        border-radius: 0.5em;
    }

    .lineup_item_text {
        padding: 0.5em;
    }

    .lineup_item_text p {
        font-size: 1.3em;
    }

    .lineup_item_text::after {
        height: 1.5em;
        width: 1.5em;
    }
}

.reviews_wrap {
    padding: 0;
    margin-bottom: 3em;
}

.reviews_area {
    max-width: 1200px;
    margin: 0 auto;
}

.reviews_tit {
    font-size: 2.5em;
    font-weight: bold;
    text-align: center;
    margin-bottom: 0.5em;
    color: #182e78;
}

.reviews_tit span {
    position: relative;
    padding-bottom: 15px;
}

.reviews_tit span::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 60px;
    height: 3px;
    background: #c40000;
}

.reviews_content {
    /* Google口コミ用のスペース */
    min-height: 200px;
}

@media screen and (max-width: 768px) {
    .reviews_wrap {
        padding: 0;
    }

    .reviews_tit {
        font-size: 24px;
        margin-bottom: 30px;
        padding: 0 20px;
    }
}

.news_wrap {
    padding: 0;
}

.news_wrap .news_area {
    background: #fff;
    padding: 40px 100px;
    border-radius: 0.3em;
}

.news_wrap .news_area .news_tit {
    text-align: center;
    font-size: 32px;
    font-weight: 700;
    margin-bottom: 25px
}

.news_wrap .news_area .txt_links {
    margin-top: 10px;
    text-align: right
}

.products_wrap .introduction_wrap {
    position: relative;
    background-color: #182e78;
    background-position: center;
    background-size: cover;
    padding: 50px 0;
    text-align: center;
    color: #fff;
    margin-bottom: 4em
}

.contact_wrap .col3 .freecall_items dt span:before,
.products_tit::after,
.products_tit::before,
.products_wrap .maker_wrap dl .speech-bubble {
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat
}

.products_wrap .introduction_wrap:after,
.products_wrap .introduction_wrap:before {
    position: absolute;
    display: inline-block;
    content: "";
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 58px 135px 0;
    border-color: #ffeb0f transparent transparent;
    bottom: -30px;
    left: 0;
    right: 0;
    margin: auto;
    z-index: 10
}

.products_wrap .introduction_wrap:after {
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 58px 135px 0;
    border-color: #182e78 transparent transparent;
    z-index: 5;
    bottom: -32px
}

.products_wrap .introduction_wrap .intro_tit {
    font-size: 3em;
    font-weight: 700
}

.products_wrap .introduction_wrap .intro_tit span {
    font-size: 1.3em;
    color: #ffec0f;
    margin: 0 .1em
}

.products_wrap .introduction_wrap .sub_tit {
    font-size: 1.1em;
    margin-bottom: 20px
}

.products_tit {
    font-size: 60px;
    font-weight: 700;
    margin-bottom: 10px;
    margin-top: 60px;
    white-space: nowrap;
    display: inline-block;
    position: relative
}

.products_tit::before {
    background-image: url(../img/common/dec_blu_l.webp);
    right: 100%
}

.products_tit::after {
    background-image: url(../img/common/dec_blu_r.webp);
    left: 100%
}

.products_tit::after,
.products_tit::before {
    content: "";
    position: absolute;
    width: 60px;
    height: 70px;
    top: 50%;
    transform: translateY(-50%)
}

.products_tit span {
    font-size: 50px
}

.products_wrap .introduction_wrap p {
    font-size: 16px;
    line-height: 2
}

.items-wrap {
    display: flex;
    flex-direction: column;
    gap: 5em
}

.product-items {
    margin: 0 auto;
    padding: 0;
    display: flex;
    flex-direction: column;
    color: #182e78
}

#ecocute-page .product-items {
    gap: 2em
}

#ranking .product-items .items,
.stoveburner_wrap .product-items,
.waterheater_wrap .product-items {
    margin: 0 auto
}

.product-items * {
    box-sizing: border-box
}

.product-items h3 {
    font-size: 4em;
    font-weight: 700;
    margin: 1.5em auto .5em;
    background: linear-gradient(transparent 60%, #ffff2b 60%);
    padding: 0 .3em
}

.product-items h3:first-child {
    margin: 0 auto .5em
}

.product-items .items {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: stretch;
    align-content: stretch;
    gap: 3em;
    margin: 1em auto;
    filter: drop-shadow(.3em .3em .5em rgba(15, 31, 139, .2));
    width: 100%;
    max-width: 85em
}

#merchandise .items{
	margin: 3em auto;
}

#ecocute-page .items{
	margin: 1em auto;
}

.product-items .ranK {
    display: flex;
    flex-direction: column;
    justify-content: stretch;
    align-items: center
}

.product-items .rank-num {
    margin: 0 auto 1em;
    display: block;
    text-align: center;
    height: 5em
}

.product-items .item {
    width: 17em;
    background-color: #182e78;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    border: .15em solid #182e78;
    border-radius: .5em;
    overflow: hidden;
    line-height: 1
}

.contact_wrap .col3 dl,
.products_wrap .maker_wrap dl,
.shop_wrap .shop_area {
    background: #fff;
    box-sizing: border-box
}

.product-items .item .model-code {
    color: #fff;
    width: 100%;
    text-align: center;
    font-size: 1.25em;
    padding: .2em;
    font-weight: 700;
    line-height: 1.1;
    margin: 0;
    background: none
}

.product-items .item .info {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    height: 100%;
    width: 100%;
    background-color: #fff
}

.product-items .item .info .item-imgs {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    height: auto;
    width: 100%
}

.product-items .item .info .item-imgs .item-img {
    width: 100%;
    height: 13em;
    max-height: 20em;
    aspect-ratio: 6/4;
    overflow: hidden;
    -o-object-fit: cover;
    object-fit: cover
}

.product-items .item .info .item-imgs .item-img img {
    -o-object-fit: contain;
    object-fit: contain;
    margin: 0 auto;
    height: 100%;
    max-height: 100%;
    width: 100%;
    max-width: 100%;
    display: block
}

.product-items .item .info .item-imgs .maker-logo {
    height: 2.5em;
    width: auto;
    margin: 0 auto .3em;
    display: block
}

.product-items .item .info .info-wrapper {
    padding: 0 1em 1em;
    min-width: 90%;
    height: 100%;
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    flex-direction: column
}

.product-items .item .info .info-wrapper .partition,
.product-items .item .info .info-wrapper .partition-arrow {
    display: block;
    background-color: #182e78;
    height: .1em;
    width: 100%;
    margin: .5em auto
}

.product-items .item .info .info-wrapper .partition-arrow:first-child,
.product-items .item .info .info-wrapper .partition:first-child {
    margin: 0 auto .5em
}

.product-items .item .info .info-wrapper .partition-arrow {
    margin: 1em auto 1.3em;
    position: relative
}

.product-items .item .info .info-wrapper .partition-arrow .down-arrow {
    width: 5em;
    height: auto;
    margin: 0 auto;
    position: absolute;
    transform: translate(-50%, -50%);
    top: 50%;
    left: 50%
}

.product-items .item .info .info-wrapper .tags {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    align-items: flex-start;
    align-content: flex-start;
    gap: .4em
}

.product-items .item .info .info-wrapper .tags .tag {
    text-align: center;
    background-color: #182e78;
    color: #fff;
    padding: .4em .6em .3em;
    border-radius: 100vw;
    font-size: .8em;
    font-weight: 700
}

.product-items .item .info .info-wrapper .list-price-wrap {
    font-size: .9em;
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: flex-end;
    white-space: nowrap
}

.product-items .item .info .info-wrapper .list-price-wrap .list-price-word {
    text-align: left
}

.product-items .item .info .info-wrapper .list-price-wrap .list-price {
    text-align: right
}

.product-items .item .info .info-wrapper .list-price-wrap .list-price span {
    font-size: 1.3em;
    font-weight: 700
}

.product-items .item .info .info-wrapper .normal-price-wrap {
    display: flex;
    flex-wrap: nowrap;
    justify-content: space-between;
    align-items: flex-end;
    white-space: nowrap;
    border-radius: .5em;
    font-weight: 700;
    margin-bottom: .3em;
    font-size: .9em
}

.product-items .item .info .info-wrapper .normal-price-wrap .normal-price {
    background: linear-gradient(transparent 60%, #ffff2b 60%)
}

.product-items .item .info .info-wrapper .komi {
    background-color: #182e78;
    color: #fff;
    padding: .4em .3em .3em;
    text-align: center;
    border-radius: 100vw;
    margin-bottom: .5em;
    font-size: .9em;
    font-weight: 700
}

.product-items .item .info .info-wrapper .price-wrapper {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center
}

.product-items .item .info .info-wrapper .price-wrapper .price {
    font-size: 2.7em;
    font-weight: 700;
    color: #c11c22;
    margin-bottom: -.2em
}

.product-items .item .info .info-wrapper .price-wrapper .tax-yen {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    margin-left: .2em;
    color: #182e78;
    line-height: .6
}

.product-items .item .info .info-wrapper .price-wrapper .tax-yen .tax {
    font-size: .8em;
    margin-bottom: 1em;
    font-weight: 700;
    white-space: nowrap
}

.product-items .item .info .info-wrapper .price-wrapper .tax-yen .yen {
    font-size: 2em;
    margin-top: -.1em;
    font-weight: 900
}

.product-items .item .info .info-wrapper .price-wrapper .kara {
    font-size: 2em;
    color: #182e78
}

.products_wrap .list_2col .products_items {
    width: 578px;
    margin-bottom: 60px
}

.products_wrap .btn_links a,
.products_wrap .btn_links_red {
    margin: 3em auto
}

.products_wrap .oter_products {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    margin: 3em auto;
    gap: 1em
}

.oter_products_link {
    width: 385px;
    border-radius: .5em;
    border: .1em solid #182e78;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    background-repeat: no-repeat;
    padding: 23px 25px;
    box-sizing: border-box;
    transition: opacity 0.4s;
    background-size: cover;
    background-position: right;
    background-color: #fff;
    content-visibility: auto
}

.oter_products_link:hover {
    text-decoration: none;
    opacity: .8
}

.oter_products_link.lazyloaded {
    background-image: url(../img/common/bg_gas.webp)
}

.oter_products_link.range.lazyloaded {
    background-image: url(../img/common/bg_range.webp)
}

.oter_products_link.dishwasher.lazyloaded {
    background-image: url(../img/common/bg_dishwasher.webp)
}

.oter_products_link.ecocute.lazyloaded {
    background-image: url(../img/common/bg_ecocute.webp)
}

.oter_products_link.waterheater.lazyloaded {
    background-image: url(../img/common/bg_waterheater.webp)
}

.oter_products_link .tit {
    font-size: 24px;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 10px;
    text-shadow: 0 0 .3em #fff, 0 0 .3em #fff, 0 0 .3em #fff, 0 0 .3em #fff
}

.oter_products_link .tit span {
    font-size: 32px;
    color: #182e78
}

.products_link-wrap {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 1.5em
}

.products_link-wrap.oter_products_link {
    width: 100%
}

.products_link-wrap .oter_products_link .tit {
    width: 100%;
    font-size: 24px
}

.products_link-wrap .oter_products_link .tit span {
    width: 100%;
    font-size: 1.5em
}

.products_wrap .maker_wrap {
    margin: 1em auto
}

.products_wrap .maker_wrap dl {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    flex-direction: column;
    max-width: 1000px;
    margin: auto;
    border-radius: 10px;
    position: relative;
    padding: 1em 2em 2em
}

.products_wrap .maker_wrap dl .character {
    position: absolute;
    bottom: 0;
    right: 0
}

.products_wrap .maker_wrap dl .speech-bubble {
    position: absolute;
    right: 0em;
    bottom: 13em;
    width: 10em;
    height: 10em;
    background-image: url(/img/common/speech-bubble.svg);
    z-index: 10
}

.products_wrap .maker_wrap dl .speech-bubble p {
    font-size: 1em;
    font-weight: 700;
    position: absolute;
    top: 45%;
    left: 50%;
    transform: translate(-50%, -50%);
    writing-mode: vertical-rl;
    width: auto;
    height: 7em
}

.products_wrap .maker_wrap dl .speech-bubble p span {
    text-combine-upright: all
}

.products_wrap .maker_wrap dl .professor {
    position: absolute;
    right: 5em;
    bottom: 1em;
    width: 9em;
    z-index: 1
}

.products_wrap .maker_wrap dl .character-description {
    display: block;
    position: absolute;
    bottom: 2em;
    right: -6em;
    width: 10em;
    z-index: 2;
    font-size: .9em;
    font-weight: 700;
    color: #3b3b3b;
    background-color: rgba(255, 255, 255, .7);
    padding: .5em;
    border-radius: .5em
}

.products_wrap .maker_wrap dt {
    text-align: center;
    font-size: 2em;
    font-weight: 700;
    color: #182e78;
    width: 100%;
    display: block;
    padding: 0;
    border-bottom: 2px solid #182e78
}

.products_wrap .maker_wrap dd {
    margin-top: 2em;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 1em 2em;
    width: 100%
}

.products_wrap .maker_wrap dd img {
    height: 3.5em;
    -o-object-fit: contain;
    object-fit: contain
}

.p-maker-outro {
    background: #f2f2f2;
    padding: 40px 0;
    margin: 2% 0% 0% 0%
}

.c-box-inr {
    width: 900px;
    margin: 0 auto;
    padding: 0 16px;
    box-sizing: border-box
}

.c-ttl-c {
    text-align: center
}

.c-ttl {
    font-size: 24px;
    font-weight: 700;
    letter-spacing: .05em;
    margin-bottom: 24px;
    line-height: 1.4
}

.l-page ul {
    line-height: 1.6
}

.p-maker-outro-list {
    width: 804px;
    margin: 12px auto 34px
}

.c-btn-mfr-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2px;
    justify-items: center;
    margin: 0% 26% 0% 0%
}

.c-btn-mfr {
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #fff;
    padding: 14px;
    box-sizing: border-box;
    border: 1px solid #ddd;
    width: 12vw
}

.c-btn-mfr a {
    transition: opacity 0.2s
}

.c-btn-mfr a,
.c-btn-mfr span {
    width: 100%;
    height: 165%;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    background: #fff;
    position: relative
}

.c-btn-mfr a img,
.c-btn-mfr span img {
    vertical-align: middle;
    width: 7vw;
    height: 2vw
}

.c-btn-mfr img {
    transition: filter 0.2s ease
}

.c-btn-mfr img:hover {
    filter: brightness(70%)
}

.contact_wrap {
    background: #182e78;
    padding: 3em 0;
    margin: 3em auto
}

.contact_wrap:last-child {
    margin: 0 auto
}

.contact_wrap .contact_tit {
    margin-bottom: 20px
}

.contact_wrap .contact_tit span {
    position: relative;
    font-size: 32px;
    font-weight: 700;
    color: #fff;
    padding: 0 40px;
    display: inline-block
}

.contact_wrap .contact_tit span:after,
.contact_wrap .contact_tit span:before {
    position: absolute;
    display: inline-block;
    content: "";
    width: 29px;
    height: 46px;
    background-image: url(../img/common/dec_wht_l.webp);
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto
}

.contact_wrap .contact_tit span:after {
    background-image: url(../img/common/dec_wht_r.webp);
    left: auto;
    right: 0
}

.shop_wrap,
footer {
    background: #ebf4fe
}

.contact_wrap .sub_tit {
    color: #fff;
    margin-bottom: 15px
}

.contact_wrap .col4 {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 20px
}

.contact_wrap .col4 p {
    position: relative;
    border: 1px solid #fff;
    border-radius: 5px;
    font-size: 20px;
    font-weight: 700;
    color: #fff;
    padding: 10px 20px 7px 55px;
    line-height: 1;
    margin: 0 .5%
}

.contact_wrap .col4 p:before {
    position: absolute;
    display: inline-block;
    content: "";
    left: 20px;
    top: 0;
    bottom: 0;
    margin: auto
}

.contact_wrap .col4 p.support_item:before {
    width: 26px;
    height: 26px;
    background-image: url(../img/common/icon_support.webp)
}

.contact_wrap .col4 p.estimate_item:before {
    width: 20px;
    height: 26px;
    background-image: url(../img/common/icon_estimate.webp)
}

.contact_wrap .col4 p.price_item:before {
    width: 25px;
    height: 25px;
    background-image: url(../img/common/icon_price.webp)
}

.contact_wrap .col4 p.safety_item:before {
    width: 26px;
    height: 18px;
    background-image: url(../img/common/icon_safety.webp)
}

.contact_wrap .col3 {
    display: flex;
    justify-content: space-around
}

.contact_wrap .col3 dl {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    padding: 20px 10px;
    border-radius: 5px;
    width: 390px
}

.contact_wrap .col3 .freecall_items {
    padding: 20px 10px 10px
}

.contact_wrap .col3 dt {
    border-bottom: 1px solid #c7c7c7;
    margin-bottom: 5px;
    padding-bottom: 10px
}

.contact_wrap .col3 dt span {
    position: relative;
    font-size: 18px;
    font-weight: 700;
    padding-left: 40px
}

.contact_wrap .col3 dt span:before {
    position: absolute;
    display: inline-block;
    content: "";
    left: 10px;
    top: 0;
    bottom: 0;
    margin: auto
}

.contact_wrap .col3 .freecall_items dt span:before {
    width: 18px;
    height: 24px;
    background-image: url(../img/common/icon_ctt_tel_blu.webp)
}

.contact_wrap .col3 .mail_items dt span:before {
    width: 24px;
    height: 18px;
    background-image: url(../img/common/icon_ctt_mail_blu.svg);
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat
}

.contact_wrap .col3 .line_items dt span:before {
    width: 30px;
    height: 28px;
    background-image: url(../img/common/icon_ctt_line_blu.svg);
    background-position: center;
    background-size: contain;
    background-repeat: no-repeat;
    left: 5px
}

.contact_wrap .col3 dd {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center
}

.contact_wrap .col3 .freecall_items dd .freecall_wrap {
    position: relative;
    font-size: 2em;
    font-weight: 700;
    color: #d4002d;
    letter-spacing: -.025em;
    line-height: 1;
    display: block;
    text-align: right;
    padding-top: 4px;
    padding-bottom: 3px;
    padding-left: 50px;
    text-decoration: none
}

.contact_wrap .col3 .freecall_items dd .freecall_wrap:before {
    position: absolute;
    display: inline-block;
    content: "";
    width: 40px;
    height: 32px;
    background: url(../img/common/icon_freedial.webp) 0 0 / cover no-repeat;
    left: 5px;
    top: 0;
    bottom: 0;
    margin: auto
}

.contact_wrap .col3 .freecall_items dd>span {
    display: block;
    color: #333;
    font-size: 14px;
    margin-top: 3px
}

.contact_wrap .col3 .line_items dd .btn_links,
.contact_wrap .col3 .mail_items dd .btn_links,
.contact_wrap .col3 .line_items dd .btn_links_red,
.contact_wrap .col3 .mail_items dd .btn_links_red {
    margin-top: 15px
}

.contact_wrap .col3 dd .btn_links a,
.waterheater_contents .btn_links a,
.contact_wrap .col3 dd .btn_links_red a,
.waterheater_contents .btn_links_red a {
    margin: auto
}

.contact_wrap .col3 dd .btn_links a span,
.contact_wrap .col3 dd .btn_links_red a span {
    position: relative;
    display: inline-block;
    padding-left: 40px
}

.contact_wrap .col3 dd .btn_links a span:before,
.contact_wrap .col3 dd .btn_links_red a span:before {
    position: absolute;
    display: inline-block;
    content: "";
    width: 31px;
    height: 27px;
    background-image: url(../img/common/icon_ctt_tel.webp);
    background-repeat: no-repeat;
    background-size: cover;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto;
    transition: background 0.4s
}

.contact_wrap .col3 .mail_items dd .btn_links a span:before,
.contact_wrap .col3 .mail_items dd .btn_links_red a span:before {
    width: 26px;
    height: 20px;
    background-image: url(../img/common/icon_ctt_mail.svg);
    background-position: center
}

.contact_wrap .col3 .line_items dd .btn_links a span:before,
.contact_wrap .col3 .line_items dd .btn_links_red a span:before {
    width: 30px;
    height: 28px;
    background-image: url(../img/common/icon_ctt_line.svg)
}

.contact_wrap .col3 dd .btn_links a:hover span:before,
.contact_wrap .col3 dd .btn_links_red a:hover span:before {
    background-image: url(../img/common/icon_ctt_tel_blu02.webp)
}

.shop_wrap {
    padding: 80px 0 50px
}

.faq_wrap,
.step_wrap {
    padding: 60px 0
}

.shop_wrap .shop_area {
    position: relative;
    padding: 100px 30px 50px
}

.shop_wrap .shop_area .shop_tit {
    text-align: center;
    position: absolute;
    top: -20px;
    left: 0;
    right: 0;
    margin: auto
}

.shop_wrap .shop_area .shop_tit span:after,
.shop_wrap .shop_area .shop_tit span:before {
    position: absolute;
    display: inline-block;
    content: "";
    background-image: url(../img/common/dec_blu_l.webp);
    background-repeat: no-repeat;
    bottom: 0;
    left: 0;
    width: 68px;
    height: 97px
}

.shop_wrap .shop_area .shop_tit span:after {
    right: 0;
    left: auto;
    transform: scale(-1, 1)
}

.shop_wrap .shop_area .shop_tit span b {
    font-size: 75px;
    color: #d4002d;
    line-height: 1
}

.shop_wrap .shop_area .shop_tit span .sub_tit {
    position: static;
    padding: 0;
    display: block;
    font-size: 16px;
    font-weight: 400
}

.shop_wrap .shop_area .shop_list {
    display: flex;
    margin-bottom: 25px
}

.shop_wrap .shop_area .shop_list .shop_links {
    width: 60%
}

.shop_wrap .shop_area .shop_list .shop_links dt,
.shop_wrap .shop_area .shop_list .shop_links dt a {
    font-size: 18px;
    font-weight: 700;
    color: #182e78;
    margin-bottom: 5px
}

.shop_wrap .shop_area .shop_list .shop_links dd li {
    display: inline-block;
    padding: 0 14px;
    border-left: 1px solid #282828;
    line-height: 1;
    margin-bottom: 20px;
    font-size: 14px
}

.footer_bottom ul li:first-of-type,
.shop_wrap .shop_area .shop_list .shop_links dd li:first-of-type {
    padding-left: 0;
    border-left: none
}

.shop_wrap .shop_area .shop_list .shop_links dd li a,
.shop_wrap .shop_area .shop_list .shop_links dd li span {
    font-size: 14px
}

.shop_wrap .shop_area .shop_list .shop_links dd li a {
    color: #182e78;
    text-decoration: underline
}

#foot_right li a:hover,
.footer_bottom ul li a:hover,
.shop_wrap .shop_area .shop_list .shop_links dd li a:hover {
    text-decoration: none
}

.shop_wrap .shop_area .shop_list .map_wrap {
    position: relative;
    width: 40%
}

.shop_wrap .shop_area .shop_list .map_wrap .bubble {
    position: absolute;
    left: -15%;
    top: -6%
}

.shop_wrap .shop_area .shop_list .map_wrap .map_img {
    margin-top: 50px;
    text-align: center
}

.shop_wrap .shop_img {
    display: flex;
    justify-content: flex-start;
    align-items: center
}

.shop_wrap .shop_img .shop_items {
    margin-right: 1%
}

.shop_wrap .shop_img .shop_items:nth-of-type(5n) {
    margin-right: 0
}

.shop_wrap .shop_img .shop_items p {
    text-align: center;
    font-weight: 700;
    color: #182e78;
    margin-top: 5px
}

.shop_wrap .shop_img .shop_items img {
    border-radius: 10px
}

.step_wrap {
    position: relative;
    background: #142e7a;
    background: linear-gradient(125deg, #142e7a 0, #163387 100%);
    z-index: 0
}

.step_wrap .img_speedy {
    position: absolute;
    top: -25%;
    right: 10%;
    z-index: -1
}

.step_wrap .step_tit {
    font-size: 3em;
    font-weight: 700;
    color: #fff;
    margin: 0 auto 1em;
    border-bottom: .2em solid #fee92d;
    display: inline-block
}

.flow .step_wrap .step_tit {
    background: #142e7a;
    width: 100%;
    padding: 20px 0;
    padding-left: 0;
    /* 280px を 0 に変更 */
    margin: 0;
    margin-bottom: 2.2%;
    text-align: center;
    font-size: 24px;
    height: 70px;
    box-sizing: border-box;
    display: flex;
    /* 追加 */
    align-items: center;
    /* 追加 */
    justify-content: center;
    /* 追加 */
}

.step_wrap .step_flow {
    position: relative;
    padding-bottom: 56px
}

.step_wrap .step_flow:after,
.step_wrap .step_flow:before {
    position: absolute;
    display: inline-block;
    content: "";
    width: 100%;
    min-width: 1200px;
    height: 56px;
    background: url(../img/top/step_all.webp) center no-repeat;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1;
    margin: auto
}

.step_wrap .step_flow:after {
    background: #2343a0;
    z-index: 0
}

.step_wrap .step_list {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    color: #fff;
    padding-top: 20px
}

.step_wrap .step_list .step_items {
    width: 220px;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.6
}

.step_wrap .step_list .step_items h3 {
    position: relative;
    font-size: 18px;
    font-weight: 700;
    color: #ffec0f;
    padding: 7px 10px 7px 50px;
    box-sizing: border-box;
    margin-bottom: 15px
}

.step_wrap .step_list .step_items h3:before {
    position: absolute;
    display: inline-block;
    content: "";
    width: 42px;
    height: 42px;
    background-repeat: no-repeat;
    left: 0;
    top: 0;
    bottom: 0;
    margin: auto
}

.step_wrap .step_list .step_items .step_01:before {
    background-image: url(../img/top/icon_step01.webp)
}

.step_wrap .step_list .step_items .step_02:before {
    background-image: url(../img/top/icon_step02.webp)
}

.step_wrap .step_list .step_items .step_03:before {
    background-image: url(../img/top/icon_step03.webp)
}

.step_wrap .step_list .step_items .step_04:before {
    background-image: url(../img/top/icon_step04.webp)
}

.step_wrap .step_list .step_items .step_05:before {
    background-image: url(../img/top/icon_step05.webp)
}

/* PC版 */
.step_wrap .step_detail {
    display: flex;
    flex-direction: row;
    gap: 30px;
    align-items: flex-start;
}

.step_wrap .step_detail_images {
    display: grid;
    grid-template-columns: repeat(2, 175px);
    /* 350pxの半分 */
    gap: 10px;
    flex-shrink: 0;
}

.step_wrap .step_detail_img {
    width: 350px;
    /* 元の画像サイズ */
    height: 233px;
    /* 350pxに対する比率で調整 */
}

.step_wrap .step_detail_img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.step_wrap .step_detail_img_half {
    width: 175px;
    /* 350pxの半分 */
    height: 233px;
    /* 元の画像と同じ高さ */
    margin-right: 0;
    display: flex;
    flex-direction: column;
}

.step_wrap .step_detail_img_half img {
    width: 100%;
    height: 233px;
    object-fit: cover;
}

.step_wrap .step_detail_img_half .caption {
    font-size: 12px;
    color: #333;
    margin-top: 5px;
    text-align: left;
    font-weight: 400;
}

.step_wrap .step_detail_img_half_2 {
    width: 175px;
    /* 350pxの半分 */
    height: auto;
    display: flex;
    flex-direction: column;
}

.step_wrap .step_detail_img_half_2 img {
    width: 100%;
    height: 233px;
    /* 元の画像と同じ高さ */
    object-fit: cover;
}

.step_wrap .step_detail_img_half_2 .caption {
    font-size: 12px;
    color: #333;
    margin-top: 5px;
    text-align: left;
    font-weight: 400;
}

.step_wrap .step_detail_txt {
    flex: 1;
}

/* スマホ版 */
@media screen and (max-width: 768px) {
    .step_wrap .step_detail {
        flex-direction: column;
        /* 画像とテキストは縦並び */
    }

    .step_wrap .step_detail_images {
        grid-template-columns: repeat(2, 1fr);
        /* 2列を維持 */
        width: 100%;
        gap: 8px;
    }

    .step_wrap .step_detail_img {
        width: 100%;
        height: auto;
    }

    .step_wrap .step_detail_img img {
        height: auto;
        object-fit: contain;
    }

    .step_wrap .step_detail_img_half {
        width: 100%;
        height: auto;
        margin-right: 0;
    }

    .step_wrap .step_detail_img_half img {
        width: 100%;
        height: auto;
        object-fit: contain;
    }

    .step_wrap .step_detail_img_half_2 {
        width: 100%;
        height: auto;
    }

    .step_wrap .step_detail_img_half_2 img {
        width: 100%;
        height: auto;
        object-fit: contain;
    }
}


.faq_wrap .faq_tit {
    font-size: 32px;
    font-weight: 700;
    text-align: center;
    margin-bottom: 20px
}

.faq_wrap .faq_tit .sub_tit {
    display: block;
    font-size: 16px;
    font-weight: 400
}

.faq_wrap .faq_list {
    padding: 0 100px
}

.faq_wrap .faq_list .faq_items {
    cursor: pointer
}

.faq_wrap .faq_list .faq_items dt {
    position: relative;
    border-bottom: 1px solid #c7c7c7;
    padding: 18px 25px 20px 78px
}

.faq_wrap .faq_list .faq_items dt:after,
.faq_wrap .faq_list .faq_items dt:before {
    position: absolute;
    display: inline-block;
    content: ""
}

.faq_wrap .faq_list .faq_items dt:before {
    width: 36px;
    height: 36px;
    background: url(../img/common/icon_q.webp) no-repeat;
    top: 0;
    bottom: 0;
    left: 25px;
    margin: auto
}

.faq_wrap .faq_list .faq_items dt:after {
    width: 8px;
    height: 8px;
    border-top: 2px solid #182e78;
    border-right: 2px solid #182e78;
    transform: rotate(135deg);
    right: 10px;
    top: 0;
    bottom: 0;
    margin: auto;
    transition: transform 0.4s
}

.faq_wrap .faq_list .faq_items dt.opened:after {
    transform: rotate(-45deg)
}

.faq_wrap .faq_list .faq_items dd {
    position: relative;
    background: #ebf4fe;
    padding: 10px 25px 10px 78px;
    font-size: 14px;
    line-height: 1.8
}

.faq_wrap .faq_list .faq_items dd:before {
    position: absolute;
    display: inline-block;
    content: "";
    width: 36px;
    height: 36px;
    background: url(../img/common/icon_a.webp) no-repeat;
    top: 15px;
    left: 25px
}

.faq_wrap .faq_list .txt_links {
    text-align: right;
    margin-top: 10px
}

.error .error_wrap {
    text-align: center;
    margin: 150px auto 250px
}

.error .error_wrap p {
    display: inline-block;
    text-align: left;
    max-width: 496px;
    width: 100%;
    margin-top: 100px
}

.error .error_wrap br+p {
    margin-top: 1rem
}

.youtube-wrap {
    width: 80%;
    margin: 0 auto
}

.youtube-wrap_home {
    width: 100%;
    margin: 0 auto
}

.youtube {
    position: relative;
    width: 100%;
    aspect-ratio: 16/9
}

.youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%
}

@media screen and (max-width:768px) {
    html {
        color: #000;
        font-size: 14px
    }

    .common_page .article_body .sitewrap,
    .pref_page .article_body .sitewrap,
    .pref_page .article_body .contact_wrap .sitewrap,
    .contact_wrap .sitewrap,
    .sitewrap {
        width: 100%;
        min-width: 0;
        padding: 0 1.5em;
    }

    .pref_page .shop_wrap .shop_area {
        padding: 50px 10px 120px
    }

    .contact_wrap .col3 .freecall_items,
    .faq_wrap .faq_list,
    header .sitewrap {
        padding: 0
    }

    main {
        margin-top: 0
    }

    .freedial_wrap,
    .freedial_wrap .tel-btn {
        display: flex;
        width: 100%;
        box-sizing: border-box;
		width: 100%;
    }

    .faq_wrap .faq_list .faq_items dt:after,
    .faq_wrap .faq_list .faq_items dt:before,
    .step_wrap .step_list .step_items h3:after,
    .step_wrap .step_list .step_items:before {
        content: "";
        display: inline-block;
        position: absolute
    }

    .freedial_wrap {
        text-align: center;
        margin: auto;
        background-color: #abd3ff;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        font-size: 1vw;
    }

    .freedial_wrap span {
        font-size: 5em;
        font-weight: 700;
        color: #182e78
    }

    .freedial_wrap .tel-btn img {
        height: 100%
    }

    .freedial_wrap .tel-btn {
        align-items: center;
        justify-content: center;
        gap: 2em;
        background-color: #fff;
        border-radius: 100vw;
        padding: 1.5em 3em;
        text-decoration: none;
        border: .7em solid #182e78;
        box-shadow: 0 1em 0 #182e78;
        height: 11em
    }

    .freedial_wrap .tel-btn .freedial {
        height: 100%;
        width: auto
    }

    .freedial_wrap .tel-btn .tel-num {
        height: 6em;
        width: auto
    }

    #NavWrap .freedial_wrap .tel-btn .tel-num {
        height: 5em
    }

    .freedial_wrap .tel-btn span {
        color: #d2002f;
        font-size: 7.5em;
        white-space: nowrap;
        font-optical-sizing: auto;
        font-weight: 900;
        font-style: normal;
        line-height: 1
    }

    .freedial_wrap .tel-btn::after {
        content: "";
        height: 3em;
        width: 3em;
        border-top: 1em solid #182e78;
        border-right: 1em solid #182e78;
        transform: rotate(45deg);
        box-sizing: border-box
    }

    .strengths_wrap {
        display: none;
        flex-wrap: wrap;
        border: 0 solid #182e78;
        font-size: 1.35vw;
        gap: .5em;
        row-gap: 1em;
        padding: 1.5em
    }

    .strengths_wrap .strengths_items {
        width: 24%;
        height: auto;
        font-size: 1.7em;
        padding: 1.3em .7em;
        background-color: #182e78;
        color: #fff;
        border-left: none;
        border-right: none;
        border-top: none;
        border-bottom: none
    }

    .strengths_wrap .strengths_items:last-child {
        border-right: none
    }

    .strengths_wrap .strengths_items:first-child {
        border-left: none
    }

    .strengths_wrap .strengths_items span {
        color: #fff;
        background: linear-gradient(transparent 90%, #ffff2b 0);
        padding-bottom: .3em
    }

    .crowns_wrap {
        margin: 20px 0
    }

    .crowns_wrap .crowns_tit span {
        font-size: 5vw;
        padding: 0 18px;
        width: 100%
    }

    .crowns_wrap .crowns_tit span b {
        display: inline-block;
        font-size: 6.45vw
    }

    .crowns_wrap .crowns_tit span ::after,
    .crowns_wrap .crowns_tit span::before {
        width: 20px;
        height: 28px;
        background-size: cover;
        top: auto;
        bottom: 0
    }

    .crowns_wrap .img_wrap {
        margin-top: 10px
    }

    .crowns_wrap .img_wrap img,
    .products_wrap .maker_wrap dd img,
    .products_wrap .products_items .detail_wrap .img_wrap img,
    .shop_wrap .shop_area .shop_list .map_wrap .bubble img,
    .shop_wrap .shop_area .shop_list .map_wrap .map_img img,
    .shop_wrap .shop_img .shop_items img,
    .step_wrap .img_speedy img,
    .youtube-wrap {
        width: 100%
    }

    .c-btn-mfr-list {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: 2px;
        justify-items: center;
        margin: 0% 67% 0% -3%;
        position: relative;
        top: 1vw;
        left: 6.5vw
    }

    .c-btn-mfr {
        display: flex;
        align-items: center;
        justify-content: space-between;
        background: #fff;
        box-sizing: border-box;
        border: 1px solid #ddd;
        width: 42vw;
        padding: 6% 2% 6% 2%
    }

    .c-ttl {
        font-size: 24px;
        font-weight: 700;
        letter-spacing: .05em;
        margin: 0% 0% 0% 0%;
        line-height: 1.4;
        position: relative;
        top: -4vw;
        right: 74vw
    }

    .c-btn-mfr a img,
    .c-btn-mfr span img {
        vertical-align: middle;
        width: 22vw;
        height: 6vw
    }

    .caution_wrap {
        margin: 0 1em 3em
    }

    .caution_wrap_2 {
        margin: 3em auto
    }

    .caution_wrap,
    .caution_wrap_2 {
        display: block;
        border-radius: 0;
        border-width: 1px
    }

    .products_wrap .maker_wrap dt,
    .shop_wrap .shop_area .shop_list .shop_links dt.opened {
        border-bottom: 1px solid #182e78
    }

    .caution_wrap dt,
    .caution_wrap_2 dt {
        width: 100%;
        font-size: 16px;
        padding: 5px 0
    }

    .caution_wrap dt,
    .caution_wrap_2 .caution_wrap dd,
    .caution_wrap_2 dd {
        width: 100%;
        padding: 8px 25px;
        line-height: 1.6
    }

    .news_wrap .news_area {
        padding: 20px 10px 10px
    }

    .news_wrap .news_area .news_tit {
        font-size: 5vw;
        margin-bottom: 10px
    }

    .items-wrap {
        display: flex;
        flex-direction: column;
        gap: 5em
    }

    .product-items {
        padding: 1em 0;
        font-size: 3.1vw
    }

    .product-items h3 {
        font-size: 10vw;
        text-align: center
    }

    .product-items .items {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: stretch;
        align-content: stretch;
        gap: 3em;
        font-size: 1.4em
    }

    .product-items .maker-wrap {
        gap: 2em;
        flex-direction: column
    }

    .product-items .comparison-title {
        flex-direction: column;
        margin-bottom: 3em
    }

    .product-items .comparison-title .product-img {
        width: 70%;
        order: 2;
        margin-top: -1.5em
    }

    .product-items .comparison-title .title-text {
        order: 1
    }

    .product-items .companys {
        align-items: stretch;
        gap: 1em
    }

    .product-items .companys .syouzikiya .syouzikiya-logo {
        height: 4em
    }

    .product-items .companys .syouzikiya .komi {
        background-color: #c11f1f
    }

    .product-items .companys .syouzikiya .price-wrapper .price {
        font-size: 3em
    }

    .product-items .companys .syouzikiya .price-wrapper .price,
    .product-items .companys .syouzikiya .price-wrapper .tax-yen {
        color: #c11c22
    }

    .product-items .companys .company {
        width: 47%
    }

    .product-items .companys .company:nth-child(2) {
        background-color: #d0d0e2
    }

    .product-items .companys .company:nth-child(3) {
        background-color: #e5c0c0
    }

    .product-items .companys .company .komi {
        background-color: #282828
    }

    .product-items .companys .company .price-wrapper .price {
        color: #282828;
        font-size: 2.3em
    }

    .product-items .companys .company .price-wrapper .tax-yen {
        color: #282828
    }

    .product-items .companys .syouzikiya {
        font-size: 1.2em
    }

    .products_tit,
    .products_wrap .introduction_wrap .intro_tit {
        font-size: 6vw
    }

    .product-items .companys .company,
    .product-items .companys .syouzikiya {
        gap: .5em;
        box-sizing: border-box;
        padding: 1em 2em
    }

    .product-items .companys .company .company-name,
    .product-items .companys .syouzikiya .company-name {
        font-size: 1.25em;
        white-space: nowrap;
        font-weight: 700
    }

    .product-items .companys .company .komi,
    .product-items .companys .syouzikiya .komi {
        padding: .3em 1em .2em;
        font-weight: 700;
        font-size: 1em;
        color: #fff;
        border-radius: 5em;
        line-height: 1.3
    }

    .product-items .companys .company .komi .sp-block,
    .product-items .companys .syouzikiya .komi .sp-block,
    .products_wrap .products_items .detail_wrap {
        display: block
    }

    .product-items .companys .company .price-wrapper,
    .product-items .companys .syouzikiya .price-wrapper {
        display: flex;
        flex-wrap: nowrap;
        justify-content: center;
        align-items: center
    }

    .product-items .companys .company .price-wrapper .price,
    .product-items .companys .syouzikiya .price-wrapper .price {
        font-weight: 700
    }

    .product-items .companys .company .price-wrapper .tax-yen,
    .product-items .companys .syouzikiya .price-wrapper .tax-yen {
        display: flex;
        flex-direction: column;
        flex-wrap: nowrap;
        justify-content: center;
        align-items: center;
        margin-left: .2em
    }

    .product-items .companys .company .price-wrapper .tax-yen .tax,
    .product-items .companys .syouzikiya .price-wrapper .tax-yen .tax {
        font-size: .8em;
        margin-bottom: 0;
        font-weight: 700;
        white-space: nowrap
    }

    .product-items .companys .company .price-wrapper .tax-yen .yen,
    .product-items .companys .syouzikiya .price-wrapper .tax-yen .yen {
        font-size: 1.5em;
        font-weight: 900
    }

    .product-items .companys .company .plus,
    .product-items .companys .syouzikiya .plus {
        font-size: 1.5em
    }

    .product-items .all-komikomi .product-cost {
        width: 90%;
        border: .08em solid #182e78
    }

    .product-items .all-komikomi .costs {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-wrap: wrap;
        gap: 1em;
        width: 100%
    }

    .product-items .all-komikomi .costs .cost-item {
        border-radius: 1em;
        width: 25%;
        flex-direction: column
    }

    .product-items .all-komikomi .costs .cost-item img {
        width: 15vw
    }

    .product-items .all-komikomi .costs .cost-item span {
        font-size: 4.5vw
    }

    .products_wrap .introduction_wrap {
        position: relative;
        background-color: #182e78;
        text-align: center;
        color: #fff;
        padding: 2em 1em 3em
    }

    .products_wrap .introduction_wrap .sub_tit {
        font-size: max(1.1em, 16px);
        margin-bottom: 10px;
        text-align: left
    }

    .products_tit {
        margin-bottom: 10px;
        margin-top: 60px
    }

    .products_tit::after,
    .products_tit::before {
        width: 6vw;
        height: 7vw
    }

    .products_tit span,
    .oter_products_link .tit span {
        font-size: 20px
    }

    .products_wrap .introduction_wrap p,
    .shop_wrap .shop_area .shop_tit span .sub_tit {
        font-size: 14px
    }

    .products_wrap .introduction_wrap .which_area p {
        width: 40%;
        height: auto;
        padding: 8px 10px;
        border-radius: 24px;
        margin: 0 5px;
        font-size: 16px
    }

    .products_wrap .oter_products {
        flex-wrap: wrap;
        gap: 1em
    }

    .products_wrap .oter_products .oter_products_link {
        width: 100%;
        border-radius: .5em;
        border: .1em solid #182e78;
        background-position: right;
        background-color: #fff
    }

    .products_wrap .oter_products .oter_products_link:hover {
        text-decoration: none;
        opacity: .8
    }

    .products_wrap .oter_products .oter_products_link .tit {
        font-size: 18px;
        margin-bottom: 5px;
        text-shadow: 0 0 2px #fff, 0 0 2px #fff, 0 0 2px #fff
    }

    .products_wrap .maker_wrap dl {
        flex-direction: column;
        align-items: center
    }

    .products_wrap .maker_wrap dl .character {
        position: absolute;
        bottom: -3em;
        right: 50%;
        transform: translateX(50%);
        width: 100vw;
        margin: auto
    }

    .products_wrap .maker_wrap dl .speech-bubble {
        width: max(11em, 40vw);
        height: max(11em, 40vw);
        right: 0;
        left: 5vw;
        bottom: max(-15em, -8vw);
        transform: scale(-1, 1) rotate(45deg)
    }

    .products_wrap .maker_wrap dl .speech-bubble p {
        transform: scale(-1, 1) translate(50%, -50%) rotate(45deg);
        font-size: 16px
    }

    .products_wrap .maker_wrap dl .professor {
        right: 5vw;
        transform: translateX(-50%);
        bottom: -12vw;
        width: 34vw
    }

    .products_wrap .maker_wrap dl .character-description {
        bottom: -10vw;
        right: 5vw
    }

    .products_wrap .maker_wrap dt {
        width: 85%;
        border-right: none;
        font-size: 8vw;
        padding-top: 0
    }

    .products_wrap .maker_wrap dd {
        margin: 2em auto;
        gap: 1.5em;
        flex-wrap: wrap;
        justify-content: center
    }

    .products_wrap .maker_wrap dd span {
        width: 45%
    }

    .about-btn-wrap .btn_links,
    .about-btn-wrap .btn_links_red {
        font-size: 3.8vw
    }

    .contact_wrap,
    .shop_wrap,
    .step_wrap {
        padding: 5em 0;
    }

    .contact_wrap .contact_tit {
        margin-bottom: 10px;
        white-space: nowrap
    }

    .contact_wrap .contact_tit span {
        font-size: 7vw;
        padding: 0 25px
    }

    .contact_wrap .contact_tit span:after,
    .contact_wrap .contact_tit span:before {
        background-size: cover;
        width: 21px;
        height: 32px
    }

    .contact_wrap .sub_tit {
        color: #fff;
        margin-bottom: 15px;
        font-size: 4vw
    }

    .contact_wrap .col4 {
        flex-wrap: wrap
    }

    .contact_wrap .col4 p {
        font-size: 16px;
        padding: 8px 20px 8px 45px;
        margin: 0 2% 4%
    }

    .contact_wrap .col4 p:before {
        left: 15px;
        background-size: cover
    }

    .contact_wrap .col4 p.support_item:before {
        width: 22px;
        height: 22px
    }

    .contact_wrap .col4 p.estimate_item:before {
        width: 17px;
        height: 22px
    }

    .contact_wrap .col4 p.price_item:before {
        width: 23px;
        height: 23px
    }

    .contact_wrap .col4 p.safety_item:before {
        width: 24px;
        height: 16px
    }

    .contact_wrap .col3 {
        flex-wrap: wrap;
        margin: 0 auto;
        align-items: center;
        flex-direction: column;
        background: #fff;
        border-radius: 5px;
        padding: 15px 20px 10px;
        box-sizing: border-box
    }

    .contact_wrap .col3 dl {
        display: block;
        padding: 0;
        width: 100%
    }

    .contact_wrap .col3 dt,
    .step_wrap .step_flow:after,
    .step_wrap .step_flow:before,
    .step_wrap .step_list .step_items:last-of-type:before {
        display: none
    }

    .contact_wrap .col3 dd {
        display: block;
        width: 100%
    }

    .contact_wrap .col3 .freecall_items dd .freecall_wrap {
        text-align: left;
        font-size: 8vw;
        white-space: nowrap;
        padding-left: 18%;
        padding-bottom: 5px;
        padding-top: 5px;
        margin-bottom: 4px
    }

    .contact_wrap .col3 .freecall_items dd .freecall_wrap:before {
        width: 11vw;
        height: 9vw;
        background-size: cover;
        left: 5px
    }

    .contact_wrap .col3 .line_items dd .btn_links,
    .contact_wrap .col3 .mail_items dd .btn_links,
    .contact_wrap .col3 .line_items dd .btn_links_red,
    .contact_wrap .col3 .mail_items dd .btn_links_red {
        margin: 15px 0
    }

    .shop_wrap .shop_area {
        padding: 50px 10px 20px
    }

    .shop_wrap .shop_area .shop_tit {
        top: -20px
    }

    .shop_wrap .shop_area .shop_tit span {
        font-size: 4.5vw;
        padding: 0 20px
    }

    .shop_wrap .shop_area .shop_tit span:after,
    .shop_wrap .shop_area .shop_tit span:before {
        width: 20px;
        height: 28px;
        background-size: cover;
        top: 10%;
        bottom: 0
    }

    .shop_wrap .shop_area .shop_tit span b {
        font-size: 9vw
    }

    .shop_wrap .shop_area .shop_list {
        display: flex;
        flex-direction: column;
        margin-bottom: 25px
    }

    .shop_wrap .shop_area .shop_list .shop_links {
        width: 100%;
        order: 2
    }

    .shop_wrap .shop_area .shop_list .shop_links dl {
        border: 1px solid #182e78;
        border-radius: 5px;
        margin-bottom: 10px;
        overflow: hidden
    }

    .shop_wrap .shop_area .shop_list .shop_links dt {
        position: relative;
        padding: 5px 20px 5px 10px
    }

    .shop_wrap .shop_area .shop_list .shop_links dt {
        font-size: 14px;
        margin-bottom: 0;
        background: #f2f3f3
    }

    .shop_wrap .shop_area .shop_list .shop_links dt a {
        font-size: 14px
    }

    .shop_wrap .shop_area .shop_list .shop_links dt:before {
        position: absolute;
        display: inline-block;
        content: "";
        width: 6px;
        height: 6px;
        border-top: 2px solid #182e78;
        border-right: 2px solid #182e78;
        transform: rotate(50deg);
        right: 6px;
        top: 0;
        bottom: 0;
        margin: auto;
        transition: transform 0.4s
    }

    .shop_wrap .shop_area .shop_list .shop_links dd {
        padding: 5px 10px;
        box-sizing: border-box
    }

    .shop_wrap .shop_area .shop_list .shop_links dd li {
        display: inline-block;
        padding: 0 10px;
        line-height: 1;
        margin-bottom: 10px
    }

    .shop_wrap .shop_area .shop_list .shop_links dd li:first-of-type {
        padding-left: 0;
        border-left: none
    }

    .shop_wrap .shop_area .shop_list .shop_links dd li a,
    .shop_wrap .shop_area .shop_list .shop_links dd li span {
        font-size: 12px
    }

    .shop_wrap .shop_area .shop_list .shop_links dd li a {
        color: #182e78;
        text-decoration: underline
    }

    .shop_wrap .shop_area .shop_list .shop_links dd li a:hover {
        text-decoration: none
    }

    .shop_wrap .shop_area .shop_list .shop_links dt .display_sp {
        font-size: 2.15vw;
        margin: 1% 0% 0% 0%;
        color: #000
    }

    .shop_wrap .shop_area .shop_list .map_wrap {
        width: 100%;
        order: 1;
        margin-bottom: 10px
    }

    .shop_wrap .shop_area .shop_list .map_wrap .bubble {
        left: 0;
        top: 0;
        width: 50%
    }

    .shop_wrap .shop_area .shop_list .map_wrap .map_img {
        margin-top: 50px;
        margin-right: auto;
        margin-left: auto;
        width: 80%
    }

    .shop_wrap .shop_img {
        justify-content: space-between;
        flex-wrap: wrap;
        margin: 0 6%
    }

    .shop_wrap .shop_img .shop_items {
        width: 44%;
        margin-right: 0
    }

    .step_wrap .img_speedy {
        position: absolute;
        top: -125px;
        right: 0;
        width: 58%
    }

    .step_wrap .step_tit {
        text-align: center;
        font-size: 12vw;
        margin-bottom: 15px
    }

    .step_wrap .step_flow {
        position: relative;
        padding-bottom: 0
    }

    .step_wrap .step_list {
        display: block;
        padding-top: 20px
    }

    .step_wrap .step_list .step_items {
        position: relative;
        width: 100%;
        font-weight: 400;
        padding-bottom: 50px
    }

    .step_wrap .step_list .step_items:before {
        width: 0;
        height: 0;
        border-style: solid;
        border-width: 32px 44px 0;
        border-color: #2342a0 transparent transparent;
        bottom: 10px;
        left: 0;
        right: 0;
        margin: auto
    }

    .step_wrap .step_list .step_items h3 {
        padding: 2px 10px 2px 160px;
        box-sizing: border-box;
        line-height: 1;
        margin-bottom: 9px
    }

    .step_wrap .step_list .step_items h3:before {
        width: 21px;
        height: 21px;
        background-size: cover;
        left: 120px
    }

    .step_wrap .step_list .step_items h3:after {
        width: 110%;
        height: 25px;
        background-size: cover;
        left: -5%;
        top: -10%;
        right: 0;
        z-index: -1
    }

    .faq_wrap .faq_list .faq_items dd:before,
    .faq_wrap .faq_list .faq_items dt:before {
        top: 5px;
        left: 5px;
        width: 28px;
        height: 28px;
        background-size: cover
    }

    .step_wrap .step_list .step_items .step_01:after {
        background-image: url(../img/top/step01.webp)
    }

    .step_wrap .step_list .step_items .step_02:after {
        background-image: url(../img/top/step02.webp)
    }

    .step_wrap .step_list .step_items .step_03:after {
        background-image: url(../img/top/step03.webp)
    }

    .step_wrap .step_list .step_items .step_04:after {
        background-image: url(../img/top/step04.webp)
    }

    .step_wrap .step_list .step_items .step_05:after {
        background-image: url(../img/top/step05.webp)
    }

    .faq_wrap {
        padding: 30px 0
    }

    .faq_wrap .faq_tit {
        font-size: 6vw;
        margin-bottom: 10px
    }

    .faq_wrap .faq_tit .sub_tit {
        text-align: left;
        font-size: 14px;
        width: 80%;
        margin: auto
    }

    .faq_wrap .faq_list .faq_items {
        cursor: pointer
    }

    .faq_wrap .faq_list .faq_items dd,
    .faq_wrap .faq_list .faq_items dt {
        padding: 10px 25px 10px 50px
    }

    .faq_wrap .faq_list .faq_items dt:before {
        bottom: auto
    }

    .error .error_wrap {
        margin: 50px auto 100px;
        padding: 0 15px
    }
}

@media screen and (max-width:768px) and (max-width:360px) {
    .step_wrap .img_speedy {
        top: -90px
    }
}

#pageTop {
    position: fixed;
    bottom: 100px;
    right: 5%;
    width: 70px;
    z-index: 500
}

footer {
    padding: 30px 0 15px
}

.footer_top {
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    margin-bottom: 20px
}

#foot_left>a {
    display: inline-block
}

#foot_left>a img {
    width: 208px;
    vertical-align: middle
}

#foot_left p {
    margin-top: 4px;
    font-size: 14px;
    color: #282828
}

#foot_left p:first-of-type {
    margin-top: 10px
}

#foot_right {
    font-size: 14px;
    display: flex;
    justify-content: flex-start;
    align-items: flex-start;
    margin-left: 2%;
    width: 59%;
    max-width: 700px
}

#foot_right ul {
    border-left: 1px solid #bdbdbd;
    padding-top: 10px
}

#foot_right ul+ul {
    margin-left: 12%
}

#foot_right li {
    display: block;
    padding: 2px 10px 2px 30px;
    text-align: left
}

#foot_right li a,
.footer_bottom ul li a {
    position: relative;
    display: inline-block;
    overflow: hidden
}

#foot_right li a:before,
.footer_bottom ul li a:before {
    position: absolute;
    display: inline-block;
    content: "";
    width: 100%;
    height: 1px;
    background: #182e78;
    bottom: 0;
    left: -100%;
    transition: left 0.2s
}

#foot_right li a:hover:before,
.footer_bottom ul li a:hover:before {
    left: 0
}

.footer_bottom {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-top: 1px solid #bdbdbd;
    font-size: 12px;
    padding-top: 10px
}

.footer_bottom ul li {
    display: inline-block;
    padding: 0 8px;
    border-left: 1px solid #bdbdbd
}

main a.page_link {
    margin-top: -60px;
    padding-top: 60px;
    display: block;
    position: relative;
    z-index: -1
}

.waterheater_contents .list_2col,
.waterheater_contents .list_4col {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap
}

@media screen and (max-width:768px) {
    #pageTop {
        width: 49px;
        right: 10px;
        bottom: 120px
    }

    footer {
        padding: 3em 0 10px
    }

    .footer_top {
        margin-bottom: 3em
    }

    #foot_left {
        text-align: center;
        width: 100%
    }

    #foot_left>a {
        display: inline-block
    }

    #foot_left p {
        margin-top: 1em;
        font-size: 10px;
        color: #282828
    }

    #foot_left p:first-of-type {
        margin-top: 10px
    }

    #foot_right,
    .footer_bottom ul {
        display: none
    }

    .footer_bottom {
        justify-content: center
    }

    .page_link {
        margin-top: -60px;
        padding-top: 60px !important;
        display: block
    }

    .waterheater_contents {
        margin: 40px 0 20px
    }
}

.attention_wrap {
    padding: 3em 1em;
    background: #ebf4fe;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 5em;
}

.attention_wrap .col2 {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1em;
}

.attention_wrap .col2 img {
    margin: 0 auto;
    width: auto;
    height: 5em;
    display: block
}

.attention_wrap .text {
    margin-top: 40px;
    font-size: 1.1em;
    line-height: 1.8
}

.group-company .group-company_logos {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5em;
}

.group-company .group-company_logos img {
    height: 5em;
}

.group-company {
    background-color: white;
    border-radius: 0.3em;
    padding: 3em;
    margin: 0 auto;
}

.group-company .text {
    max-width: 40em;
    margin: 1em auto 0;
    text-align: left;
}

.group-company .brand-x {
    font-size: 4em;
}

#home_movie {
    background-color: #ffffff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3em;
    gap: 1em;
    border-radius: 0.3em;
}

.home_movie_wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 2em;
    width: 100%;
}

#home_movie .honestly_img img {
    max-width: 40em;
    width: 100%;
}

#home_movie h3 {
    font-size: 2em;
    margin: 0.5em auto 0;
    letter-spacing: 0.5em;
    font-weight: 900;
    color: #182e78;
    border-bottom: dashed 0.15em #182e78;
    line-height: 1.25;
}

.home_movie_item {
    width: 100%;
    margin-bottom: 20px;
}

.home_movie_item iframe {
    width: 100%;
    aspect-ratio: 16 / 9;
    height: auto;
}

.banner-honestly {
    width: 100%;
    max-width: 700px;
    transition: 0.2s all;
}

.banner-honestly:hover {
    opacity: 0.8;
}

.banner-honestly img {
    width: 100%;
}

@media screen and (max-width:768px) {
    .attention_wrap .sitewrap {
        padding: 0;
    }

    .attention_wrap .col2 {
        gap: 1em;
    }

    .attention_wrap .col2 img {
        width: auto;
        height: 12vw
    }

    .attention_wrap .text {
        margin-top: 10px
    }

    .attention_wrap .group-company {
        padding: 2em 1em;
    }

    #home_movie {
        padding: 2em 1em;
    }

    .group-company .group-company_logos img {
        height: 13vw;
    }

    .group-company .brand-x {
        font-size: 13vw;
    }
}

/* ===== 小さい画面サイズ用のmenu_bottom調整 ===== */
@media screen and (max-width:430px) {
    header .menu_bottom .drop_menu #NavWrap>ul>li>a {
        font-size: 12px !important;
    }

    header .menu_bottom .drop_menu #NavWrap>ul>li>a>span {
        font-size: 12px !important;
    }
}

@media screen and (max-width:360px) {
    header .menu_bottom .drop_menu #NavWrap>ul>li>a {
        font-size: 11px !important;
    }

    header .menu_bottom .drop_menu #NavWrap>ul>li>a>span {
        font-size: 11px !important;
    }
}

/* PC画面では非表示 */
.sp-menu-bar {
    display: none;
}

/* スマホ画面（768px以下）のみ表示 */
@media screen and (max-width: 768px) {
    .sp-menu-bar {
        display: block;
        position: fixed;
        top: 60px;
        /* menu_topの高さ分 */
        left: 0;
        right: 0;
        width: 100%;
        z-index: 140;

        /* 背景色の設定（以下のいずれかを選択） */
        background: #192e77;
        /* オプション1: 薄い青（デフォルト） */
        /* background: #f5f5f5; */
        /* オプション2: 薄いグレー */
        /* background: #ffffff; */
        /* オプション3: 白 */
        /* background: #e8f4f8; */
        /* オプション4: 薄い水色 */

        overflow-x: auto;
        overflow-y: hidden;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
        -ms-overflow-style: none;
        box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
        /* 下線は削除 */
    }

    /* スクロールバーを非表示（Webkit） */
    .sp-menu-bar::-webkit-scrollbar {
        display: none;
        width: 0;
        height: 0;
    }

    /* ナビゲーション */
    .sp-menu-nav {
        width: 100%;
        min-width: max-content;
    }

    /* メニューリスト */
    .sp-menu-list {
        display: flex;
        flex-wrap: nowrap;
        list-style: none;
        margin: 0;
        padding: 0;
        width: auto;
        min-width: max-content;
    }

    /* メニュー項目 */
    .sp-menu-item {
        flex-shrink: 0;
        flex-grow: 0;
        min-width: fit-content;
        padding: 0;
        margin: 0;
        position: relative;
        /* 縦線を短くするために追加 */
    }

    /* メニューリンク */
    .sp-menu-item a {
        display: block;
        padding: 14px 20px;

        /* 文字色: 紺色 */
        color: #182e78;

        text-decoration: none;
        white-space: nowrap;
        font-size: 14px;
        font-weight: 700;
        transition: background-color 0.3s, color 0.3s;
        box-sizing: border-box;
        position: relative;
    }

    /* 縦の区切り線（短め・紺色） */
    .sp-menu-item a::after {
        content: "";
        position: absolute;
        right: 0;
        top: 50%;
        transform: translateY(-50%);
        width: 1px;
        height: 60%;
        /* 短めに設定（60%の高さ） */
        background-color: #ffffff;
        /* 紺色 */
        /* opacity: 0.3; 少し薄く */
    }

    /* 最後の項目は縦線なし */
    .sp-menu-item:last-child a::after {
        display: none;
    }

    /* メニューリンクのspan */
    .sp-menu-item a span {
        display: block;
        line-height: 1.3;
        color: #ffffff;
        /* 紺色 */
    }

    /* ホバー・アクティブ効果 */
    .sp-menu-item a:hover,
    .sp-menu-item a:active {
        /* ホバー時の背景色（紺色） */
        background-color: #182e78;

        /* ホバー時の文字色（白） */
        color: #fff;
    }

    .sp-menu-item a:hover span,
    .sp-menu-item a:active span {
        color: #fff;
        /* ホバー時は白 */
    }

    /* ホバー時は縦線も白に */
    .sp-menu-item a:hover::after,
    .sp-menu-item a:active::after {
        background-color: #fff;
        opacity: 0.3;
    }

    /* bodyのpadding調整 */
    body {
        padding-top: 106px;
        /* 60px(menu_top) + 50px(sp-menu-bar) */
    }

    /* mainのmargin調整 */
    main {
        margin-top: 0;
    }
}

/* より小さい画面（430px以下）用の調整 */
@media screen and (max-width: 430px) {
    .sp-menu-bar {
        top: 60px;
    }

    .sp-menu-item a {
        padding: 12px 16px;
        font-size: 13px;
    }

    body {
        padding-top: 100px;
    }
}

/* さらに小さい画面（360px以下）用の調整 */
@media screen and (max-width: 360px) {
    .sp-menu-item a {
        padding: 10px 14px;
        font-size: 12px;
    }

    body {
        padding-top: 95px;
    }
}

.four-columns {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    flex-wrap: nowrap;
    gap: 20px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px 15px;
	box-sizing: border-box;
}

.four-columns .column {
    flex: 0 1 auto;
    padding: 10px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.four-columns img {
    width: 60px;
    height: 60px;
    object-fit: contain;
    display: block;
    margin: 0 auto 8px;
}

.four-columns p {
    font-size: 11px;
    color: #182e78;
    font-weight: bold;
    margin: 0;
    white-space: nowrap;
}

/* スマホ対応（768px以下） */
@media screen and (max-width: 768px) {
    .four-columns {
        gap: 15px;
        padding: 15px 10px;
    }

    .four-columns .column {
        padding: 8px;
    }

    .four-columns img {
        width: 60px;
        height: 60px;
    }

    .four-columns p {
        font-size: 10px;
    }
}

/* より小さい画面（430px以下） */
@media screen and (max-width: 430px) {
    .four-columns {
        gap: 17px;
        padding: 12px 8px;
    }

    .four-columns .column {
        padding: 5px;
    }

    .four-columns img {
        width: 60px;
        height: 60px;
        margin-bottom: 6px;
    }

    .four-columns p {
        font-size: 12px;
    }
}

/* より小さい画面（400px以下） */
@media screen and (max-width: 400px) {
    .four-columns {
        gap: 15px;
        padding: 12px 8px;
    }

    .four-columns .column {
        padding: 5px;
    }

    .four-columns img {
        width: 55px;
        height: 55px;
        margin-bottom: 6px;
    }

    .four-columns p {
        font-size: 11px;
    }
}

/* さらに小さい画面（375px以下 - iPhone SE等） */
@media screen and (max-width: 375px) {
    .four-columns {
        gap: 25px;
        padding: 10px 5px;
    }

    .four-columns .column {
        padding: 3px;
    }

    .four-columns img {
        width: 50px;
        height: 50px;
        margin-bottom: 5px;
    }

    .four-columns p {
        font-size: 9px;
        line-height: 1.2;
    }
}

/* 最小サイズ（360px以下） */
@media screen and (max-width: 360px) {
    .four-columns {
        gap: 6px;
        padding: 8px 3px;
    }

    .four-columns .column {
        padding: 2px;
    }

    .four-columns img {
        width: 35px;
        height: 35px;
        margin-bottom: 4px;
    }

    .four-columns p {
        font-size: 7px;
    }
}

.fixed-footer-contact {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    opacity: 0;
    transform: translateY(100%);
}

.fixed-footer-contact.show {
    animation: slideFadeIn 0.75s ease-out forwards;
}

@keyframes slideFadeIn {
    0% {
        opacity: 0;
        transform: translateY(100%);
    }

    50% {
        opacity: 0.5;
        transform: translateY(20%);
    }

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