/****** 製品ページ ******/

/**** 勤怠管理　開始 ****/
.attend-color {
    color: #cc3399;
}

.attend-back {
    background-color: #cc3399;
}

.attend-border-color {
    border-color: #cc3399;
}

#attend h3 {
    color: #cc3399;
}

#attend h3 span {
    color: #ffffff;
    background: #cc3399;
    background-color: #cc3399;
    border: 1px solid #cc3399;
}

#attend>li {
    border: 5px double #cc3399;
}

#attend .fa-lightbulb {
    color: #cc3399;
    font-size: 3vh;
    padding-right: 0.3em;
}

#attend .support-title {
    border: 1px solid #cc3399;
    background-color: #cc3399;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

/* 特徴1  */
.attend_wrapper01 {
    display: grid;
    /*grid-template-columns: repeat(4, 1fr);*/
    grid-column: 1/5;
    width: 100%;
    column-gap: 2em;
    /*IE用*/
    display: -ms-grid;
    -ms-column-gap: 2em;
    -ms-grid-columns: 50% 50%
}

.attend_wrapper01 img {
    width: 100%;
}

.box1 {
    grid-column-start: 1;
    grid-column-end: 3;
    grid-row-start: 1;
    grid-row-end: 2;
    width: 100%;
    margin: auto;
    display: block;
    text-align: center;
    /*IE用*/
    -ms-grid-column: 1;
    -ms-grid-column-span: 3;
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
}

.box1 img {
    border: 3px solid #cc3399;
    max-width: 500px;
}

.box2 {
    grid-column-start: 1;
    grid-column-end: 2;
    grid-row-start: 2;
    grid-row-end: 3;
    max-width: 350px;
    height: 100%;
    margin-left: auto;
    margin-right: 1em;
    /*IE用*/
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
}

.box3 {
    grid-column-start: 2;
    grid-column-end: 3;
    grid-row-start: 2;
    grid-row-end: 3;
    max-width: 344px;
    height: 100%;
    /*IE用*/
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    -ms-grid-row: 2;
    -ms-grid-row-span: 1;
}

.box2 tr:nth-child(2n),
.box3 tr:nth-child(2n) {
    background-color: #cc3399;
    color: #ffffff;
    margin-top: -2em;
}

.box2 td,
.box3 td {
    border: none;
}

/* 特徴2 */
.attend_wrapper02 {
    display: grid;
    grid-column: 1/5;
    width: 100%;
    /*IE用*/
    display: -ms-grid;
    -ms-column-gap: 2em;
    -ms-grid-columns: 50% 50%;
}

.attend_wrapper02>div {
    margin: 0.5em;
}

.box4 {
    grid-column-start: 1;
    grid-column-end: 2;
    grid-row-start: 1;
    grid-row-end: 2;
    max-width: 300px;
    margin-left: auto;
    /*IE用*/
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
}

.box4 img {
    max-width: 300px;
}

.box5 {
    grid-column-start: 2;
    grid-column-end: 3;
    grid-row-start: 1;
    grid-row-end: 2;
    max-width: 300px;
    /*IE用*/
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    -ms-grid-row: 1;
    -ms-grid-row-span: 1;
}

.box5 img {
    max-width: 300px;
}

.box4 td,
.box5 td {
    border: 3px solid #cc3399;
}

.box4 tr:nth-child(2n),
.box5 tr:nth-child(2n) {
    border: 1px solid #cc3399;
    background-color: #cc3399;
    color: #ffffff;
    text-align: center;
}

.box6 {
    grid-column-start: 1;
    grid-column-end: 3;
    grid-row-start: 2;
    grid-row-end: 4;
    text-align: center;
    /*IE用*/
    -ms-grid-column: 1;
    -ms-grid-column-span: 2;
    -ms-grid-row: 2;
    -ms-grid-row-span: 2;
}

.box7 {
    grid-column-start: 1;
    grid-column-end: 2;
    grid-row-start: 3;
    grid-row-end: 4;
    max-width: 350px;
    margin-left: auto;
    /*IE用*/
    -ms-grid-column: 1;
    -ms-grid-column-span: 1;
    -ms-grid-row: 3;
    -ms-grid-row-span: 1;
}

.box8 {
    grid-column-start: 2;
    grid-column-end: 3;
    grid-row-start: 3;
    grid-row-end: 4;
    max-width: 350px;
    /*IE用*/
    -ms-grid-column: 2;
    -ms-grid-column-span: 1;
    -ms-grid-row: 3;
    -ms-grid-row-span: 1;
}

.box7,
.box8 {
    border: 4px solid #32cd32;
    border-radius: 20px;
    padding: 0.5em;
    color: #000000;
    background-color: #ffffff;
}

/**** 勤怠管理　終わり ****/


/**** 報酬管理　開始 ****/
.reward-color {
    color: #2d479b;
}

#reward h3 {
    color: #2d479b;
}

#reward h3 span {
    color: #ffffff;
    background: #2d479b;
    background-color: #2d479b;
    border: 1px solid #2d479b;
}

#reward>li {
    border: 5px double #2d479b;
}

#reward>li img {
    max-width: 600px;
    width: 100%;
    /*border:1px #ccc solid;*/
}

#reward .product-support dt {
    background-color: #2d479b;
    border-style: none;
}

#reward dd {
    border-color: #2d479b;
}

#reward .fa-lightbulb {
    color: #2d479b;
    font-size: 3vh;
    padding-right: 0.3em;
}

#reward .support-title {
    border: 1px solid #2d479b;
    background-color: #2d479b;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

/**** 報酬管理　終わり ****/


/**** 栄養計算　開始 ****/
.food-color {
    color: #ffa500;
}

#food h3 {
    color: #ffa500;
}

#food h3 span {
    color: #ffffff;
    background-color: #ffa500;
    border: 1px solid #ffa500;
}

#food>li {
    border: 5px double #ffa500;
}

#food>li img {
    max-width: 600px;
    width: 100%;
}

#food .product-support dt {
    background-color: #ffa500;
    border-style: none;
}

#food dd {
    border-color: #ffa500;
}

#food .fa-lightbulb {
    color: #ffa500;
    font-size: 3vh;
    padding-right: 0.3em;
}

#food .support-title {
    border: 1px solid #ffa500;
    background-color: #ffa500;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

/**** 栄養計算　終わり ****/


/**** 財務　開始 ****/
.zaim-color {
    color: #ff9900;
}

.zaim-back {
    background-color: #ff9900;
}

.zaim-border-color {
    border-color: #ff9900;
}

#zaim h3 {
    color: #ff9900;
}

#zaim h3 span {
    color: #ffffff;
    background: #ff9900;
    background-color: #ff9900;
    border: 1px solid #ff9900;
}

#zaim>li {
    border: 5px double #ff9900;
}

#zaim .fa-lightbulb {
    color: #ff9900;
    font-size: 3vh;
    padding-right: 0.3em;
}

#zaim .support-title {
    border: 1px solid #ff9900;
    background-color: #ff9900;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

#zaim .product-support dt {
    background-color: #ff9900;
    border-style: none;
}

#zaim dd {
    border-color: #ff9900;
}

/**** 財務　終わり ****/

/**** NEW製品ページ　全システム共通パーツ ****/

