/* 変数定義 */
:root {
    --main-color: #2c2c44;
    --danger-color: #C30D23;
    --info-color: #078EC8;
    --text-color: #474747;
    --text-dark: #1c1c1c;
    --white: #fff;
    --shadow: 0 .2rem 0.5rem rgba(0, 0, 0, .15);
    --border-radius: 3px;
    --transition: all 0.3s ease;
}

/* ベーススタイル */
body,
p,
table {
    letter-spacing: 0.5px;
    font-weight: 500;
    font-family: 'Noto Sans JP', sans-serif;
}

body {
    background: #f5f5f5 !important;
}

h2,
p,
h3 {
    font-family: 'Noto Sans JP', sans-serif;

}

/* レイアウト */
.container-xl {
    max-width: 1100px;
}

.flex-md-row {
    display: flex;
}

.flex {
    display: flex;
    justify-content: center;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.col-md-8{
    width: 60%!important;
}
.video{
    padding-top: 3rem;
    background: #fff;
}


.row {
    justify-content: center;
}

/* グリッドシステム */
.col-4 {
    width: 40% !important;
}

.app {
    padding-top: 0 !important;
}

.app-wrapper {
    max-width: auto !important;
}

.col-8 {
    width: 60% !important;
}
.sp {
    display: none !important;
}

.pc{
    display: block;
}

/* タイポグラフィ */
h2 {
    margin-bottom: 0.7rem;
    font-size: 36px;
}

h3,
.h3 {
    font-size: calc(1.1rem + 0.6vw);
    line-height: 1.5;
}

h4,
.h4 {
    line-height: 1.45;
    font-size: clamp(17px, 1.2vw, 22px);
}

h5,
.h5 {
    font-size: calc(1em + 0.4vw);
    line-height: 1.5;
}

.fs-2 {
    font-weight: normal;
    font-size: 1.1em;
}

/* ボタン */
.btn {
    font-weight: 600;
    padding: 1.2rem 0.8rem;
    font-size: 1.6rem;
    width: 45%;
}

.cmn_btn01 {
    height: 64px;
    overflow: hidden;
    border-radius: 32px;
    transition: var(--transition);
    position: relative;
    cursor: pointer;
}

.cmn_btn01.navy {
    border: 3px solid #2c2c44;
    background: #2c2c44;
}

.cmn_btn01.navy a {
    color: #fff;
}

.cmn_btn01.white {
    background: #fff;
}

.cmn_btn01.white a {
    color: var(--main-color);
}

/* ユーティリティ */
.shadow {
    box-shadow: var(--shadow) !important;
}

.bg-danger {
    background-color: var(--danger-color) !important;
}

.red {
    color: var(--danger-color);
}

.info a,
.info {
    color: #0000ff;
    text-decoration: underline;
}

/* レスポンシブ */
.pc {
    display: block !important;
}

.sp {
    display: none !important;
}
@media screen and (max-width:1080px) {
    .fix_area .btn_area{
        display: block!important;
        margin:0.6rem auto;
        text-align: center;
    }
    .fix_area .btn_area .cmn_btn01{
        width: 250px!important ;
        margin:0.6rem auto;
    }
    .con1 {
        background: url(/img/ecgo/header-bg.jpg) no-repeat top center;
        background-size: cover;
    }
}

/* メディアクエリ */
@media screen and (max-width: 780px) {
    .pc {
        display: none;
    }
    .header-bg .header-item p{
        background: #fff;
        margin-top: 0!important;
        padding: 0.1rem;
    }
    .con1 .container-lg{
        padding: 0!important;
    }

    .sp {
        display: block;
    }

    .btn {
        width: 100%;
    }

    h2 {
        font-size: 28px;
    }

    h5 {
        font-size: 16px;
    }
}

.con3,
.con4,
.con5,
.con6,
.con7,
.con8,
.con9,
.con10,
.con11,
.con12,
.con13 {
    padding-bottom: 2.5rem;
}

.fix_area .btn_area {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 0 30px;
    width: 100%;
}

.fix_area.area_act {
    visibility: visible;
    opacity: 1;
}

.fix_area .btn_area .cmn_btn01 {
    width: 220px;
    height: 50px;
}

.cmn_btn01.navy {
    border: 3px solid #2c2c44;
    background: #2c2c44;
    padding-right: 1rem;
}

.cmn_btn01 {
    height: 64px;
    overflow: hidden;
    border-radius: 32px;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    position: relative;
    cursor: pointer;
}

*,
::before,
::after {
    box-sizing: border-box;
    border-style: solid;
    border-width: 0;
}

.fix_area .btn_area .cmn_btn01 a {
    font-size: 16px;
}

.cmn_btn01.navy a {
    color: #fff;
}

.cmn_btn01.navy {
    padding-right: 2.5rem;
    border: 3px solid #2c2c44;
    background: #2c2c44;
}

.cmn_btn01 {
    font-weight: 700;
    font-size: 18px;
    text-align: center;
    padding: 1rem 2rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 100%;
    position: relative;
    z-index: 1;
    position: relative;
}

.cmn_btn01.navy::after {
    background: #fff;
}
.cmn_btn01.navy:hover::after {
    background: #2c2c44;
}

.cmn_btn01::after {
    content: "";
    width: 8px;
    height: 8px;
    border-radius: 50vh;
    position: absolute;
    background: #2c2c44;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    right: 22px;
    -webkit-transition: all 0.4s ease;
    transition: all 0.4s ease;
}

*,
::before,
::after {
    box-sizing: border-box;
    border-style: solid;
    border-width: 0;
}

.fix_area .btn_area .cmn_btn01 {
    width:80%;
    height: 50px;
}
.fix_area .btn_area .cmn_btn01{
    width:340px;
}
.cmn_btn01.navy {
    border: 3px solid #2c2c44;
    background: #2c2c44;
}

.fix_area .btn_area .cmn_btn01.circle_none.white {
    border: 3px solid #2c2c44;
}

.cmn_btn01.white {
    background: #fff;
}

.cmn_btn01.white a {
    color: #2c2c44;
}

.shadow {
    box-shadow: 0 .2rem 0.5rem rgba(0, 0, 0, .15) !important;
}

.bg-danger {
    background-color: #C30D23 !important;
}

img {
    max-width: 100%;
}

.line-white {
    border: 1px solid #fff;
    -webkit-border-radius: 3px;
    border-radius: 3px;
}

p {
    color: #1c1c1c;
}

.pc {
    display: block;
}

.sp {
    display: none !important;
}

h4,
.h4 {
    line-height: 1.45;
    font-size: clamp(17px, 1.2vw, 22px);
}

h2 {
    margin-bottom: 0.7rem;
    font-size: 36px;
}

h3,
.h3 {
    font-size: calc(1.1rem + 0.6vw);
    line-height: 1.5;
}

h5,
.h5 {
    font-size: calc(1em + 0.4vw);
    line-height: 1.5;
}

.fs-2 {
    font-weight: normal;
    font-size: 1.2em;
}

.red {
    color: #C30D23;
}

.btn {
    font-weight: 600;
    padding: 0.8rem 0.4rem;
    font-size: 1.2rem;
    width: 100%;
}

.info a,
.info {
    color: #078EC8;
    text-decoration: underline;
}

.d-flex .badge {
    margin-right: 0.4rem;
}

.container-xl {
    max-width: 1100px;
}

.cmn_btn01.navy:hover {
    background: #fff;
}

.header-bg .header-item p {
    text-align: left;
    line-height: 1.8;
    margin-top: 1rem;
    font-size: 1em;
}

.cmn_btn01:hover.navy a {
    color: #2c2c44 !important;
}

a:hover {
    opacity: 0.94;
}

.cmn_btn01.navy a {
    color: #fff;
}

.list-group-item {
    border: none;
    padding: .3rem 1rem;
}

.row {
    justify-content: center;
}

.btn-outline-danger {
    color: #C30D23;
    border-color: #C30D23;
}

.btn-outline-danger:hover {
    color: #FFF;
    background-color: #C30D23;
    border-color: #C30D23;
}

.help.btn {
    font-size: 1em !important;
}

.col-3 {
    width: 22%;
}

.back a {
    text-decoration: underline;
    color: #6C757D;
    font-size: 0.9em;
}

.back a:hover {
    opacity: 0.9;
}

.multi-swiper {
    width: 100%;
    max-width: 1000px;
    margin: 0 auto;
}

.multi-swiper img {
    width: 100%;
    max-width: 150px;
    height: 150px;
    object-fit: cover;
}

.swiper-pagination-bullet-active {
    background: #C30D23;
}

.swiper-button-next:after,
.swiper-button-prev:after {
    color: #C30D23;
}

.swiper-slide {
    height: auto;
    padding: 1.52rem;
    background: #fff;
    border: 1px solid #8F8F8F;
    -webkit-border-radius: 15px;
    border-radius: 15px;
}

.swiper-slide p {
    color: #222222;
    font-size: 15px;
    letter-spacing: 1px;
    line-height: 1.6;
}

.swiper-button-prev,
.swiper-rtl .swiper-button-next {
    display: none;
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
    display: none;
}

.swiper-wrapper {
    transition-timing-function: linear;
}

/* オーバーレイのスタイル */
.popup-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    display: none;
    z-index: 999;
}

