@charset "UTF-8";
/* /common/css/mizumawari-reform.css */
/* デフォルトで両方非表示にする場合（例） */
.mizumawari_pc, .mizumawari_sp {
    display: none;
}
/* PC表示用 */
@media (min-width: 821px) {
    .mizumawari_pc {
        display: block;
    }
}
/* スマホ＋タブレット（iPad Air含む）用 */
@media (max-width: 820px) {
    .mizumawari_sp {
        display: block;
    }
}
#mizumawari-reform {
    font-family: "Yu Gothic", "游ゴシック", sans-serif;
    color: #4d4d4d;
    font-size: 18px;
    line-height: 1.6;
    padding: 20px 0px;
}
#mizumawari-reform .btn {
    all: unset;
    display: inline-block;
    background: #0066cc;
    color: #fff;
    padding: 12px 24px;
    border-radius: 6px;
    text-decoration: none;
    font-weight: bold;
    cursor: pointer;
}
/* メインタイトルビジュアル */
.mainImgBox {
    position: relative;
    width: 100%;
    padding-top: 37.9%;
}
.mainImgBox .mainImg {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background-image: url("../images/mizumawari/top_pc.webp");
    background-size: cover;
    background-position: center;
}
.mainImgBox .mainTitle {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 30%;
    text-align: center;
}
.mainImgBox .mainTitle img {
    width: 100%;
    height: auto;
    display: block;
}
/* キービジュアル */
.kv {
    text-align: center;
    max-width: 1000px;
    margin: 50px auto 20px auto;
}
.kvFadeGroup.fadeUp {
    animation-delay: 0.3s;
}
.kv .kvImg img {
    width: 700px;
    height: auto;
    display: block;
    margin: 0 auto 20px;
}
.kv .kvText {
    font-size: 30px;
    font-weight: bold;
}
.kv .kv_comment {
    width: 1000px;
    height: 200px;
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    background-image: url("../images/mizumawari/kv_commentbg_pc.webp");
    background-size: cover;
    color: #ffffff;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    padding: 20px;
    box-sizing: border-box;
    margin: 70px auto;
}
.kv .kv_comment br {
    display: block;
    content: "";
    margin-top: 10px;
}
/* 特徴 */
.featureContainer {
    display: flex;
    justify-content: space-between;
    max-width: 1000px;
    margin: 100px auto;
    gap: 100px;
    padding: 60px 20px;
}
.featureText {
    width: 520px;
}
.featureCopy {
    background-image: url("../images/mizumawari/feature_copybg_pc.svg");
    background-size: cover;
    width: 480px;
    height: 360px;
    text-align: center;
    font-weight: bold;
    font-size: 20px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.featureCopy h2 {
    font-size: 33px;
    font-weight: bold;
    margin-bottom: 26px;
}
.featureTokui {
    text-align: center;
    margin-top: 40px;
    width: 520px;
    height: 500px;
    background-image: url("../images/mizumawari/feature_tokui_bg.svg");
    background-size: cover;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.featurePointList {
    list-style: none;
    padding: 0;
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 16px;
    align-items: center;
}
.featurePointItem {
    width: 465px;
    height: 50px;
    line-height: 50px;
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 0 10px;
    box-sizing: border-box;
}
.tokuiTitle {
    width: 250px;
    margin: 36px auto;
}
.tokuiLeaf {
    width: 160px;
    margin-bottom: 36px;
}
.item1 {
    background-image: url("../images/mizumawari/feature_tokui_box1.svg");
}
.item2 {
    background-image: url("../images/mizumawari/feature_tokui_box2.svg");
}
.item3 {
    background-image: url("../images/mizumawari/feature_tokui_box3.svg");
}
.item4 {
    background-image: url("../images/mizumawari/feature_tokui_box4.svg");
}
.featureImages {
    width: 380px;
}
.featureImageGroup {
    display: flex;
    flex-direction: column;
    gap: 70px;
    align-items: center;
}
.imageBox {
    position: relative;
    width: 380px;
    border-radius: 14px;
    overflow: visible;
}
.imageBox img:first-child {
    width: 100%;
    display: block;
    border-radius: 14px;
}
.fukidashi {
    position: absolute;
}
.fukidashi1 {
    width: 236px;
    top: -30px;
    left: -20px;
}
.fukidashi2 {
    width: 192px;
    top: -80px;
    right: -30px;
}
.fukidashi3 {
    width: 200px;
    top: -60px;
    left: 30px;
}
/* 選ばれる理由 */
.whyChooseUsWrapper {
    background-color: #F7F4EF;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 60px 0;
}
.whyChooseUs {
    max-width: 1000px;
    height: 854px;
    background-image: url("../images/mizumawari/WCU_bg.png");
    background-size: cover;
    margin: 50px auto;
    padding: 50px 20px;
    background-color: #fff;
    text-align: center;
}
.whyChooseUs h2 {
    font-size: 30px;
    font-weight: bold;
}
.whyChooseUs h3 {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 7px;
}
.whyChooseUs p {
    font-size: 18px;
    font-weight: normal;
}
.whyChooseUs__title {
    font-size: 24px;
    text-align: center;
    margin-bottom: 40px;
}
.whyChooseUs__list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%;
    max-width: 1000px;
    background-size: cover;
    background-position: center;
    padding: 20px;
    box-sizing: border-box;
    gap: 14px;
}
.whyChooseUs__item {
    background-size: cover;
    position: relative;
    display: flex;
    height: 188px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: calc(50% - 10px);
    padding: 16px;
    box-sizing: border-box;
    z-index: 1;
}
.whyChooseUs__item::before {
    content: "";
    position: absolute;
    top: 0px;
    left: 0px;
    width: 100%;
    height: 100%;
    background-image: url("../images/mizumawari/WCU_libg.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    z-index: -1;
    transform: translateY(11px)
}
.whyChooseUs__item::after {
    content: "";
    position: absolute;
    top: 30px;
    right: 6px;
    width: 100%;
    height: 100%;
    background-image: url("../images/mizumawari/WCU_libg_on.webp");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    z-index: -1;
    pointer-events: none;
}
.whyChooseUs__list::before {
    content: "";
    position: absolute;
    top: -20px;
    left: -20px;
    width: calc(100% + 40px);
    height: calc(100% + 40px);
    background-image: url("dot-bg.png");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    z-index: 0;
    pointer-events: none;
}
.whyChooseUs__buttonArea {
    width: 960px;
    margin-top: 40px;
    text-align: right;
}
.whyChooseUs__button {
    display: flex;
    width: 434px;
    height: 59px;
    background-image: url("../images/mizumawari/WCU_btn.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    font-size: 24px;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    justify-content: center;
    align-items: center;
    margin-left: auto;
    margin-right: 22px;
    box-sizing: border-box;
    cursor: pointer;
    appearance: none;
    -webkit-tap-highlight-color: transparent;
}
/* 施工事例 */
.casesWrapper {
    background-color: #DFD1C6;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 60px 0;
}
.cases {
    box-sizing: border-box;
    max-width: 1000px;
    height: auto;
    margin: 50px auto;
    padding: 50px;
    background-color: #fff;
    text-align: left;
}
.case-headings {
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
    align-items: flex-end;
    gap: 16px;
    margin-bottom: 26px;
}
.case-lead {
    font-size: 20px;
}
.case-label {
    font-size: 30px;
    font-weight: bold;
}
.case01_main, .case02_main, .case03_main, .case04_main {
    width: 900px;
    height: auto;
}
.caseimg-footer {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
    height: 140px;
    margin-bottom: 70px;
}
.margin50 {
    margin-bottom: 50px;
}
.thumbs, .data, .before-img {
    flex: 1;
    margin-top: -63px;
}
.thumbs {
    margin-top: 20px;
    display: flex;
    flex-direction: row;
}
.thumbs img {
    width: 100px;
    height: 100px;
    margin-right: 10px;
}
.data {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 12px;
    height: 100px;
    margin-top: 30px;
    width: 200px;
    margin-left: -20px;
}
.before-img {
    position: relative;
    z-index: 1;
    right: auto;
    top: auto;
    align-self: flex-end;
    max-width: 270px;
    margin-top: -82px;
    margin-right: 10px;
}
.before-img img {
    width: 100%;
    height: auto;
    display: block;
}
.float-button {
    display: inline-block;
    position: relative;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.float-button img:hover {
    opacity: 1 !important;
}
.float-button:hover {
    opacity: 1 !important;
    transform: translate(4px, -4px);
}
.madoriandsubimg {
    margin-bottom: 60px;
    display: flex;
    gap: 20px;
}
.madori, .subimg {
    flex: 1;
}
.madori {
    max-width: 420px;
}
.madori img {
    max-width: 395px;
    height: auto;
}
.subimg {
    width: 450px;
}
.subimg img {
    width: 450px;
}
.section-divider {
    border: none;
    border-top: 10px solid #DFD1C6;
    margin: 100px auto 50px;
    width: 100%;
}
/* LINE */
.LINE_pc img {
    display: block;
    width: 1000px;
    margin: 100px auto;
}
/* リフォームの流れ */
.flowWrapper {
    background-color: #F7F4EF;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 60px 0;
}
.flow {
    max-width: 1000px;
    height: 808px;
    background-image: url("../images/mizumawari/flow_bg.svg");
    background-size: cover;
    margin: 50px auto;
    padding: 50px 20px;
    background-color: #fff;
    text-align: center;
}
.flow h2 {
    font-size: 30px;
    font-weight: bold;
    margin-bottom: 50px;
}
.flowList .arrow {
    width: 320px;
    height: 32px;
    margin: 20px auto;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}
.arrow[data-type="1"] {
    background-image: url('../../../common/images/mizumawari/flow_li_arrow1.png');
}
.arrow[data-type="2"] {
    background-image: url('../../../common/images/mizumawari/flow_li_arrow2.png');
}
.flowList .step {
    width: 918px;
    height: 80px;
    font-size: 20px;
    font-weight: bold;
    background-image: url("../images/mizumawari/flow_li_bg.svg");
    background-size: cover;
    margin: 0 auto;
}
.flowList .step p {
    transform: translateY(19px);
}
.flow span {
    color: #B26473;
}
/* よくある質問 */
.faqWrapper {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    padding: 0 0;
}
.faq {
    max-width: 1000px;
    margin: 50px auto;
    padding: 50px 20px;
    background-color: #fff;
    text-align: center;
}
.faq h2 {
    font-size: 30px;
    font-weight: bold;
    margin-bottom: 50px;
}
.faq-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 50px;
    text-align: left;
}
.faq-question-wrap {
    overflow: hidden;
    border-radius: 13px;
}
.faq-item {
    margin-bottom: 30px;
    overflow: hidden; /* 角丸を活かすためにOK */
    border-radius: 13px;
    background: transparent;
    /* 背景はここに入れない！ */
}
.faq-item.open {
    background: #F7F4EF; /* ← 開いてる時だけ背景色 */
}
.faq-question {
    display: block;
    width: 100%;
    margin-left: 0;
    height: 86px;
    border-radius: 13px 13px 0 0;
    border-style: none;
    background-color: #B6B096;
    color: #ffffff;
    font-size: 20px;
    font-weight: bold;
    position: relative;
}
/* 左のQマーク */
.faq-question::before {
    content: "";
    position: absolute;
    left: 1rem;
    top: 50%;
    transform: translateY(-50%) translateX(4px);
    width: 46px;
    height: 46px;
    background: url("../images/mizumawari/icon_Q.svg") no-repeat center;
    background-size: contain;
}
/* 右の＋マーク */
.faq-question::after {
    content: "";
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: translateY(-50%) translateX(-6px);
    width: 16px;
    height: 16px;
    background: url("../images/mizumawari/icon_plus.svg") no-repeat center;
    background-size: contain;
}
.faq-answer {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease, padding 0.4s ease; /* ← ここが重要！ */
    padding: 0 20px;
    background: #F7F4EF;
    border-radius: 0 0 13px 13px;
    margin-top: -1px;
    will-change: max-height, padding; /* ← オマケで追加：カクつき予防 */
}
.faq-item.open .faq-answer {
    max-height: 500px;
    padding: 20px;
}
.faq-answer p {
    font-size: 17px;
    margin: 30px;
}
/* 対応エリア */
.areaWrapper {
    background-color: #DFD1C6;
    padding: 60px 0;
}
.areaWrapper h2 {
    font-size: 30px;
    font-weight: bold;
    margin-bottom: 50px;
    text-align: center;
}
.area {
    box-sizing: border-box;
    max-width: 900px;
    height: 170px;
    margin: 50px auto;
    padding: 44px;
    background-image: url("../images/mizumawari/area_bg.svg");
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    text-align: center;
}
/* ========== タブレット対応 ========== */ /*
@media (max-width: 1100px) and (min-width: 801px) {
    .mainImgBox .mainTitle {
        width: 43%;
    }
    .kv .kvImg img {
        width: 75%;
    }
    .kv .kvText {
        width: 100%;
        font-size: clamp(1rem, 3vw, 2.5rem); 
        max-width: 75%; 
        margin: 0 auto;
        text-align: center;
        line-height: 1.6;
    }
    .kv .kv_comment {
        width: 90%;
        height: auto;
        font-size: 20px;
    }
    .featureContainer {
        display: flex;
        justify-content: space-between;
        max-width: 960px;
        margin: 60px auto;
        gap: 40px;
        padding: 0 40px;
        align-items: stretch;
    }
    .featureText {
        width: 55%;
        display: flex;
        flex-direction: column;
        gap: 30px;
    }
    .featureCopy, .featureTokui {
        width: 100%;
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
        padding: 40px 20px;
        box-sizing: border-box;
    }
    .featureTokui {
        height: auto;
        display: flex;
        flex-direction: column;
        align-items: center;
    }
    .featurePointList {
        width: 100%;
        max-width: 360px;
        gap: 14px;
    }
    .featurePointItem {
        width: 100%;
        padding: 0 16px;
        background-size: contain;
        background-repeat: no-repeat;
        box-sizing: border-box;
    }
    .featureImages {
        width: 45%;
        align-self: stretch;
    }
    .imageBox {
        width: 100%;
    }
    .LINE_pc img {
        width: 80%;
    }
    .flowList .step {
        width: 90%;
        margin: 0 auto;
        background-size: contain;
        background-repeat: no-repeat;
        background-position: center;
    }
    .flowList .arrow {
        width: 100px;
    }
    .faq {
        max-width: 960px;
    }
}*/
/* ========== タブレット対応 ここまで ========== */
/* ========== スマホ対応 ========== */
@media (max-width: 820px) {
    body {
        overflow-x: hidden;
    }
    html {
        overflow-x: hidden;
    }
    #mizumawari-reform {
        padding: 0 0;
    }
    p {
        font-size: 15px;
    }
    /* メインタイトル スマホ */
    .mainImgBox {
        width: 100%;
        padding-top: 140%; /* ←スマホ画像の縦長比率に合わせて調整 */
    }
    .mainImgBox .mainImg {
        background-image: url("../images/mizumawari/top_sp.webp");
        top: 0px;
    }
    .mainImgBox .mainTitle {
        width: 75%;
    }
    /* キービジュアル スマホ */
    .kv {
        width: 100%;
        margin: 50px auto 30px;
    }
    .kv .kvImg img {
        width: 100%;
        max-width: 80%;
        margin: 0 auto 20px;
        content: url("../images/mizumawari/kv_sp.svg");
    }
    .kv .kvText {
        font-size: 20px;
        line-height: 1.8;
        max-width: 300px;
        margin: 0 auto 70px;
    }
    .kv .kv_comment {
        max-width: 100%;
        background-image: url("../images/mizumawari/kv_commentbg_sp.webp");
        font-size: 15px;
        line-height: 1.8;
        padding: 20px 16px;
        margin: 0 auto 40px;
        color: #fff;
    }
    .kv .kv_comment br {
        margin-top: 6px;
    }
    /* 特徴 コピー スマホ */
    .featureContainer {
        display: block;
        padding: 0;
        margin: 0px auto;
        box-sizing: border-box;
        width: 100%;
    }
    .featureCopy {
        max-width: 100%;
        aspect-ratio: 416 / 300;
        background-image: url("../images/mizumawari/feature_copybg_sp.svg");
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
        margin: 0 auto 20px;
    }
    .featureCopy h2 {
        font-size: 23px;
    }
    .featureCopy p {
        font-size: 15px;
    }
    .featureText {
        width: 100%;
        margin: 0 auto;
        box-sizing: border-box;
    }
    /* 特徴 コレが得意 スマホ */
    .featureTokui {
        width: 90%;
        margin: 0 auto;
        background-image: url("../images/mizumawari/feature_tokui_bg_sp.svg");
        background-size: contain;
        background-position: center;
        background-repeat: no-repeat;
        padding: 20px 16px;
        box-sizing: border-box;
    }
    .featureTokui h3 {
        margin: 0;
    }
    .tokuiTitle {
        margin: 0 auto 16px;
        display: block;
    }
    .featurePointList {
        max-width: 300px;
        margin: 0 auto;
        gap: 12px;
    }
    .featurePointItem {
        height: 44px;
        line-height: 44px;
        font-size: 14px;
        padding: 0 10px;
        background-size: contain;
        background-image: none; /* デフォルトのカバー背景を無効化 */
    }
    .item1 {
        background-image: url("../images/mizumawari/feature_tokui_box1_sp.svg");
    }
    .item2 {
        background-image: url("../images/mizumawari/feature_tokui_box2_sp.svg");
    }
    .item3 {
        background-image: url("../images/mizumawari/feature_tokui_box3_sp.svg");
    }
    .item4 {
        background-image: url("../images/mizumawari/feature_tokui_box4_sp.svg");
    }
    /* 特徴 画像と吹き出し スマホ */
    .featureImages {
        width: 100%;
        margin-top: 40px;
    }
    .featureImageGroup {
        gap: 0px;
    }
    .imageBox {
        width: 90%;
        max-width: 100%;
        margin: 30px auto;
    }
    .fukidashi {
        max-width: 80%;
        position: absolute;
        z-index: 2;
    }
    .fukidashi1 {
        width: 190px;
        top: -20px;
        left: 0;
    }
    .fukidashi2 {
        width: 165px;
        top: -50px;
        right: 0;
    }
    .fukidashi3 {
        width: 182px;
        top: -40px;
        left: 1%;
    }
    /* 選ばれる理由 */
    .whyChooseUsWrapper {
        padding: 3px 0;
    }
    .whyChooseUs {
        margin: 20px auto;
        max-width: 82%;
        padding: 40px 20px;
        height: auto;
        background-image: url("../images/mizumawari/corner_dot_top.svg"), url("../images/mizumawari/corner_dot_bottom.svg");
        background-position: left top, right bottom;
        background-repeat: no-repeat;
        background-size: 60px, 60px;
    }
    .whyChooseUs h2 {
        font-size: 23px;
        line-height: 1.5;
    }
    .whyChooseUs__list {
        flex-direction: row;
        padding: 0;
        gap: 9px;
    }
    .whyChooseUs__item {
        width: 100%;
        height: 150px;
        padding: 20px;
    }
    .whyChooseUs__item::before {
        background-size: contain;
    }
    .whyChooseUs__item::after {
        right: -20px;
        width: 109%;
        top: 18px;
        background-size: 95% 95%;
        max-width: 560px;
    }
    .whyChooseUs h3 {
        font-size: 16px;
        line-height: 1.4;
        padding-top: 13px;
    }
    .whyChooseUs p {
        font-size: 15px;
        width: 102%;
    }
    /* 施工事例 */
    .casesWrapper {
        padding: 1px 0;
    }
    .case-headings {
        flex-direction: column-reverse;
        align-items: flex-start;
        gap: 0px;
    }
    .cases {
        margin: 20px 15px;
        padding: 20px;
    }
    .case-label {
        font-size: 23px;
        margin-bottom: 10px;
    }
    .case-lead {
        font-size: 16px;
    }
    .case01_main {
        width: 100%;
        min-width: 100%;
    }
    .case01_main, .case02_main, .case03_main, .case04_main {
        width: 100%;
        height: auto;
        margin: 0 auto;
    }
    .caseimg-footer {
        display: flex;
        flex-direction: column;
    }
    /* thumbsをflex横並びにしておく */
    .thumbs {
        display: flex;
        gap: 0px;
        width: 60%
    }
    .thumbs img {
        height: 50px;
        width: 50px;
        margin-right: 10px;
    }
    /* before-img を右に寄せるだけ */
    .before-img {
        width: 45%;
        align-self: flex-end;
        max-width: 150px;
        top: -100px;
        right: -11px;
    }
    .before-img img {
        width: 100%;
        height: auto;
        margin-bottom: 0;
        margin-right: 0;
    }
    .data {
        font-size: 10px;
        margin-top: -2px;
        margin-left: 0px;
        width: auto;
    }
    .data p {
        font-size: 10px;
    }
    .madoriandsubimg {
        flex-direction: column;
        align-items: center; /* 中央揃え（任意） */
        gap: 40px;
    }
    .subimg {
        width: auto;
    }
    .madori-left, .madori-right {
        position: absolute;
        top: 0;
        height: 100%;
        width: 50%;
        z-index: 10;
    }
    .case a {
        cursor: pointer;
        pointer-events: auto;
    }
    .madori-left {
        left: 0;
    }
    .madori-right {
        right: 0;
    }
    .click-area {
        display: block;
        width: 100%;
        height: 100%;
    }
    .subimg img {
        width: 100%;
        height: auto;
    }
    .section-divider {
        margin: 60px auto 30px;
        border-width: 2px;
    }
    .caseSP_buttonArea {
        margin-top: 80px;
    }
    .caseSP_buttonLead {
        height: 18px;
        margin: 0 auto;
    }
    .caseSP_button-text {
        display: flex;
        transform: translateY(-40px);
        font-size: 16px;
        color: #ffffff;
        justify-content: center;
        font-weight: bold;
    }
.caseSP_buttonBg {
    width: 100%;
    max-width: 335px;
    margin: 0 auto;
}
    /* LINE */
    .LINE_sp img {
        display: block;
        width: 90%;
        height: auto;
        margin: 80px auto;
        max-width: 400px;
    }
    /* リフォームの流れ */
    .flowWrapper {
        padding: 3px 0;
    }
    .flow {
        margin: 20px auto;
        max-width: 82%;
        padding: 40px 20px;
        height: auto;
        background-image: url("../images/mizumawari/corner_dot_top.svg"), url("../images/mizumawari/corner_dot_bottom.svg");
        background-position: left top, right bottom;
        background-repeat: no-repeat;
        background-size: 60px, 60px;
    }
    .flow h2 {
        font-size: 23px;
    }
    .flowList {
        max-width: 400px;
        margin: auto;
    }
    .flowList .step {
        background-image: url("../images/mizumawari/flow_li_bg_sp.svg");
    }
    .flowList .step {
        width: 92%;
        height: calc(89vw * 0.42);
        max-height: 220px;
        font-size: 15px;
        font-weight: bold;
        background-image: url("../images/mizumawari/flow_li_bg_sp.svg");
        background-size: 100% 100%;
        background-repeat: no-repeat;
        box-sizing: border-box;
        display: flex;
        flex-direction: column;
        justify-content: center;
        overflow: hidden;
    }
    .flowList .step p {
        margin-top: -45px;
    }
    .flowList .arrow {
        width: 120px;
        height: 20px;
        margin: 0 auto;
    }
    /* よくある質問　スマホ */
    .faq h2 {
        font-size: 23px;
    }
    .faq {
        margin: 0 auto;
        padding: 0px 30px 60px;
    }
    .faq-list {
        grid-template-columns: 1fr;
        gap: 10px;
    }
    .faq-question {
        font-size: 15px;
    }
    .faq-answer p {
        font-size: 14px;
        margin: 10px;
    }
    .faq-question::before {
        width: 40px;
        height: 40px;
    }
    /* 対応エリア　スマホ */
    .areaWrapper {
        padding: 40px 0;
    }
    .areaWrapper h2 {
        font-size: 23px;
    }
    .area {
        max-width: 90%;
        margin: 30px auto;
        background-image: url("../images/mizumawari/area_bg_sp.svg");
        background-size: 100% 100% !important;
        padding: 23px;
        font-size: 13px;
    }
.mizumawari_form {
    max-width: 100%;
    margin: 0 auto;
}
}
/* スマホここまで　ボタンはもっと下 */
/* ボタン・ボタンきらり */
.buttonArea {
    text-align: center;
    margin: 140px 0;
}
.buttonWrapper {
    text-align: center;
    width: 480px;
    margin: 0 auto;
}
.image-button {
    position: relative;
    overflow: hidden;
    display: inline-block;
    width: 100%;
    text-decoration: none;
    color: #fff;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.buttonLead {
    display: block;
    width: auto;
    height: 23px;
    margin: 0 auto 8px auto;
}
.buttonBg {
    width: 100%;
    height: auto;
    display: block;
    margin: auto;
}
.button-text {
    position: absolute;
    top: 65%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 1.1em;
    font-weight: bold;
    color: #fff;
    pointer-events: none;
    white-space: nowrap;
}
.image-button:hover {
    opacity: 1 !important;
    transform: translateY(-4px);
    transition: 0.5s;
}
a.image-button:hover, a.image-button:hover img, a.image-button:hover span {
    opacity: 1 !important;
}
.image-button:hover .button-text .whyChooseUs__button {
    color: #fff !important;
}
.whyChooseUs__button:hover .whyChooseUs__button-text {
    color: #fff !important;
}
.image-button::before {
    content: "";
    position: absolute;
    top: -50%;
    left: -75%;
    width: 50%;
    height: 200%;
    background: rgba(255, 255, 255, 0.3);
    transform: rotate(25deg);
    pointer-events: none;
}
.image-button:hover::before {
    animation: shine 0.7s ease-out;
}
/* ========== ボタン スマホ対応 ========== */
@media (max-width: 820px) {
    /* お申し込みボタン スマホ */
    .buttonArea {
        width: 100%;
        margin: 70px 0 100px;
    }
    .buttonWrapper {
        width: 80%;
    }
    .cases .buttonWrapper {
        width: 100%;
    }
    .buttonLead {
        height: 17px;
        margin: 0 auto 3px auto;
    }
    .button-text {
        font-size: 0.9em;
    }
    .buttonBg {
        max-width: 335px;
    }
    .whyChooseUs__button {
        width: 86%;
        background-size: contain;
        font-size: 17px;
        max-width: 335px;
    }
}
/* ========== ボタン スマホ対応 ここまで ========== */
@keyframes shine {
    0% {
        left: -75%;
    }
    100% {
        left: 125%;
    }
}
/* ふわっと表示 */
.inview.fadeup {
    opacity: 0;
    transform: translateY(20px);
    transition-property: opacity, transform;
    transition-duration: 1s;
    transition-timing-function: ease-out;
}
.inview.fadeup.active {
    opacity: 1;
    transform: translateY(0px);
}
.fadeup-fast {
    transition-duration: 0.5s;
    transition-timing-function: ease-in;
}
.delay01 {
    transition-delay: 0.3s;
}
.delay02 {
    transition-delay: 0.6s;
}
.delay03 {
    transition-delay: 0.9s;
}
.delay04 {
    transition-delay: 1.2s;
}
.delay05 {
    transition-delay: 1.5s;
}
.delay06 {
    transition-delay: 1.8s;
}
.delay07 {
    transition-delay: 2.1s;
}
.delay08 {
    transition-delay: 2.4s;
}
.delay09 {
    transition-delay: 2.7s;
}
.delay10 {
    transition-delay: 3.0s;
}
.delay_featureImg1 {
    transition-delay: 1.0s;
}
.delay_featureImg2 {
    transition-delay: 1.6s;
}
.delay_featureImg3 {
    transition-delay: 2.2s;
}
.delay_featureImg4 {
    transition-delay: 1.3s;
}
.delay_featureImg5 {
    transition-delay: 1.9s;
}
.delay_featureImg6 {
    transition-delay: 2.5s;
}