/* 画面内メニューバー */
.product_li {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    width: 100%;
    padding: 10px 0 0px;
    margin-bottom: 60px;
}
    .product_li > li {
        margin: 0 0 12px 20px;
    }
        .product_li > li > a {
            position: relative;
            margin-left: 40px;
            text-decoration: none;
        }
            .product_li > li > a::before {
                content: "▶";
                position: absolute;
                top: 0;
                left: -30px;
                display: block;
                width: 20px;
                height: 20px;
                border-radius: 50%;
                border-radius: 50%;
                color: #fff;
                text-align: center;
                font-size: 12px;
                line-height: 1.3rem;
            }
.product_sec1{
    margin-bottom:3em;
}
/* h3のスタイル */
.secttl1 {
    display: flex;
    align-items: center;
    padding: .5em .6em;
    margin: 0 auto;
    font-size: 20px;
    font-weight: bold;
}
.secttl {
    /*width: 100%;*/
    display: flex;
    align-items: center;
    padding: .5em .6em;
    margin: 0 auto;
    margin-top:2.5em;
    font-size: 20px;
    font-weight: bold;
}
    .secttl::before , .secttl1:before {
        display: inline-block;
        width: 5px;
        height: 1.5em;
        margin-right: .4em;
        content: '';
    }
/* h4のスタイル */
.product_cttl {
    width: 100%;
    padding: 10px 0;
    margin-top: 0 !important;
    font-size:1.25em;
    text-align: center;
}
    /* 各sectionのスタイル */
    .sec {
        max-width: 80%;
        padding: 0 7.5%;
        /*min-width: 580px;*/
        margin: 0 auto;
    }
/* ○○システムとは～以下 */
.product_subcc {
    font-size: 18px;
    text-align: center;
    font-weight: bold;
}
/* 改行 */
.sp_br{
    display:none;
}
/* 機能紹介詳細 */
.product_fn {
    max-width:95%;
    margin:2em auto;
    padding-bottom: 20px;
    border-radius: 10px;
    overflow: hidden;
}
    .product_fn li{
        text-align:center;
    }
    .product_fn td{
        text-align:center;
    }
    /* よくあるご質問 */
    .question-box {
        position: relative;
        background: rgba(255, 255, 255, 0.8);
        border-radius: 10px;
        padding: 0 5% 5% 5%;
    }
.question-q,
.question-a {
    position: relative;
    display: flex;
    align-items: flex-start;
    align-content: center;
    margin: 0;
    padding: 1em 0em 1em 4.8em;
    font-size: 16px;
    /* color: #696969;*/
}
.question-q {
    display: flex;
    align-items: center;
    font-weight: 600;
}
.question-a + .question-q {
    border-top: 1px dotted #bdbdbd;
    padding-top: 2em;
}
.question-q::before,
.question-a::before {
    display: inline-block;
    position: absolute;
    width: 40px;
    height: 40px;
    left: 3%;
    border-radius: 50%;
    color: #fff;
    font-weight: 600;
    font-size: 1.1em;
    line-height: 40px;
    text-align: center;
}
.question-q::before {
    background: #75bbff;
    content: "Q";
}
.question-a::before {
    background: #ff8d8d;
    content: "A";
}

/* ----- 財務.ver4_renewal 開始 ---- */
/* メニューバー・h3　背景色 */
.zm {
    background: #ffefd1;
}
/* h3　左のちょんの色 */
h3.zm::before {
    background-color: #fcbb43;
}
.zm > li > a:before {
    background: #ffba7a;
}
.zm_subcc {
    color: #fa7e2c;
}
h4.zm {
    background: #ffcc80;
}
.zm_fn {
    border: 2px solid #ffcc80;
}

.zm_img {
    width: 100%;
    height: 100%;
}
.zm_txt {
    font-size: 16px;
    line-height: 1.7rem;
    padding: 0 5px;
}
.zm_mv {
    width: 100%;
    height: 300px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    /* background: url(img/product/zaim/zaimu_mv.png)center center / cover no-repeat; */
    background: url(img/product/zaim/zaimu_mv_2025.3.jpg)center center / cover no-repeat;

}
.zm_cc {
    width: 240px;
    padding: 5px;
    border: 2px solid #929292;
    text-align: center;
    margin: 20px auto;
}
.zm_sec1 {
    margin-bottom: 60px;
}

/* swiperあれこれ */
.swct {
    position: relative;
}
.slider {
    width:100%;
    min-width:100%;
    margin: 0 auto;
}
/*.zm_sec {
    width: 60%;
    min-width: 580px;
    margin: 0 auto 60px;
}*/
.zm_bnrbox {
    display: flex;
}

.zm_bnr {
    width: 40%;
    display: flex;
    align-items: center;
    grid-gap: 0.7em;
    margin: 0 auto 20px;
    padding: 1em;
    border-radius: 5px;
    background-color: #ffefd1;
    box-shadow: 1px 1px 3px #0000002d;
}

.zm_bnr_txt {
    margin: 0;
    padding: 0 0 0 .7em;
    font-weight: bold;
    border-left: 1px solid #ff8d5c;
}

.zm_verup {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: end;
    flex-wrap: wrap;
    border-radius: 15px;
    background-color: rgb(255, 250, 233);
    border: 1px solid #ff8d5caf;
}

.zm_appeal {
    width: 100%;
    margin: 0 auto 20px !important;
    padding: 16px 0;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    background: #ffc8a3;
    border-radius: 15px 15px 0 0;
}

.zm_ap_box {
    width: 22%;
    min-width: 150px;
    margin: 10px;
}

.zm_ap_ttl {
    text-align: center;
    font-weight: bold;
    margin-bottom: 3px;
}
.zm_ap_img {
    border: 1px solid #e2e2e2;
}

.zm_cttl {
    width: 100%;
    padding: 10px 0;
    margin-top: 0 !important;
    font-size: 16px;
    text-align: center;
    background: #ffcc80;
}

.zm_sec6_ct {
    position: relative;
    width: 90%;
    margin: 0 auto 30px;
}

.zm_sec6_ct::after {
    content: "";
    display: block;
    position: absolute;
    width: 80%;
    bottom: -20px;
    left: 10%;
    border-bottom: 1px dashed #c7c7c7;
}

.zm_sec6_ct:last-child::after {
    content: "";
    display: none;
}


.zm_opttl {
    display: inline-block;
    position: relative;
    padding: .3em 2em .2em 2.4em;
    margin-bottom: 10px;
    font-size: 1.1em;
    border-bottom: 3px solid #ffc8a3;
}

.zm_opttl::before {
    position: absolute;
    top: 0;
    left: 1.3em;
    transform: rotate(55deg);
    height: 11px;
    width: 12px;
    background: #ffc8a3;
    content: '';
}

.zm_opttl::after {
    position: absolute;
    transform: rotate(15deg);
    top: .6em;
    left: .6em;
    height: 8px;
    width: 8px;
    background: #ffc8a3;
    content: '';
}


#accordion {
    position: relative;
    cursor: pointer;
}

.zm_service-list {
    display: none;
    width: 80%;
    margin: 0 auto;
}


/* ----- 財務.ver4_renewal 終了 ---- */

/* ----- 総合相談管理 開始 ---- */
/* 相談共通パーツ */
.soudan {
    background: #ffcccc;
}
.soudan_table {
    border-collapse: separate;
    display:inline;
}
.soudan_table td {
    border: none;
    border-radius: 10px;
    background-color: #ff5050;
    color: #ffffff;
    text-align: center;
    font-size: 1.2em;
    display: inline-block;
    width: 12em;
    margin:0 0.25em 0.25em 0.25em;
    padding: 1em 1.5em;
}
/**  製品共通 **/
.product-list {
    margin:0 3%;
    border-radius: 5px;
    padding:0 5px;
}