/* ポップアップボックスのスタイル */
.popup-box {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 86%;
    max-width: 800px;
    max-height: 70%;
    /* 高さを制限 */
    padding: 40px 20px 20px;
    /* 上部に余白を確保（閉じるボタンのため） */
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
    display: none;
    z-index: 1000;
    overflow-y: auto;
    /* 縦方向にスクロール可能 */
    scrollbar-width: thin;
    /* Firefox用 */
    scrollbar-color: #aaa #f4f4f4;
    /* Firefox用 */
}

/* Webkit系ブラウザのスクロールバーカスタマイズ */
.popup-box::-webkit-scrollbar {
    width: 8px;
    /* スクロールバーの幅 */
}

.popup-box::-webkit-scrollbar-thumb {
    background: #aaa;
    /* スクロールバーのつまみの色 */
    border-radius: 4px;
    /* つまみを丸くする */
}

.popup-box::-webkit-scrollbar-thumb:hover {
    background: #888;
    /* ホバー時のつまみの色 */
}

.popup-box::-webkit-scrollbar-track {
    background: #f4f4f4;
    /* スクロールバーの背景色 */
    border-radius: 4px;
    /* 背景も少し丸みをつける */
}

/*------------------------------------*\
    section.con1
\*------------------------------------*/




.container-lg {
    max-width: 1100px !important;
}

.cap-bg {
    background: #C30D23;
    font-size: 1.2em !important;
    font-weight: normal !important;
    margin-top: 2rem;
}

.logo {
    margin-bottom: 1.4rem;
}

.logo img {
    max-width: 100px;
}

.app-wrapper {
    margin-left: 0;
}

.app {
    background: #fff;
}

.sub {
    max-width: 560px;
    display: inline-block;
    margin: 0.1rem auto;
}

/*------------------------------------*\
    section.con2
\*------------------------------------*/


.problem-heading {
    display: flex;
    align-items: center;
    position: relative;
    font-weight: 500;
    font-size: 1rem;
    text-transform: uppercase;
    color: #000;
    border: none;
}


.problem-heading::before {
    content: "●";
    color: black;
    margin-right: 8px;
    margin-left: 6px;
}

h2 {
    font-size: 2.6em !important;
    font-weight: bold;
    line-height: 1.4 !important;
    color: #000 !important;
}

.con2 {
    padding-top: 4rem;
}

/*カラフルライン*/

.vertical-lines {
    display: flex;
    height: 3px;
    width: 200px;
    margin-top: 2rem;
    margin-bottom: 4rem;
    flex-direction: row;
    flex-wrap: wrap;
}

.vertical-lines>div {
    flex: 1;
    width: 100%;
}

.line-orange {
    background-color: #f59c00;
}

/* オレンジ */
.line-red {
    background-color: #b9001e;
}

/* 赤 */
.line-black {
    background-color: #000000;
}

/* 黒 */
.line-blue {
    background-color: #0057a0;
}

/* 青 */


.trouble-wrap {
    padding-left: 1rem;
}

.con2 .container-lg {
    background: url(/img/ecgo/img02.png)no-repeat right top;
}

.item {
    border: 2px solid #555;
    border-radius: 2rem;
    padding: 1rem;
    text-align: center;
    width: 30%;
    height: 200px;
    margin-bottom: 1rem;
    margin-right: 1rem;
    background: #FBFBFB;
}

.item img {
    margin: auto;
}

#more-btn:hover {
    cursor: pointer;
    opacity: 0.9;
}

.item p {
    margin-top: 0.5rem;
}

/*------------------------------------*\
    section.con3
\*------------------------------------*/

.con3 {
    position: relative;
    z-index: 2;
    padding-top: 5rem;
    color: #000;
    margin-top: 4rem;
    padding-bottom: 6rem;

}

.yellow-bg {
    background-size: cover !important;
    margin-left: 4rem;
    padding-bottom: 6rem;
    padding-top: 6rem;
    border-top-left-radius: 12rem;
    /* 左上の角 */
    border-bottom-left-radius: 12rem;
    /* 左下の角 */

    background: url(/img/ecgo/con3bg.webp)no-repeat right top;
}