/* 罫線なし */
.nbtable td {
    border: none;
}

/* 共通パーツ */
/* section1のみ */
.soudan {
    background: #ffcccc;
}
.soudan::before {
    background-color: #ff0000;
}
.soudan > li > a:before {
    background: #ff0000;
}
.soudan_subcc {
    color: #ff6666;
}
.soudan_cttl {
    background: #ff9393;
}
h4.soudan {
    background-color:#ff6666;
    color:#ffffff;
}
.soudan_fn {
    border: 2px solid #ff6666;
}
.soudan_mv {
    width: 100%;
    height: 300px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: url(img/product/soudan/soudan_mv_new.png)center center / cover no-repeat;
}
.soudan_mv_old {
    width: 100%;
    height: 300px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    background: url(img/product/soudan/soudan_mv.png)center center / cover no-repeat;
}


/* swiperあれこれ */
.slider {
    width: 60%;
    margin: 0 auto;
}
.swiper-slide{
    text-align:center;
}
.zm_bnrbox {
    display: flex;
}

.zm_bnr {
    width: 30%;
    display: flex;
    align-items: center;
    grid-gap: 0.7em;
    margin: 0 auto 20px;
    padding: 1em;
    border-radius: 5px;
    background-color: #ffefd1;
    box-shadow: 1px 1px 3px #0000002d;
}

.zm_bnr_txt {
    margin: 0;
    padding: 0 0 0 .7em;
    font-weight: bold;
    border-left: 1px solid #ff8d5c;
}

.zm_verup {
    width: 100%;
    margin: 0 auto;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: end;
    flex-wrap: wrap;
    border-radius: 15px;
    background-color: rgb(255, 250, 233);
    border: 1px solid #ff8d5caf;
}

.zm_appeal {
    width: 100%;
    margin: 0 auto 20px !important;
    padding: 16px 0;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    background: #ffc8a3;
    border-radius: 15px 15px 0 0;
}


.zm_ap_box {
    width: 22%;
    min-width: 150px;
    margin: 10px;
}

.zm_ap_ttl {
    text-align: center;
    font-weight: bold;
    margin-bottom: 3px;
}

/* .zm_ap_pic {} */

.zm_ap_img {
    border: 1px solid #e2e2e2;
}

/*.zm_sec5_ct {
    width: 100%;
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-radius: 10px;
    overflow: hidden;
    border: 2px solid #ffcc80;
}*/

.zm_cttl {
    width: 100%;
    padding: 10px 0;
    margin-top: 0 !important;
    font-size: 16px;
    text-align: center;
    background: #ffcc80;
}

.zm_sec6_ct {
    position: relative;
    width: 90%;
    margin: 0 auto 30px;
}

    .zm_sec6_ct::after {
        content: "";
        display: block;
        position: absolute;
        width: 80%;
        bottom: -20px;
        left: 10%;
        border-bottom: 1px dashed #c7c7c7;
    }

    .zm_sec6_ct:last-child::after {
        content: "";
        display: none;
    }


.zm_opttl {
    display: inline-block;
    position: relative;
    padding: .3em 2em .2em 2.4em;
    margin-bottom: 10px;
    font-size: 1.1em;
    border-bottom: 3px solid #ffc8a3;
}

    .zm_opttl::before {
        position: absolute;
        top: 0;
        left: 1.3em;
        transform: rotate(55deg);
        height: 11px;
        width: 12px;
        background: #ffc8a3;
        content: '';
    }

    .zm_opttl::after {
        position: absolute;
        transform: rotate(15deg);
        top: .6em;
        left: .6em;
        height: 8px;
        width: 8px;
        background: #ffc8a3;
        content: '';
    }

.question-box {
    position: relative;
    background: rgba(255, 255, 255, 0.8);
    border-radius: 10px;
    padding: 0 5% 5% 5%;
}
#accordion {
    position: relative;
    cursor: pointer;
}

.zm_service-list {
    display: none;
    width: 80%;
    margin: 0 auto;
}
/* ----- 相談記録 終了 ---- */




/**** 経営分析　開始 ****/
#keiei h3 {
    color: #ff9900;
}

#keiei h3 span {
    color: #ffffff;
    background: #ff9900;
    background-color: #ff9900;
    border: 1px solid #ff9900;
}

#keiei table td {
    border: none;
}

#keiei table td img {
    max-width: 100%;
}

.keiei-color {
    color: #ff9900;
}

#keiei>li {
    border: 5px double #ff9900;
}

#keiei .fa-lightbulb {
    color: #ff9900;
    font-size: 3vh;
    padding-right: 0.3em;
}

#keiei .support-title {
    border: 1px solid #ff9900;
    background-color: #ff9900;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

#keiei .product-support dt {
    background-color: #ff9900;
    border-style: none;
}

#keiei dd {
    border-color: #ff9900;
}

.keiei1 {
    vertical-align: top;
    text-align: center;
    width: 20%;
}

/**** 経営分析　終わり ****/


/**** 給与　開始 ****/
.pay-color {
    color: #203864;
}

#pay h3 {
    color: #203864;
}

#pay h3 span {
    color: #ffffff;
    background: #4472c4;
    background-color: #4472c4;
    border: 1px solid #4472c4;
}

#pay>li {
    border: 5px double #4472c4;
}

#pay .fa-lightbulb {
    color: #4472c4;
    font-size: 3vh;
    padding-right: 0.3em;
}

#pay .support-title {
    border: 1px solid #4472c4;
    background-color: #4472c4;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

#pay .product-support dt {
    border: 1px solid #4472c4;
    background-color: #4472c4;
    border-radius: 10px 10px 0 0;
    padding: 0;
    color: #ffffff !important;
    margin-left: 0.5em;
    text-align: center;
    width: 200px;
}

#pay .product-support dd {
    border: 4px solid #4472c4;
    border-radius: 10px;
    margin-top: -0.1em;
    margin-left: 0px;
    margin-bottom: 1em;
    padding: 0.5em;
}

/**** 給与　終わり ****/