.con3 .item-inner {
    background: #FFF;
    padding: 1rem 2rem 2rem 2rem;
    max-width: 481px;
    min-height: 400px;
    color: #000;
}

.con3 .num {
    font-family: 'Noto Sans';
    font-weight: bold;
    line-height: 1 !important;
    font-size: 2em;
}

.con3 h3 {
    font-size: 1.3em;
    line-height: 1.7;
    text-align: center;
}

.con3 p {
    line-height: 2;
    margin-top: 1rem;
}

.con3 .box {
    margin-right: 3rem;

}

.con3 .box:nth-child(even) {
    margin-right: 0;
    margin-top: 6rem;
}

.con3 .box:last-child {
    margin-top: 3rem;
    margin-right: 0;
}

.con3 .cmn_btn01 {
    border: 2px solid #252930;
    max-width: 500px;
    margin: 3rem auto 2rem auto;
}


/*------------------------------------*\
    section.con4
\*------------------------------------*/

.con4 {
    background: #FFF;
    margin-top: -15rem;
    padding-top: 20rem;
}

.con4 .voice-wrap img {
    margin-right: 1rem;
    margin-top: 1rem;
}

.con4 .container-lg {
    margin-bottom: 4rem;
}



/*------------------------------------*\
    section.con5
\*------------------------------------*/

.con5 {
    background-color: #FFF;
    background-image: url(/img/ecgo/review-bg1.png), url(/img/ecgo/review-bg2.png);
    background-position: left top, right top;
    background-repeat: no-repeat;
    padding-top: 3rem;
    padding-bottom: 6rem;

}

.review {
    text-align: center;
}
.review img{
    margin: auto;   
}

/*------------------------------------*\
    section.con6
\*------------------------------------*/


.con6 {
    background: #FFF;
    padding-top: 4rem;
}

.accordion_area .accordion_one .ac_header {
    background-color: #ffffff;
    border: 1px solid #ccc;
    padding: 1.5rem 4rem 1.5rem 2rem;
    position: relative;
    z-index: +1;
    cursor: pointer;
    transition: .2s;
}

.accordion_area {
    margin-top: 3rem;
    margin-bottom: 3rem;
}

.gutter>*:not(:last-child) {
    margin-bottom: 1.5rem;
}

.p-faq__headinner {
    display: block;
    padding-left: 35px;
    position: relative;
    line-height: 1.5;
}

.p-faq__headinner::before {
    position: absolute;
    left: 0;
    content: "Q．";
    color: #bd052c;
    font-size: 27px;
    font-weight: bold;
}

.p-faq__headinner p.p-faq__q-txt {
    font-size: 20px;
    margin-left: 2rem;
    margin-bottom: 0 !important;
    color: #142537;
    line-height: 2;
}

.p-faq__bodyinner p.p-faq__a-txt {
    line-height: 2;
    margin-bottom: 0 !important;
}

.p-faq__bodyinner::before {
    position: absolute;
    left: 0;
    content: "A．";
    color: #294da1;
    font-size: 27px;
    font-weight: bold;
}

.p-faq__bodyinner p.p-faq__a-txt {
    font-size: 20px;
    margin-left: 2rem;
    color: #142537;
}

.accordion_area .accordion_one .ac_header .i_box {
    position: absolute;
    top: 50%;
    right: 2rem;
    width: 20px;
    height: 20px;
    margin-top: -10px;
}

.accordion_area .accordion_one .ac_header .i_box:before,
.accordion_area .accordion_one .ac_header .i_box:after {
    position: absolute;
    content: "";
    margin: auto;
    box-sizing: border-box;
    vertical-align: middle;
}

.accordion_one .ac_header .i_box:before {
    border-top: 2px solid #bd052c;
    width: 20px;
    height: 0;
    top: 0;
    bottom: 0;
    right: 0;
}

.i_box:after {
    border-left: 2px solid #bd052c;
    width: 0;
    height: 20px;
    top: 0;
    bottom: 0;
    right: 9px;
    transition: .3s;
}

.accordion_area .accordion_one .ac_inner {
    display: none;
    padding: 1.5rem 2rem 1.5rem 2rem;
    border-left: 1px solid #ccc;
    border-right: 1px solid #ccc;
    border-bottom: 1px solid #ccc;
    box-sizing: border-box;
    background: #fbfcff;
}

.p-faq__bodyinner {
    display: block;
    padding-left: 35px;
    position: relative;
    line-height: 1.5;
}

.ac_inner p {
    font-size: 17px !important;
}


.grey-bg {
    background-color: #F4F4F4;
    -webkit-border-radius: 0 8rem 8rem 0;
    border-radius: 0 8rem 8rem 0;
    margin-right: 7rem;
    padding-top: 4rem;
    padding-bottom: 4rem;
}

.center {
    text-align: center;
}

/*------------------------------------*\
    section.con7
\*------------------------------------*/

.con7 {
    background: #FFF;
    padding-bottom: 4rem;
}

.con7 h4 {
    font-size: 1.2em;
    margin-bottom: 1rem;

}


.app-footer {
    background: #000;
    color: #FFF;
}

.fixed-btns {
    position: fixed;
    right: 1vw;
    bottom: 0;
    z-index: 1000;
    width: 300px;
    height: 160px;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.5s, transform 0.5s;
    transform: translateY(40px);
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
}

.fixed-btns.active {
    opacity: 1;
    pointer-events: auto;
    transform: translateY(0);
}

.btns-group {
    display: flex;
    flex-direction: column;
    position: absolute;
    left: 5px;
    top: 40px;
    z-index: 2;
    gap: 12px;
    width: 200px;
}

.btn2 {
    display: block;
    padding: 9px 0;
    border-radius: 25px;
    font-weight: bold;
    font-size: 1rem;
    text-align: center;
    text-decoration: none;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.07);
    position: relative;
    padding-right: 36px;
}

.btn2::after {
    content: "";
    width: 8px;
    height: 8px;
    display: inline-block;
    border-radius: 50%;
    position: absolute;
    right: 18px;
    top: 50%;
    transform: translateY(-50%);
}

.btn2 a:hover {
    opacity: 0.9;
    color: #0C2145;
}

.btn-navy::after {
    background: #fff;
    /* navy色のドット */
    border: 1.5px solid #fff;
    /* 白枠 */
    transition: background 0.2s, border 0.2s;
}

.btn-white {
    background: #fff;
    color: #0C2145;
    border: 1px solid #0C2145;
}
.btn-white:hover{
    color:#2c2c44 ;
}

.btn-white::after {
    background: #0C2145;
}

.btn-navy {
    background: #2c2c44;
    color: #fff;
    border: 1px solid #2c2c44;
    transition: background 0.2s, color 0.2s;
}

.btn-illust {
    height: auto;
    z-index: 1;
    display: block;
    margin-left: auto;
    margin-bottom: 0;
}

.btn-navy:hover {
    background: #fff;
    color: #0C2145;
    border-color: #0C2145;
}