/**** 介護保険　開始 ****/
.cr-color {
    color: #203864;
}
#cr h3 {
    color: #0989b1;
}
#cr h3 span {
    color: #ffffff;
    background: #0989b1;
    background-color: #0989b1;
    border: 1px solid #0989b1;
}
#cr>li {
    border: 5px double #0989b1;
}
#cr .fa-lightbulb {
    color: #0989b1;
    font-size: 3vh;
    padding-right: 0.3em;
}
#cr .support-title {
    border: 1px solid #0989b1;
    background-color: #0989b1;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    /* margin-left: auto; */
    margin-bottom: 1em;
}
#cr .product-support dt {
    border: 1px solid #0989b1;
    background-color: #0989b1;
    border-radius: 10px 10px 0 0;
    padding: 0;
    color: #ffffff !important;
    margin-left: 0.5em;
    text-align: center;
    width: 200px;
}
#cr .product-support dd {
    border: 4px solid #0989b1;
    border-radius: 10px;
    margin-top: -0.1em;
    margin-left: 0px;
    margin-bottom: 1em;
    padding: 0.5em;
}
/* 221128追記 */
h2:first-letter {
    font-size: 1em;
    color: #696969;
}
.cr_secttl {
    align-items: center;
    padding: .5em .6em;
    margin: 40px auto !important;
    font-size: 24px;
    font-weight: bold;
    text-align: center;
    border: none !important;
}
.cr__main {
    background: #fefeff;
}
.cr__top-mv {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 300px;
    display: flex;
    background: url(img/product/cr/mv.png) center center / cover no-repeat;
}
.cr__top-ul {
    position: absolute;
    bottom: 0;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    width: 100%;
    padding: 0;
    margin: 0;
    background: #fffcfc;
    border-top: 2px solid rgb(104, 130, 161, 0.7);
    border-bottom: 2px solid rgb(104, 130, 161, 0.7);
}
.cr__top-link {
    position: relative;
    display: inline-block;
    padding: 20px 40px 20px 60px;
    font-weight: bold;
    text-decoration: none;
    transition: .4s;
    color: #696969;
}
.cr__top-link:hover {
    background: #dfdfdf;
}
.cr__top-link::before {
    font-family: "Font Awesome 5 Free";
    content: "\f138";
    position: absolute;
    font-weight: 900;
    font-size: 25px;
    top: 17px;
    left: 10px;
    transform: rotate(90deg);
    color: #aabde6;
}
.cr__background {
    position: relative;
    background: #ecf2ff;
    padding-bottom: 200px;
}
.cr__problems {
    padding: 30px;
    padding-bottom: 60px;
}
.cr__problems-ttl {
    text-align: center;
    font-size: 30px;
    letter-spacing: 0.08rem;
    font-weight: bold;
    color: #fff;
}
.cr__problems-container {
    width: 70%;
    margin: 0 auto 40px;
    display: flex;
    justify-content: space-around;
    flex-wrap: wrap;
}
.cr__problems-txt {
    margin: 0 auto;
    font-weight: bold;
    color: #696969;
}
.cr_slide {
    width: 30%;
}
.cr__solutions {
    position: absolute;
    z-index: 2;
    bottom: 0;
    left: 50%;
    transform: translate(-50%, 50%);
    width: 70%;
    margin: 0 auto;
    background: #fffdfd;
    padding: 2% 0;
    border-radius: 30px;
    box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.3);
}
.cr__solutions-container {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    margin: 0 auto 40px;
}
.cr__problems-box {
    position: relative;
    width: 30%;
    margin: 40px 0 0;
    padding: 60px 20px 20px;
    background: #fffcfc;
    border-radius: 10px;
    text-align: center;
    box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.2);
}
.cr__problems-icon {
    position: absolute;
    top: -20%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 60px;
    height: 60px;
    padding: 10px;
    background: #fffbfb;
    border-radius: 50%;
    border: 3px solid rgb(141, 162, 184);
}
.cr__problems-img {
    display: block;
    width: 100%;
}
.cr__solutions-ttl {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    border: none;
    font-size: 20px;
}
.cr__solutions-ttl::before,
.cr__solutions-ttl::after {
    content: "";
    width: 3px;
    height: 40px;
    background: #9b9b9b;
    border-radius: 3px;
}
.cr__solutions-ttl::before {
    transform: rotate(-35deg);
    margin-right: 30px;
}
.cr__solutions-ttl::after {
    transform: rotate(35deg);
    margin-left: 30px;
}
.cr__solutions-pic {
    width: 15%;
}
.cr__solutions-img {
    width: 100%;
}
.cr__solutions-box {
    width: 65%;
}
.cr__solutions-txt {
    margin-left: 30px;
    line-height: 1.8rem;
}
.cr__span {
    padding: 5px 3px;
    font-weight: bold;
    background: #fff6b0;
}
.cr__intro {
    width: 60%;
    padding-top: 250px;
    margin: 0 auto 60px;
}
.cr__intro-container {
    width: 70%;
    margin: 0 auto;
}
.cr__intro-label {
    position: relative;
    font-weight: bold;
    font-size: 18px;
    padding: 10px 30px;
    margin: 0;
    background: #dadada;
}
.cr__intro-more {
    padding: 20px;
    margin: 0 0 20px 0;
    background: #f0fff0;
}
.cr__reason {
    width: 100%;
    margin: 0 auto;
    padding: 40px 0;
    background: url(img/product/cr/img11.png) no-repeat top center;
    background-size: 130%;
}
.cr__reason-container {
    width: 60%;
    min-width: 790px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.cr__reason-box {
    width: 42%;
    padding: 3%;
    padding-bottom: 1%;
    margin-bottom: 40px;
    border-radius: 40px;
    background: #fffefe;
    box-shadow: 2px 2px 5px #afafaf;
}
.cr__reason-boxttl {
    font-size: 22px;
    font-weight: 600;
    margin: 0 0 20px 0;
    border-bottom: 1px solid #098ab1;
}
.cr__question {
    padding: 40px 0 80px;
    background: linear-gradient(60deg, #f9ffff, #bfd2eb);
}
.cr__question-container {
    width: 50%;
    min-width: 760px;
    padding: 50px auto;
    margin: 0 auto;
}
.cr__question-ttl {
    text-align: center;
    font-size: 30px;
    font-weight: 600;
    padding: 20px;
    margin-top: 0;
}
.cr__question-box {
    background: rgba(255, 255, 255, 0.8);
    box-shadow: 2px 2px 2px #afafaf;
    border-radius: 10px;
    padding: 5% 5% 3%;
}
.cr__question-q,
.cr__question-a {
    position: relative;
    display: flex;
    align-items: flex-end;
    align-content: center;
    margin: 0 0 1em;
    padding-left: 50px;
    color: #696969;
    vertical-align: bottom;
}
.cr__question-q {
    font-weight: 600;
}

.cr__question-a+.cr__question-q {
    border-top: 1px dotted #696969;
    padding-top: 30px;
}

.cr__question-q::before,
.cr__question-a::before {
    display: inline-block;
    position: absolute;
    width: 36px;
    height: 36px;
    left: 0;
    border-radius: 50%;
    color: #fff;
    font-weight: 600;
    line-height: 2;
    text-align: center;
}

.cr__question-q::before {
    background: #75bbff;
    content: "Q";
}

.cr__question-a::before {
    background: #ff8d8d;
    content: "A";
    top: 5px;
}

#accordion {
    position: relative;
    cursor: pointer;
}

#accordion::after {
    content: "+";
    position: absolute;
    top: 0.3rem;
    right: 30px;
    font-size: 20px;
    font-weight: bold;
}

.cr__service-list {
    display: none;
    width: 80%;
    margin: 0 auto;
}

.cr__flow {
    position: relative;
    z-index: 3;
    width: 55%;
    margin: 0 auto 80px;
    padding: 5% 0;
    min-width: 760px;
}

.cr__flow::after {
    content: "";
    position: absolute;
    z-index: -1;
    bottom: -150px;
    left: 47.5%;
    background: #fffaf7;
    width: 180px;
    height: 180px;
    transform: rotate(45deg) translateX(-50%);
}

.cr__flow-dl {
    display: flex;
    flex-wrap: wrap;
    margin: 0 auto;
    min-width: 770px;
}

.cr__flow-dt,
.cr__flow-dd {
    padding: 30px 20px;
    font-size: 16px;
    background: #e4ebf0;
    margin: 0 0 40px 0;
}

.cr__flow-dt {
    position: relative;
    width: 29%;
    font-weight: bold;
    letter-spacing: 0.04rem;
    border-radius: 15px 0 0 15px;
}

.cr__flow-number {
    position: absolute;
    z-index: 3;
    top: -40px;
    left: -10px;
    font-size: 60px;
    font-style: italic;
    font-weight: normal;
    color: #a8acad;
}

.cr__flow-dt::before {
    position: absolute;
    content: "";
    z-index: 2;
    right: 0;
    top: 20%;
    height: 60%;
    border-right: 1px dashed #929292;
}

.cr__flow-dd {
    width: 60%;
    border-radius: 0 15px 15px 0;
}


.cr__contact {
    width: 100%;
    padding: 80px 0 50px;
    background: #d4edf1;
    color: #696969;
    text-align: center;
}

.cr__contact-ttl {
    font-size: 24px;
    text-align: center;
    font-weight: bold;
}

.cr__contact-link {
    margin: 0 auto;
    display: inline-block;
    text-align: center;
    padding: 20px 40px;
    background: #75acbd;
    color: #fff;
    box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.2);
    border-radius: 40px;
}

.cr__contact-link:hover {
    background: #5297ac;
    transform: translateY(1px);
}

.cr__contact-tell {
    font-size: 24px;
    text-align: center;
}
/* 231227ケアプラン連携　表追加 */
.careplantable{
    max-width:80%;
    font-size:0.85em;
    margin:0 auto;
}
.careplantable th {
    background-color: #dbebc4;
}
.careplantable th:first-of-type {
    text-align: left;
}
.careplantable th, .careplantable td {
    text-align: center;
    color: #000000;
}
.syasen {
    background-image: linear-gradient(to right top, transparent calc(50% - 0.5px), #999 50%, #999 calc(50% + 0.5px), transparent calc(50% + 1px));
    vertical-align:bottom;
    padding-bottom:0.15em;
}
.crsp_br{
    display:none;
}
@media screen and (max-width: 1080px) {
/* 231227ケアプラン連携　表追加 */
    .careplantable th{
        font-size:50%;
        padding:0.75em;
    }
    .careplantable img{
        min-width:50%;
    }
        .crsp_br {
            display: block;
        }
}
/**** 介護保険　終わり ****/

/**** 総合支援　開始 ****/
.aid-color {
    color: #2A4F1D;
}

#aid h3 {
    color: #92dd50;
}

#aid h3 span {
    color: #ffffff;
    background: #92dd50;
    background-color: #92dd50;
    border: 1px solid #92dd50;
}

#aid>li {
    border: 5px double #92dd50;
}

#aid .fa-lightbulb {
    color: #92dd50;
    font-size: 3vh;
    padding-right: 0.3em;
}

#aid .support-title {
    border: 1px solid #92dd50;
    background-color: #92dd50;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

#aid .product-support dt {
    border: 1px solid #92dd50;
    background-color: #92dd50;
    border-radius: 10px 10px 0 0;
    padding: 0;
    color: #ffffff !important;
    margin-left: 0.5em;
    text-align: center;
    width: 200px;
}

#aid .product-support dd {
    border: 4px solid #92dd50;
    border-radius: 10px;
    margin-top: -0.1em;
    margin-left: 0px;
    margin-bottom: 1em;
    padding: 0.5em;
}

/*.aid_service {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}*/
.aid_service td {
    border: 1px solid #808080;
}

/* 221215追記 */

.aid__top-mv {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background: url(img/product/aid/aid_mv.png) center center / cover;
    height: 860px;
}

.aid_bg-color {
    background: #e4f1d6;
}

.aid_bd-color {
    border-color: #a1bd8c;
}

/**** 総合支援　終わり ****/

/**** 預り金　開始 ****/
.dp-color {
    color: #7030a0;
}

#dp h3 {
    color: #7030a0;
}

#dp h3 span {
    color: #ffffff;
    background: #7030a0;
    background-color: #7030a0;
    border: 1px solid #7030a0;
}

#dp>li {
    border: 5px double #7030a0;
}

#dp .fa-lightbulb {
    color: #7030a0;
    font-size: 3vh;
    padding-right: 0.3em;
}

#dp .support-title {
    border: 1px solid #7030a0;
    background-color: #7030a0;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

#dp .product-support dt {
    border: 1px solid #7030a0;
    background-color: #7030a0;
    border-radius: 10px 10px 0 0;
    padding: 0;
    color: #ffffff !important;
    margin-left: 0.5em;
    text-align: center;
    width: 200px;
}

#dp .product-support dd {
    border: 4px solid #7030a0;
    border-radius: 10px;
    margin-top: -0.1em;
    margin-left: 0px;
    margin-bottom: 1em;
    padding: 0.5em;
}

/**** 預り金　終わり ****/


/****　シルバー人材　開始 ****/

.silver-color {
    color: #32cd32;
}

#silver h3 {
    color: #32cd32;
}

#silver h3 span {
    color: #ffffff;
    background: #32cd32;
    background-color: #32cd32;
    border: 1px solid #32cd32;
}

#silver>li {
    border: 5px double #32cd32;
}

#silver .fa-lightbulb {
    color: #32cd32;
    font-size: 3vh;
    padding-right: 0.3em;
}

#silver .support-title {
    border: 1px solid #32cd32;
    background-color: #32cd32;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

#silver .product-support dt {
    border: 1px solid #32cd32;
    background-color: #32cd32;
    border-radius: 10px 10px 0 0;
    padding: 0;
    color: #ffffff !important;
    margin-left: 0.5em;
    text-align: center;
    width: 200px;
}

#silver .product-support dd {
    border: 4px solid #32cd32;
    border-radius: 10px;
    margin-top: -0.1em;
    margin-left: 0px;
    margin-bottom: 1em;
    padding: 0.5em;
}

/**** シルバー人材　終わり ****/


/****　日誌　開始 ****/
.self-color {
    color: #00bfff;
}

#self h3 {
    color: #00bfff;
}

#self h3 span {
    color: #ffffff;
    background: #00bfff;
    background-color: #00bfff;
    border: 1px solid #00bfff;
}

#self>li {
    border: 5px double #00bfff;
}

#self .fa-lightbulb {
    color: #00bfff;
    font-size: 3vh;
    padding-right: 0.3em;
}

#self .support-title {
    border: 1px solid #00bfff;
    background-color: #00bfff;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

#self .product-support dt {
    border: 1px solid #00bfff;
    background-color: #00bfff;
    border-radius: 10px 10px 0 0;
    padding: 0;
    color: #ffffff !important;
    margin-left: 0.5em;
    text-align: center;
    width: 200px;
}

#self .product-support dd {
    border: 4px solid #00bfff;
    border-radius: 10px;
    margin-top: -0.1em;
    margin-left: 0px;
    margin-bottom: 1em;
    padding: 0.5em;
}

/**** 日誌　終わり ****/

/****  Web日誌　開始 ****/

/*.productbox > h2 {
    color: #ffffff;
    background-color: #5cbce4;
    padding: 0.5em 2em;
    margin-top: 2em;
    border-radius: 10px;
    display: inline-block;
    width: 12em;
}*/
h2.selfsection {
    color: #696969;
    /*background-color: #5cbce4;*/
    padding: 0.5em 1em;
    margin-top: 2em;
    /*border-radius: 10px;*/
    border-bottom: 3px solid #5cbce4;
    display: inline-block;
    width: 12em;
}