.btn-navy:hover::after {
    background: #0C2145;
    /* 反転：白丸＋紺枠 */
   
}
@media screen and (max-width: 1023px) {
    .con5 {
        background-color: #FFF;
        background-image: url(..//img/ecgo/review-bg1.png), url(..//img/ecgo/review-bg2.png);
        background-position: -8rem top, 38rem top;
        background-repeat: no-repeat;
        padding-top: 3rem;
        padding-bottom: 6rem;
    
    }
}


/*スマホ*/

@media screen and (max-width: 780px) {
    .pc {
        display: none !important;
    }
    
    .url-form {
        width: 100%;
    }
    .col-md-5{
        width: 100%!important;
    }

    .app-nav-tabs .nav-link.active::after {
        display: none;
    }

    .fixed-btns {
        right: 1vw;
        bottom: 0;
    }

    .flex-md-row {
        display: block;
    }

    .fixed-btns {
        width: 100%;
        max-width: 400px;
        height: 120px;
        right: 0;
        left: 0;
        margin: 0 auto;
    }

    .btns-group {
        left: 50%;
        transform: translateX(-50%);
        display: flex;
        flex-direction: row;
        top: 67px;
        gap: 8px;
        width: auto;
        max-width: 90%;
        justify-content: center;
    }


    .btn-illust {
        width: 100px;
    }

    .btn2,
    .btn-white,
    .btn-navy {
        font-size: 1rem;
        padding: 8px 12px;
        min-width: 120px;
        max-width: 200px;
        flex: 1;
    }

    .pc {
        display: none !important;
    }

    .sp {
        display: block !important;
    }

    .btn {
        width: 80%;
    }

    .list {
        width: 100%;
        min-width: auto;
    }

    .title-bg {
        padding: 2rem 1.2rem;
    }

    h2 {
        line-height: 1.5;
        font-size: 1.6em;
    }

    h5 {
        font-size: 1.2em;
        line-height: 1.5;
    }
    


    .d-flex .badge {
        margin-right: 0.2rem;
        font-size: 0.72em;
    }

    ..badge {
        padding: 0.6em 0.65em;
    }

    .cap-bg {
        background: #C30D23;
        font-size: 0.85em !important;
        font-weight: bold !important;
    }

    .header-bg .header-item p {
        font-size: 0.86em;
    }

    .cmn_btn01.navy {
        padding-right: 2rem;
    }

    .btn {
        padding: 4rem 0 !important;
    }

    .fix_area .btn_area .cmn_btn01 a {
        font-size: 0.75em !important;
    }

    .cmn_btn01::after {
        right: 10px;
    }

    .fix_area .btn_area {
        gap: 0 12px;
    }

    .fix_area .btn_area .cmn_btn01 {
        height: 38px;
    }

    .fix_area .btn_area .cmn_btn01.circle_none.white {
        border: 2px solid #2c2c44;
    }

    .cmn_btn01 {
        margin-bottom: 2rem;
        font-size: 17px;
        padding: 0.1rem 1.1rem;
    }

    .img01 {
        width: 67%;
        margin-bottom: -12px;
        float: right;

    }

    h2 {
        font-size: 1.2em !important;
    }

    .problem-heading {
        font-size: 0.8rem;
    }

    .con2 .container-lg {
        background: url(..//img/ecgo/img02.png) no-repeat 14rem 2rem;
        background-size: 41%;
    }

    .item {
        border: 2px solid #555;
        border-radius: 1rem;
        padding: 1rem;
        text-align: center;
        width: 48%;
        height: 200px;
        margin-bottom: 1rem;
        margin-right: 0.8rem;
        background: #FBFBFB;
    }

    .item p {
        font-size: 0.8em;
    }

    .item:nth-child(even) {
        margin-right: 0;
    }

    .trouble-wrap {
        padding-left: 0;
    }

    .con3 {
        padding-top: 3rem;
        margin-top: 0rem;
    }

    .yellow-bg {
        background-size: cover !important;
        margin-left: 0;
        padding-bottom: 3rem;
        padding-top: 3rem;
        border-top-left-radius: 5rem;
        border-bottom-left-radius: 5rem;
    }

    .con3 h3 {
        font-size: 1em;
    }

    .con3 .num {
        font-size: 1.4em;
    }

    .con3 .box {
        margin-right: 0;
    }

    .con3 p {
        font-size: 0.9em;
    }

    .con3 .box:nth-child(even) {
        margin: auto;
    }

    .con3 .box {
        margin-top: 2rem !important;
    }

    .vertical-lines {
        margin-bottom: 2rem;
    }

    .con3 .cmn_btn01 {
        padding: 0.3rem;
        max-width: 220px;
    }

    .con4 {
        margin-top: -21rem;
    }

    .con4 .voice-wrap img {
        width: 90%;
        margin: 0.5rem auto;
    }

    .accordion_area .accordion_one .ac_header .i_box {
        right: 1rem;
    }
    .text-box {
        padding: 0 1rem !important;
    }


    .accordion_area .accordion_one .ac_header {
        padding: 1rem 3rem 1rem 1rem;
    }

    .p-faq__headinner::before {
        font-size: 17px;
    }

    .p-faq__headinner p.p-faq__q-txt {
        font-size: 14px;
        margin-left: 0;
    }

    .grey-bg {
        margin-right: 0;
    }

    .p-faq__bodyinner::before {
        font-size: 17px;
    }

    .p-faq__bodyinner p.p-faq__a-txt {
        margin-left: 0;
    }

    .ac_inner p {
        font-size: 14px !important;

    }

    .p-faq__a-txt {
        overflow-wrap: break-word;
    }



    .con5 {
        padding-top: 0;
        padding-bottom: 0;
        background: transparent;
    }

    .con5 .container-lg {
        padding: 0;
    }

    .btn2 {
        padding: 9px 17px;
        width: 370px;
    }

    .btn2::after {
        right: 11px;
    }
    .app-footer{
        padding-bottom: 6rem;   
    }

}

/* より小さなスマホ画面対応 */
@media screen and (max-width: 375px) {
    .fixed-btns {
        max-width: 95%;
    }
    
    .btns-group {
        gap: 5px;
        max-width: 95%;
    }
    
    .btn2,
    .btn-white,
    .btn-navy {
        font-size: 0.8rem;
        padding: 6px 10px;
        min-width: 100px;
        max-width: 140px;
    }
    
    .btn-illust {
        width: 80px;
    }
}