/*.productbox>h2:first-letter {
    font-size: 1em;
    color: #ffffff;
}*/
h2.selfsection:first-letter {
    font-size: 1em;
    color: #696969;
}

li {
    list-style: none;
}

/* h2がきらっとするよ */
.shine {
    border: 2px solid transparent;
    position: relative;
    overflow: hidden;
}

/* 光の疑似要素 */
.shine::before {
    content: "";
    /*animation: shine 3s cubic-bezier(0.25, 0, 0.25, 1) infinite;*/
    animation: shine 3s ease-in-out infinite;
    background-color: #fff;
    width: 140%;
    height: 100%;
    transform: skewX(-45deg);
    top: 0;
    left: -160%;
    opacity: 0.5;
    position: absolute;
}

/* 光の動き */
@keyframes shine {
    0% {
        left: -160%;
        opacity: 0;
    }

    70% {
        left: -160%;
        opacity: 0.5;
    }

    71% {
        left: -160%;
        opacity: 1;
    }

    100% {
        left: -20%;
        opacity: 0;
    }
}

.productbox > h3 {
    font-weight: normal;
    font-size: 1.5em;
    margin: 0 auto;
    margin-top: 2.5em;
}

.productbox > h3 > img {
    vertical-align: middle;
}

.productbox {
    display: block;
    text-align: center;
}

.productbox > table {
    margin: 0 auto;
    border: none;
}

.productbox > table td {
    border: none;
}

.inner-box > table td {
    border: none;
}

.productbox > table {
    display: block;
    margin: 0 auto;
    max-width: 75%;
    width: 25em;
}

.point6_table tr td {
    text-align: left;
}

.point6_table tr td:first-of-type:before {
    font-family: "Font Awesome 5 Free";
    content: '\f0eb';
    font-weight: 900;
    padding-right: 0.5em;
    color: #ffd700;
}

/****** productboxおわり ******/
/****** top 開始 ******/
h1 {
    font-size: 2.75rem;
}

h1:first-letter {
    color: #4fadf3;
}

#top ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

#top li {
    position: relative;
    padding: 0.5em 0.5em 0.5em 1.5em;
    line-height: 0.75em;
    margin-right: 1.5em;
    font-size: 1.1em;
}

#top li:before {
    font-family: "Font Awesome 5 Free";
    content: "\f138";
    font-weight: 900;
    position: absolute;
    font-size: 1em;
    left: 0.25em;
    top: 0.5em;
    color: #4fadf3;
}

#top li a {
    position: relative;
    text-decoration: none;
    color: #000000;
}

#top li a:after {
    position: absolute;
    left: 0;
    content: '';
    width: 100%;
    height: 1px;
    background: #4fadf3;
    bottom: -0.5px;
    transform: scale(0, 1);
    transform-origin: left top;
    transition: 0.5s;
}

#top li a:hover:after {
    transform: scale(1, 1);
}

/****** top おわり ******/


/****** first-box ******/
/* システム画像部分 */
.details {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    list-style: none;
    max-width: 800px;
    margin: 1em auto;
    padding: 0;
    text-align: center;
}

.details li {
    flex-basis: calc(33.333% - 8px);
    position: relative;
    max-width: 250px;
}

@media (max-width: 720px) {
    .details li {
        flex-basis: calc(50% - 6px);
    }

    .details li:nth-child(n+3) {
        margin-top: 12px;
    }
}

@media (max-width: 520px) {
    .details {
        flex-direction: column;
        align-items: center;
    }

    .details li {
        flex-basis: auto;
    }

    .details li:nth-child(n+2) {
        margin-top: 12px;
    }
}

.details .image {
    margin: 0;
}

.details .image img {
    max-width: 100%;
    height: auto;
    vertical-align: middle;
}

.details .text {
    display: grid;
    grid-template-rows: 1fr auto 1fr;
    position: absolute;
    inset: 0;
    margin: 0;
    padding: 16px 24px;
    color: white;
    text-align: left;
    background: rgba(0, 159, 227, 0.9);
}

.details .text dt {
    justify-self: flex-start;
    align-self: flex-end;
}

.details .text dd {
    margin: .5em 0 0;
    font-size: .8em;
    line-break: strict;
    overflow-wrap: break-word;
}

.details .text .price {
    justify-self: flex-end;
}

/* :::::: type1 :::::: */
.type1 {
    overflow: hidden;
}

.type1 .text {
    transition: opacity .6s, transform .6s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.type1:not(:hover) .text {
    opacity: 0;
    transform: translateY(100%);
}


/****** first-box おわり ******/

/****** second-box ******/
.number_img {
    vertical-align: middle;
}

p.fukidashi1,
p.fukidashi2 {
    position: relative;
    padding: 1rem;
    color: #ffffff;
    border-radius: 50%;
    background: #2e96e6;
    width: 120px;
    height: 120px;
    clear: both;
    line-height: 120px;
}

p.fukidashi1:after {
    position: absolute;
    top: 4em;
    right: -3.5em;
    width: 0;
    height: 0;
    content: '';
    border-width: 1em 2em 1em 2em;
    border-style: solid;
    border-color: transparent transparent transparent #2e96e6;
}

p.fukidashi2:after {
    position: absolute;
    top: 4em;
    right: 9em;
    width: 0;
    height: 0;
    content: '';
    border-width: 1em 2em 1em 2em;
    border-style: solid;
    border-color: transparent #2e96e6 transparent transparent;
    /*clear: both;*/
}

/* ふわっと出てくる */
.sa {
    opacity: 0;
    transition: all .5s ease;
    border: none;
}

.sa-up {
    transform: translate(0, 15px);
    transition: ease 1s;
}

.sa.show {
    opacity: 1;
    transform: none;
}

/* 手が上下に動く */
.hand {
    position: absolute;
    top: 130px;
    animation-name: hand;
    animation-duration: 3.5s;
    animation-iteration-count: infinite;
    animation-fill-mode: forwards;
    z-index: 999;
}

@keyframes hand {
    0% {
        transform: translateY(-30px);
    }

    50% {
        transform: translateY(0px);
    }

    100% {
        transform: translateY(30px);
    }
}

/* 豊富な記録 */
.line-l {
    overflow: hidden;
    position: relative;
}

.line-l:before {
    animation: line-l 2.5s cubic-bezier(.4, 0, .2, 1) infinite;
    background: #fff;
    bottom: 0;
    content: '';
    left: 0;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 1;
}

@keyframes line-l {
    100% {
        transform: translateX(-100%);
    }
}

.line-r {
    overflow: hidden;
    position: relative;
}

.line-r:before {
    animation: line-r 2.5s cubic-bezier(.4, 0, .2, 1) infinite;
    background: #fff;
    bottom: 0;
    content: '';
    left: 0;
    pointer-events: none;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 1;
}

@keyframes line-r {
    100% {
        transform: translateX(100%);
    }
}


/****** second-box おわり ******/

/****** fourth-box ******/
/*#fourth-box {
    max-width: 55%;
    margin: 0 auto;
}*/
dl.cp_qa {
    width: 70%;
    display: block;
    margin: 0 auto;
}

.cp_qa *,
.cp_qa *:after,
.cp_qa *:before {
    font-family: 'FontAwesome', sans-serif;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.cp_qa dt,
.cp_qa dd {
    position: relative;
    padding: 0.5em;
    box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.2);
    border-radius: 0.3em;
    text-align: left;
    /*    max-width:70%;
    display:block;
    margin:0 auto;*/
}

.cp_qa dt {
    margin: 0 3em 1em 3em;
    background: #00B66E;
    color: #FFF;
    font-weight: bold;
}

.cp_qa dd {
    margin: 0 3em 3em 3em;
    background: #cbf7cb;
}

/* 吹き出し▶︎ */
.cp_qa dt::before,
.cp_qa dd::before {
    position: absolute;
    z-index: 99;
    top: 0.5em;
    display: inline-block;
    width: 0;
    height: 0;
    content: '';
    border-style: solid;
}

/* 質問吹き出し▶︎ */
.cp_qa dt::before {
    left: -0.5em;
    border-width: 5px 8.7px 5px 0;
    border-color: transparent #00B66E transparent transparent;
}

/* 答え吹き出し▶︎ */
.cp_qa dd::before {
    right: -0.5em;
    border-width: 5px 0 5px 8.7px;
    border-color: transparent transparent transparent #cbf7cb;
}

/* ?!アイコン */
.cp_qa dt::after,
.cp_qa dd::after {
    font-size: 1.2em;
    position: absolute;
    top: 0;
    color: #ffffff;
    border-radius: 50%;
    display: inline-block;
    width: 1.5em;
    height: 1.5em;
    line-height: 1.2em;
}

/* ?アイコン */
.cp_qa dt::after {
    left: -2.75em;
    margin: -5px 0.2em 0 0;
    padding: 0em 0em;
    content: url(img/product/q.ico);
    /*background: #f57c00;*/
}

/* !アイコン */
.cp_qa dd::after {
    right: -0.5em;
    margin: 0 0 0 0.5em;
    padding: 0.2em 0.55em;
    content: url(img/product/a.ico);
}


/****** third-box おわり ******/

/****** fifth-box ******/
#fifth-box ul {
    display: flex;
    justify-content: center;
}

#fifth-box li {
    padding: 0 1.5em 2em 1.5em;
    margin-right: 1.5em;
    font-size: 1.3em;
}

#fifth-box li a {
    text-decoration: none;
    color: #000000;
}

/*丸がボタンに変形する*/
.btntransform {
    /*丸の基点とするためrelativeを指定*/
    position: relative;
    /*ボタンの形状*/
    display: inline-block;
    padding: 0 0 0 15px;
    line-height: 50px;
    outline: none;
    z-index: 1;
}

/* 丸が動く */
.btntransform::before {
    content: '';
    /*絶対配置で丸の位置を決める*/
    position: absolute;
    left: 0;
    z-index: -1;
    /*丸の形状*/
    width: 50px;
    height: 50px;
    border-radius: 25px;
    /*アニメーションの指定*/
    transition: .3s ease-out;
}

.link1:before {
    background: #0989b1;
}

.link2:before {
    background: #92dd50;
}

/*hoverした際の形状*/
.btntransform:hover::before {
    width: 120%;
}

/* 矢印の形状 */
.btntransform::after {
    position: absolute;
    content: '';
    top: 1em;
    right: -15px;
    width: 5px;
    height: 5px;
    border-top: 1px solid #000;
    border-right: 1px solid #000;
    transform: rotate(45deg);
}

/****** fifth-box おわり ******/

/****  Web日誌おわり ****/

/**** ????????? ****/
.ass-color {
    color: #87cefa;
}

#ass h3 {
    color: #87cefa;
}

#ass h3 span {
    color: #ffffff;
    background: #87cefa;
    background-color: #87cefa;
    border: 1px solid #87cefa;
}

#ass>li {
    border: 5px double #87cefa;
}

#ass .fa-lightbulb {
    color: #87cefa;
    font-size: 3vh;
    padding-right: 0.3em;
}

#ass .support-title {
    border: 1px solid #87cefa;
    background-color: #87cefa;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

#ass .product-support dt {
    border: 1px solid #87cefa;
    background-color: #87cefa;
    border-radius: 10px 10px 0 0;
    padding: 0;
    color: #ffffff !important;
    margin-left: 0.5em;
    text-align: center;
    width: 200px;
}

#ass .product-support dd {
    border: 4px solid #87cefa;
    border-radius: 10px;
    margin-top: -0.1em;
    margin-left: 0px;
    margin-bottom: 1em;
    padding: 0.5em;
}

/**** ????????? ****/


/**** ??????? ****/
.charity-color {
    color: #ff69b4;
}

#charity h3 {
    color: #ff69b4;
}

#charity h3 span {
    color: #ffffff;
    background: #ff69b4;
    background-color: #ff69b4;
    border: 1px solid #ff69b4;
}

#charity>li {
    border: 5px double #ff69b4;
}

#charity .fa-lightbulb {
    color: #ff69b4;
    font-size: 3vh;
    padding-right: 0.3em;
}

#charity .support-title {
    border: 1px solid #ff69b4;
    background-color: #ff69b4;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

#charity .product-support dt {
    border: 1px solid #ff69b4;
    background-color: #ff69b4;
    border-radius: 10px 10px 0 0;
    padding: 0;
    color: #ffffff !important;
    margin-left: 0.5em;
    text-align: center;
    width: 200px;
}

#charity .product-support dd {
    border: 4px solid #ff69b4;
    border-radius: 10px;
    margin-top: -0.1em;
    margin-left: 0px;
    margin-bottom: 1em;
    padding: 0.5em;
}

/**** ??????? ****/

/**** ??????????????? ****/
.hp-color {
    color: #ff7f50;
}

#hp h3 {
    color: #ff7f50;
}

#hp h3 span {
    color: #ffffff;
    background: #ff7f50;
    background-color: #ff7f50;
    border: 1px solid #ff7f50;
}

#hp>li {
    border: 5px double #ff7f50;
}

#hp .fa-lightbulb {
    color: #ff7f50;
    font-size: 3vh;
    padding-right: 0.3em;
}

#hp .support-title {
    border: 1px solid #ff7f50;
    background-color: #ff7f50;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

#hp .product-support dt {
    border: 1px solid #ff7f50;
    background-color: #ff7f50;
    border-radius: 10px 10px 0 0;
    padding: 0;
    color: #ffffff !important;
    margin-left: 0.5em;
    text-align: center;
    width: 200px;
}

#hp .product-support dd {
    border: 4px solid #ff7f50;
    border-radius: 10px;
    margin-top: -0.1em;
    margin-left: 0px;
    margin-bottom: 1em;
    padding: 0.5em;
}

/**** ??????????????? ****/


/**** ??????????????? ****/
.ftp-color {
    color: #7f7f7f;
}

#ftp h3 {
    color: #7f7f7f;
}

#ftp h3 span {
    color: #ffffff;
    background: #7f7f7f;
    background-color: #7f7f7f;
    border: 1px solid #7f7f7f;
}

#ftp>li {
    border: 5px double #7f7f7f;
}

#ftp .fa-lightbulb {
    color: #7f7f7f;
    font-size: 3vh;
    padding-right: 0.3em;
}

#ftp .support-title {
    border: 1px solid #7f7f7f;
    background-color: #7f7f7f;
    color: #ffffff;
    font-weight: bold;
    text-align: center;
    margin-left: auto;
    margin-bottom: 1em;
}

#ftp .product-support dt {
    border: 1px solid #7f7f7f;
    background-color: #7f7f7f;
    border-radius: 10px 10px 0 0;
    padding: 0;
    color: #ffffff !important;
    margin-left: 0.5em;
    text-align: center;
    width: 200px;
}

#ftp .product-support dd {
    border: 4px solid #7f7f7f;
    border-radius: 10px;
    margin-top: -0.1em;
    margin-left: 0px;
    margin-bottom: 1em;
    padding: 0.5em;
}

/**** ??????????????? ****/


/****** ??????????? ******/


/****** ??????? ******/
#product_detail {
    width: 100%;
    min-width: 100%;
    color:#494949;
}
#product_detail img {    
    max-width: 100%;
    /*min-width:80%;*/
}

div#product_detail h3 {
    border: none;
    font-size: 140%;
    margin-bottom: 0;
}

div#product_detail h3 span {
    border-radius: 40px;
    padding-left: 1em;
    padding-right: 1em;
    text-align: center;
    clear: both;
}

/*???????????*/
.explanation {
    text-align: center;
    font-size: 110% !important;
    font-weight: bold;
}

/*???????????*/

/*?????*/
.product-img {
    list-style: none;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

.product-img li {
    margin: 0 0.2em 1em 0.5em;
    min-width: 10%;
}

/*???*/
.product-block {
    clear: both;
    padding-bottom: 3em;
    display: flex;
    justify-content: center;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    list-style: none;
    width: 85%;
    margin: 0 auto;
}

.product-block li {
    width: 150vh;
    max-width: 80%;
    flex-grow: 1;
    margin: 2.5vh;
    padding: 0.8em;
    /*border:5px double #cc3399;*/
}

.box-last {
    visibility: hidden;
}

.product-table td {
    border: none;
    padding: 1em;
    font-size: 1.2em;
}

.product-table td:first-child {
    width: 1em;
    border: none;
    padding-right: 0;
}

/* サポート体制 */
.product-support {
    border-collapse: separate;
    margin: 0;
    padding: 0;
}

.product-support td {
    border: 1px solid #cc3399;
    border-radius: 10px;
}

.product-support td:first-child {
    display: block;
    margin: auto;
    border: none;
    color: #ffffff;
    text-align: center;
}

.product-support td>img {
    background-color: #cc3399;
    border-radius: 50%;
}

.product-support dt {
    border: 1px solid #cc3399;
    background-color: #cc3399;
    border-radius: 10px 10px 0 0;
    padding: 0;
    color: #ffffff !important;
    margin-left: 0.5em;
    text-align: center;
    width: 150px;
}

.product-support dd {
    border: 4px solid #cc3399;
    border-radius: 10px;
    margin-top: -0.1em;
    margin-left: 0px;
    margin-bottom: 1em;
    padding: 0.5em;
}

dd.product-support-icon {
    float: left;
    border: 1px solid #cc3399;
    border-radius: 50%;
    position: absolute;
    background-color: #cc3399;
    margin-left: 0;
    width: 3vw;
}

.visible {
    display: none;
}

/* 製品ページQ&A */
ul.flow_list {
    display: block;
    list-style: none;
    padding: 0;
    text-align: center;
}

ul.flow_list li {
    border-radius: 10px;
    margin-bottom: 35px;
    padding: 4px 10px;
    position: relative;
    font-size: 110%;
    color: #FFF;
    font-weight: bold;
    width: 90%;
    margin-left: auto;
    margin-right: auto;
}

ul.flow_list li:nth-child(n+1):nth-child(-n+3) {
    background-color: #5496f3;
    border: 5px solid #5496f3;
}

ul.flow_list li:nth-child(n+4):nth-child(-n+5) {
    background-color: #E3C700;
    border: 5px solid #E3C700;
}

ul.flow_list li:nth-child(n+6):nth-child(-n+8) {
    background-color: #00B66E;
    border: 5px solid #00B66E;
}

ul.flow_list li::after {
    bottom: -34px;
    color: #ccc;
    content: "▼";
    font-size: 24px !important;
    left: 48%;
    position: absolute;
}

ul.flow_list li.last::after {
    /*??????? */
    content: "";
}

ul.flow_list li h4::first-letter {
    /*1???????*/
    font-family: garamond, times;
    font-size: 1rem;
    font-style: italic;
    letter-spacing: 0.15em;
}

.cp_qa *,
.cp_qa *:after,
.cp_qa *:before {
    font-family: 'FontAwesome', sans-serif;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
}

.cp_qa dt,
.cp_qa dd {
    position: relative;
    padding: 0.5em;
    box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.2);
    border-radius: 0.3em;
}

.cp_qa dt {
    margin: 0 3em 1em 3em;
    background: #00B66E;
    color: #FFF;
    font-weight: bold;
}

.cp_qa dd {
    margin: 0 3em 3em 3em;
    background: #cbf7cb;
}

/* Q&A */
.cp_qa dt::before,
.cp_qa dd::before {
    position: absolute;
    z-index: 99;
    top: 0.5em;
    display: inline-block;
    width: 0;
    height: 0;
    content: '';
    border-style: solid;
}

/* ???????? */
.cp_qa dt::before {
    left: -0.5em;
    border-width: 5px 8.7px 5px 0;
    border-color: transparent #00B66E transparent transparent;
}

/* ???????? */
.cp_qa dd::before {
    right: -0.5em;
    border-width: 5px 0 5px 8.7px;
    border-color: transparent transparent transparent #cbf7cb;
}

/* ?!???? */
.cp_qa dt::after,
.cp_qa dd::after {
    font-size: 1.2em;
    position: absolute;
    top: 0;
    color: #ffffff;
    border-radius: 50%;
    display: inline-block;
    width: 1.5em;
    height: 1.5em;
    line-height: 1.2em;
}

/* ????? */
.cp_qa dt::after {
    left: -2.75em;
    margin: -5px 0.2em 0 0;
    padding: 0em 0em;
    content: url(img/product/q.ico);
    /*background: #f57c00;*/
}

/* !???? */
.cp_qa dd::after {
    right: -0.5em;
    margin: 0 0 0 0.5em;
    padding: 0.2em 0.55em;
    content: url(img/product/a.ico);
}

#product-con {
    background-color: #50a4ff;
    background-image: url("https://www.transparenttextures.com/patterns/inspiration-geometry.png");
    /* This is mostly intended for prototyping; please download the pattern and re-host for production environments. Thank you! */
    /* This is mostly intended for prototyping; please download the pattern and re-host for production environments. Thank you! */
    color: #FFF;
    padding: 0.5em;
}

#product-con a.btn {
    color: #fff;
    background-color: #275ad0;
    display: block;
    margin: 0.25em auto 0.25em auto;
    max-width: 350px;
    text-align: center;
    border-radius: 20px;
}

#product-con a.btn:hover {
    color: #fff;
    background: #072d7e;
}

#product-con a.btn-c {
    font-size: 1.5rem;
    position: relative;
    padding: 0.25em;
}

#product-con a.btn-c i.fa {
    margin-right: 1rem;
}

#product-con a.btn-c:before {
    font-family: 'Font Awesome 5 Free';
    font-size: 1.6rem;
    line-height: 1;
    position: absolute;
    top: calc(50% - .8rem);
    right: 1rem;
    margin: 0;
    padding: 0;
    content: '\f054';
}

/******??????????******/