@charset "UTF-8";

@import url("settings.css");

html {
    font-size: 10px;
}

* {
    box-sizing: border-box;
}
body {
    font-family: 'Montserrat', "Noto Sans JP", sans-serif;
    line-height: 1.75;
    margin: 0;
    font-size: 1.6rem;
    color: var(--text-body);
}
li {
    list-style: none;
}
@font-face {
    font-family: 'Montserrat';
    src: local('Montserrat Regular');
    font-weight: var(--en-r);
    size-adjust: 106%;
}
@font-face {
    font-family: 'Montserrat';
    src: local('Montserrat SemiBold');
    font-weight: var(--en-b);
    size-adjust: 106%;
}
a {
    text-decoration: none;
}

/*======ヘッダー======*/
.ly_header {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 40px;
    @media (max-width: 575.98px) { 
        padding: 16px var(--width-pd);
    }
}
/* ロゴ */
.ly_header_logo {
    @media (max-width: 959px) {
        width: 33%;
        line-height: 1;
        img {
            max-width: 100%;
            height: auto;
        }
    }
}
.bl_headerBtns {
}
/* ===上段ボタン=== */
.bl_headerBtns_info {
    display: flex;
    justify-content: right;
    gap: 24px;
    margin-bottom: 8px;
    font-size: 1.2rem;
    font-weight: var(--txt-b);
    @media (max-width: 959px) {
        display: none;
    }
}
.bl_headerBtns_faqBtn {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
/* ===下段ボタン=== */
.bl_headerBtns_contacts {
    font-size: 1.4rem;
    display: flex;
    justify-content:right;
    gap: 12px;
    a {
        height: 40px;
    }
    @media (max-width: 959px) {
        gap: 8px;
    }
}
/* 無料相談ボタン */
.bl_headerBtns_contactBtn {
    .el_icon_arrow {
        &:before {
            width: 20px;
            height: 20px;
        }
    }
    @media (max-width: 576px) {
        display: none;
    }
}
/* LINEボタン */
.bl_headerBtns_lineBtn {
    @media (max-width: 576px) {
        font-size: 1.2rem;
    }
}
/* 資料請求ボタン */
.bl_headerBtns_docBtn {
    .el_icon_arrowWhite {
        &:before {
            width: 20px;
            height: 20px;
        }
    }
    @media (max-width: 576px) {
        font-size: 1.2rem;
    }
}

/*======KV======*/
.ly_kv {
    background-image: url(../img/kv_bg.png);
    background-repeat: no-repeat;
    background-position: left center;
    background-size: cover;
    padding: 66px 3% 40px;
    margin: 0 40px 40px 40px;
    border-radius: var(--radius-lg);
    @media (min-width: 1080px) { 
        display: flex;
        justify-content: center;
        align-items: center;
    }
    @media (max-width: 1079.98px) { 
        margin: 0 5% 5vw;
        padding: 20px 5%;
        max-width: var(--width-sp-md);
        background-image: url(../img/kv_bg_sp.png);
    }
}
.bl_kv_pageTtl {
    font-weight: var(--txt-b);
    color: var(--white);
    font-size: 3.6vw;
    line-height: 1.25;
    margin: 0 0 20px;
    @media (max-width: 575.98px) {
        font-size: 3.2rem;
        margin: 0 0 10px;
    }
    span {
        font-weight: var(--txt-b);
        color: var(--white);
        font-size: 20px;
        display: block;
        margin-bottom: 8px;
        @media (max-width: 575.98px) {
            font-size: 1.5rem;
        }
    }
}
/* kv - card */
.bl_kvCard {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    grid-gap: 12px;
    padding: 0;
    margin-bottom: 30px;
    @media (max-width: 575.98px) { 
        margin-bottom: 15px;
    }
}
.bl_kvCard_item {
    text-align: center;
    background: var(--white);
    border-radius: var(--radius-md);
    p {
        margin: 0;
        font-weight: var(--txt-b);
        line-height: 1;
        @media (max-width: 575.98px) {
            font-size: 1.2rem;
        }
    }
    .bl_kvCard_longTxt {
        font-size: 1.4rem;
        @media (max-width: 575.98px) {
            font-size: 0.8rem;
        }
    }
    div {
        padding: 70px 4px 14px;
        @media (max-width: 575.98px) {
            padding: 56px 4px 12px;
        }
    }
}
.bl_kvCard_lowCost  {
    background: var(--icon_lowCost_blue);
    background-repeat: no-repeat;
    background-position: center 10px;
    @media (max-width: 575.98px) {
        background-size: 40px;
    }
}
.bl_kvCard_workEfficiency {
    background: var(--icon_workEfficiency_blue);
    background-repeat: no-repeat;
    background-position: center 10px;
    @media (max-width: 575.98px) {
        background-size: 40px;
    }
}
.bl_kvCard_crm {
    background: var(--icon_crm_blue);
    background-repeat: no-repeat;
    background-position: center 10px;
    background-size: 52px;
    @media (max-width: 575.98px) {
        background-size: 40px;
    }
}
.bl_kvCard_graph {
    background: var(--icon_graph_blue);
    background-repeat: no-repeat;
    background-position: center 10px;
    @media (max-width: 575.98px) {
        background-size: 40px;
    }
}
.bl_kvCard_backOut {
    background: var(--icon_backOut_blue);
    background-repeat: no-repeat;
    background-position: center 10px;
    @media (max-width: 575.98px) {
        background-size: 40px;
    }
}
.bl_kvCard_reserv {
    background: var(--icon_reserv_blue);
    background-repeat: no-repeat;
    background-position: center 10px;
    @media (max-width: 575.98px) {
        background-size: 40px;
    }
}
.bl_kvCard_online {
    background: var(--icon_online_blue);
    background-repeat: no-repeat;
    background-position: center 10px;
    background-size: 56px 56px;
    @media (max-width: 575.98px) {
        background-size: 40px;
    }
}
.bl_kvCard_payment {
    background: var(--icon_card_blue);
    background-repeat: no-repeat;
    background-position: center 10px;
    background-size: 56px 56px;
    @media (max-width: 575.98px) {
        background-size: 40px;
    }
}
.bl_kvCard_interview {
    background: var(--icon_interview_blue);
    background-repeat: no-repeat;
    background-position: center 10px;
    background-size: 56px 56px;
    @media (max-width: 575.98px) {
        background-size: 40px;
    }
}
.bl_kvCard_inventoryControl {
    background: var(--icon_pill_blue);
    background-repeat: no-repeat;
    background-position: center 10px;
    background-size: 56px 56px;
    @media (max-width: 575.98px) {
        background-size: 40px;
    }
}
.bl_kvCard_ec {
    background: var(--icon_cart_blue);
    background-repeat: no-repeat;
    background-position: center 10px;
    background-size: 56px 56px;
    @media (max-width: 575.98px) {
        background-size: 40px;
    }
}
/* KV - CTA */
.bl_kvCta {
    margin-bottom: 10px;
    @media (min-width: 576px) { 
        display: flex;
        justify-content: space-between;
    }
    a {
        color: var(--white);
        font-size: 1.7rem;
        font-weight: var(--txt-b);
        border-radius: 50px;
        height: 56px;
        @media (min-width: 576px) {
            width: 49%;
        }
        @media (max-width: 575.98px) {
            width: 100%;
        }
        span {
            color: var(--white);
            font-weight: var(--txt-b);
            line-height: 1;
        }
        .bl_kvCta_subTxt {
            display: block;
            font-size: 1.2rem;
            margin-bottom: 4px;
            line-height: 1;
        }
        .el_icon_arrowWhite {
            &::before{
                width: 32px;
                height: 32px;
            }
        }
    }
}
.bl_kvCta_inner {
    display: flex;
    justify-content: center;
    align-items: center;
    background: url(../img/icon_arrow_white.svg);
    background-repeat: no-repeat;
    background-position: right;
    background-size: 32px;
    line-height: 1.2;
    width: 100%;
    height: 100%;
}
/* 資料請求 */
.bl_kvCta_doc {
    background: var(--blue500);
    text-align: center;
    background-repeat: no-repeat;
    background-position: right;
    padding: 6px 20px 6px 16px;
    transition-duration: 0.3s;
    &:hover {
        background: var(--blue600);
    }
    @media (max-width: 575.98px) {
        margin-bottom: 8px;
    }
}
/* LINE友だち */
.bl_kvCta_line {
    background: var(--line);
    text-align: center;
    background-repeat: no-repeat;
    background-position: right;
    padding: 6px 20px 6px 10px;
    transition-duration: 0.3s;
    .el_icon_line {
        margin-right: 10px;
        &::before {
            width: 24px;
            height: 23px;
        }
    }
    &:hover {
        background: var(--line-hover);
    }
}
/* 無料相談受付中！ */
.bl_kvDiscussion {
    color: var(--white);
    text-align: center;
    text-decoration: underline;
    @media (max-width: 575.98px) { 
        margin-bottom: 10px;
    }
    a {
        color: var(--white);
    }
    &:hover {
        text-decoration: none;
    }
}
.bl_kv_mockup {
    width: 614px;
    @media (min-width: 1080px) { 
        margin-left: 50px;
    }
    @media (max-width: 1079.98px) { 
        width: 100%;
        margin-left: 0;
    }
    img {
        max-width: 100%;
        height: auto;
    }
}
/*======marchでできる4つのこと======*/
.bl_pointList {
    display: flex;
    justify-content: space-between;
    gap: 32px;
    @media (max-width: 1079.98px){
        flex-wrap: wrap;
    }
    @media (min-width: 576px) and (max-width: 1079.98px)  {
        gap: 4%;
    }
    
}
.bl_pointList_item{
    @media (min-width: 576px) and (max-width: 1079.98px)  {
        width: 48%;
    }
    img {
        max-width: 100%;
        height: auto;
        row-gap: 20px;
        margin-bottom: 20px;
    }
}
.bl_pointList_num {
    font-size: 3.2rem;
    color: var(--primary);
    border-bottom: 2px solid var(--primary);
    display: block;
    width: 40px;
    margin: auto;
    margin-bottom: 20px;

}
.bl_pointList_ttl {
    font-size: 1.8rem;
    line-height: 1.5;
    text-align: center;
    font-weight: var(--txt-b);
    margin-bottom: 4px;
}
.bl_pointList_txt {
    text-align: center;
    font-size: 1.4rem;
}

/* 詳細 */
.bl_pointDetails {
    li {
        margin-top: 4px;
        line-height: 1.8;
    }
}
.bl_pointDetails.ly_cont {
    padding-bottom: 20px;
}
.bl_pointDetails_ttl {
    font-size: 2.8rem;
    font-weight: var(--txt-b);
    line-height: 1.5;
    margin-bottom: 20px;
}
.bl_pointDetails_txt {
    color: var(--gray1000);
    line-height: 1.8;
}
.bl_pointDetails_item {
    margin-bottom: 50px;
    @media (min-width: 576px) { 
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    img {
        width: 46%;
        @media (max-width: 575.98px) { 
            width: 100%;
        }
    }
}
.bl_pointDetails_item__rev {
    margin-bottom: 80px;
    @media (min-width: 576px) { 
        display: flex;
        align-items: center;
        justify-content: space-between;
        flex-direction: row-reverse;
    }
    img {
        width: 46%;
        @media (max-width: 575.98px) { 
            width: 100%;
        }
    }
}
.bl_pointDetails_inner {
    padding: 50px;
    @media (max-width: 575.98px) { 
        padding: 50px 5%;
    }
}
.bl_pointDetails_num01 {
    position: relative;
    &::before {
        content: "01";
        color: var(--blue300);
        font-size: 12rem;
        position: absolute;
        top: -10px;
        left: 0;
        z-index: 1;
    }
}
.bl_pointDetails_num02 {
    position: relative;
    &::before {
        content: "02";
        color: var(--blue300);
        font-size: 12rem;
        position: absolute;
        top: -10px;
        left: 0;
        z-index: 1;
    }
}
.bl_pointDetails_num03 {
    position: relative;
    &::before {
        content: "03";
        color: var(--blue300);
        font-size: 12rem;
        position: absolute;
        top: -10px;
        left: 0;
        z-index: 1;
    }
}
.bl_pointDetails_num04 {
    position: relative;
    &::before {
        content: "04";
        color: var(--blue300);
        font-size: 12rem;
        position: absolute;
        top: -10px;
        left: 0;
        z-index: 1;
    }
}

.bl_pointDetails_box {
    position: relative;
    z-index: 1;
}
.bl_pointDetails_txt {
    margin-bottom: 20px;
}
.bl_pointDetails_points {
    background: var(--blue50);
    padding: 20px 24px;
    border-radius: var(--radius-md);
    h4 {
        font-size: 1.8rem;
        color: var(--primary);
        font-weight: var(--txt-b);
        text-transform: uppercase;
        margin-bottom: 4px;
    }
    li {
        font-weight: var(--txt-b);
        &::before {
            content: "・";
            color: var(--primary);
        }
    }
}

/*======marchの主な機能======*/
.bl_funcList {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
    gap: 10px;
    @media (min-width: 576px) and (max-width: 1079.98px)  { 
        grid-template-columns: 1fr 1fr 1fr 1fr;
    }
    @media (max-width: 575.98px) {
        grid-template-columns: 1fr 1fr;
    }
}
.bl_funcList_item {
    background: var(--white);
    background-size: 80px;
    border-radius: var(--radius-md);
    text-align: center;
    padding: 100px 20px 20px;
}
.bl_funcList_ttl {
    font-weight: var(--txt-b);
}
.bl_funcList_txt {
    color: var(--text-secondary);
    font-size: 1.4rem;
    margin-top: 8px;
}
.bl_funcList_reserv {
    background-image: var(--icon_reserv-sp_blue);
    background-repeat: no-repeat;
    background-position: center 20px;
}
.bl_funcList_interview {
    background-image: var(--icon_interview_blue);
    background-repeat: no-repeat;
    background-position: center 20px;
}
.bl_funcList_online {
    background-image: var(--icon_online_blue);
    background-repeat: no-repeat;
    background-position: center 20px;
}
.bl_funcList_payment {
    background-image: var(--icon_card_blue);
    background-repeat: no-repeat;
    background-position: center 20px;
}
.bl_funcList_remind {
    background-image: var(--icon_remind_blue);
    background-repeat: no-repeat;
    background-position: center 20px;
}
.bl_funcList_crm {
    background-image: var(--icon_crm_blue);
    background-repeat: no-repeat;
    background-position: center 20px;
}
.bl_funcList_shift {
    background-image: var(--icon_noun-schedule_blue);
    background-repeat: no-repeat;
    background-position: center 20px;
}
.bl_funcList_ec {
    background-image: var(--icon_cart_blue);
    background-repeat: no-repeat;
    background-position: center 20px;
}
.bl_funcList_inventoryControl {
    background-image: var(--icon_pill_blue);
    background-repeat: no-repeat;
    background-position: center 20px;
}
.bl_funcList_patientid {
    background-image: var(--icon_dz-patientid_blue);
    background-repeat: no-repeat;
    background-position: center 20px;
}
.bl_funcOthers {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
    gap: 11px 24px;
    background: var(--white);
    border-radius: var(--radius-md);
    margin-top: 10px;
    padding: 32px 24px;
    @media (min-width: 576px) and (max-width: 1079.98px)  { 
        grid-template-columns: 1fr 1fr 1fr;
    }
    @media (max-width: 575.98px) {
        grid-template-columns: 1fr;
    }
}
.bl_funcOthers_item {
    line-height: 1.5;
    &:before {
        content: "・";
        color: var(--primary);
    }
}

/*======marchが提供する8つのメリット======*/
.bl_meritList {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    @media (min-width: 576px) and (max-width: 1079.98px)  { 
        grid-template-columns: 1fr 1fr 1fr;
    }
    gap: 32px;
    @media (max-width: 575.98px) {
        grid-template-columns: 1fr;
    }
}
.bl_meritList_item {
    text-align: center;
    position: relative;
    img {
        max-width: 100%;
        margin-bottom: 20px;
    }
    .el_tag {
        position: absolute;
        top: 10px;
        left: 10px;
    }
}
.bl_meritList_ttl {
    font-size: 1.8rem;
    font-weight: var(--txt-b);
    margin-bottom: 4px;
}
.bl_meritList_txt {
    font-size: 1.4rem;
}

/*======marchについて知る======*/
.bl_movie {
    .youtube-16-9 {
        width: calc(( 720 / var(--width-sm-calc) ) * 100%);
        height: auto;
        aspect-ratio: 16 / 9;
        margin: auto;
        @media (max-width: 575.98px) {
            width: 90%;
        }
    }
    .youtube-16-9 iframe {
        width: 100%;
        height: 100%;
    }
}
/*======marchを使った診療の流れ======*/
.bl_flows_online,.bl_flows_offline {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
    gap: 32px;
    @media (min-width: 576px) and (max-width: 1079.98px)  { 
        grid-template-columns: 1fr 1fr 1fr;
    }
    @media (max-width: 575.98px) {
        grid-template-columns: 1fr;
    }
}
.bl_flow_detail {
    img {
        max-width: 100%;
    }
}
.bl_flows_txt {
    font-size: 1.4rem;
    margin-top: 4px;
}
.tab {
    width: 100%;
    max-width: 400px;
}
.bl_flows_btns {
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin-bottom: 24px;
}
.bl_flows_btn { 
    font-size: 1.8rem;
    font-weight: var(--txt-b);
    padding: 10px;
    @media (max-width: 575.98px) { 
        font-size: 1.4rem;
    }
}
.js_tab {
    cursor: pointer;
    flex: 1;
    border-bottom: 1px solid var(--border);
    color: var(--text-secondary);
    background: var(--white);
}
.js_tab.js_active {
    background-color: #fff;
    border-bottom: 2px solid var(--primary);
    color: var(--primary);
}
.js_tabPanel {
    display: none;
}
.js_tabPanel.js_active {
    display: block;
}
/*======お客様の声======*/
.bl_voicePost {
    background: var(--white);
    padding: 32px;
    border-radius: var(--radius-md);
}
.bl_voicePost_info {
    width: calc( ( 502 / var(--width-sm-calc) ) * 100% ); 
    @media (max-width: 575.98px) {
        width: 100%;
    }
}
.bl_voicePost_infoGroup {
    display: flex;
    align-items: center;
    margin-bottom: 12px;
    @media (max-width: 1079.98px) {
        display: block;
    }
}
.bl_voicePost_tags {
    display: flex;
    gap: 8px;
    margin-left: 16px;
    @media (max-width: 1079.98px) {
        margin-top: 8px;
        margin-left: 0;
        flex-wrap: wrap;
    }
}
.bl_voicePost_head {
    display: flex;
    justify-content: space-between;
    align-items: start;
    @media (max-width: 575.98px) {
        flex-wrap: wrap;
    }
    img {
        width: calc( ( 370 / var(--width-sm-calc) ) * 100% ); 
        border-radius: var(--radius-md);
        @media (max-width: 575.98px) {
            width: 100%;
            margin-top: 16px;
        }
    }
}
.bl_voicePost_ttl {
    font-size: 26px;
    font-weight: var(--txt-b);
    margin-bottom: 16px;
}
.bl_voice_description {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    margin-top: 24px;
    @media (max-width: 575.98px) {
        grid-template-columns: 1fr;
        gap: 24px;
    }
}
.bl_voiceBackground,.bl_voiceFunc {
    background: var(--gray50);
    border-left: 3px solid var(--gray400);
    padding: 16px 20px;
}
.bl_voiceBackground_ttl {
    font-weight: var(--txt-b);
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: 8px;
    &:before {
        content: "";
        background-image: var(--icon_background);
        display: block;
        width: 20px;
        height: 20px;
    }
}
.bl_voiceBackground_txt {
    font-size: 1.4rem;
}
.bl_voiceFunc_ttl {
    font-weight: var(--txt-b);
    display: flex;
    align-items: center;
    gap: 4px;
    margin-bottom: 8px;
    &:before {
        content: "";
        background-image: var(--icon_gear);
        display: block;
        width: 20px;
        height: 20px;
    }
}
.bl_voiceFunc_list {
    display: grid;
    grid-template-columns: 1fr 1fr;
}
.bl_voiceFunc_item {
    font-size: 1.4rem;
    list-style: inside;
}
.bl_voicePostMain {
    margin-top: 24px;
}
.bl_voicePostMain_ttl {
    font-size: 1.8rem;
    font-weight: var(--txt-b);
    margin:  24px 0 16px;
}
.bl_voicePostMain_txt {
    margin-top: 8px;
}
.bl_voicePostMain_bold {
    font-weight: var(--txt-b);
}

/*======導入の流れ======*/
.bl_introFlow_list {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
    gap: 18px;
    @media (max-width: 1079.98px) {
        grid-template-columns: 1fr 1fr 1fr;
    }
    @media (max-width: 575.98px) {
        grid-template-columns: 1fr
    }
}
.bl_introFlow_item {
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 12px 16px 24px;
}
.bl_introFlow_txt {
    font-size: 1.4rem;
    margin-top: 8px;
}

/*======よくある質問======*/
.bl_faq_list {
    margin-top: 24px;
}
.bl_faq_item {
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 32px 40px;
}
.bl_faq_ttl {
    font-weight: var(--txt-b);
    margin-bottom: 24px;
    &::before {
        content: "Q";
        font-size: 2.4rem;
        margin-right: 8px;
    }
}
/*======ページ下部お問い合わせ======*/
.bl_contacts_list{
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    gap: 40px;
    @media (max-width: 1079.98px) {
        gap: 24px;}
    @media (max-width: 575.98px) {
        grid-template-columns: 1fr;
        
    }
}
.bl_contacts_item {
    background: var(--white);
    text-align: center;
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: 0 5px 10px rgb(0 0 0 / 15%);
    
}
.bl_contacts_txtGroup {
    padding: 26px 34px 26px 30px;
    border-bottom: 1px solid var(--border);
}
.bl_contacts_ttl {
    font-size: 2.6rem;
    font-weight: var(--txt-b);
}
.bl_contacts_txt {
    text-align: center;
    color: var(--text-secondary);
    margin-top: 8px;
    @media (max-width: 1079.98px) { 
        font-size: 1.2rem;
    }
}
.bl_contacts_item__doc {
    &::before {
        content: "";
        background-image: url(../img/contact_document_img.png);
        background-size: cover;
        background-repeat: no-repeat;
        display: block;
        width: calc( ( 309 / 360 ) * 100% );
        height: auto;
        aspect-ratio: 16 / 9;
        margin:  28px auto 0;
    }
}
.bl_contacts_item__line {
    &::before {
        content: "";
        background-image: url(../img/line-logo.svg);
        background-size: 84px;
        background-repeat: no-repeat;
        background-position: center;
        display: block;
        width: calc( ( 309 / 360 ) * 100% );
        height: auto;
        aspect-ratio: 16 / 9;
        margin: 28px auto 0;
    }
}
.bl_contacts_item__discussion {
    &::before {
        content: "";
        background-image: url(../img/contact_img01.png);
        background-size: cover;
        background-repeat: no-repeat;
        background-position: center;
        display: block;
        width: 100%;
        height: auto;
        aspect-ratio: 16 / 9;
    }
}
.bl_contacts_btn {
    font-size: 1.8rem;
    line-height: 1;
    font-weight: var(--txt-b);
    background: var(--primary);
    color: var(--white);
    border-radius: 50px;
    display: block;
    padding: 16px 8px;
    margin: 20px 24px 20px;
    transition-duration: 0.3s;
    &:hover {
        background: var(--primary-hover);
    }
}
.bl_contacts_btn__line {
    font-size: 1.8rem;
    line-height: 1;
    font-weight: var(--txt-b);
    background: var(--line);
    color: var(--white);
    border-radius: 50px;
    display: block;
    padding: 16px 8px;
    transition-duration: 0.3s;
    &:hover {
        background: var(--line-hover);
    }
}
.bl_contacts_btn__black {
    font-size: 1.8rem;
    line-height: 1;
    font-weight: var(--txt-b);
    background: var(--text-body);
    color: var(--white);
    border-radius: 50px;
    display: block;
    padding: 16px 8px;
    transition-duration: 0.3s;
    &:hover {
        background: var(--text-secondary);
    }
}

/*======CTA======*/
.el_contContact {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
    max-width: var(--width-sm);
    margin: 0 auto 60px;
    @media (max-width: 575.98px) {
        flex-wrap: wrap;
        gap: 16px;
    }
}
.el_contContact_doc {
    color: var(--white);
    text-align: center;
    background: var(--primary);
    border-radius: 50px;
    padding: 10px;
    width: calc( ( 320 / 960 ) * 100% );
    height: 60px;
    position: relative;
    transition-duration: 0.3s;
    @media (max-width: 575.98px) {
        width: 80%;
    }
    &::after {
        content: "";
        display: block;
        background: var(--icon_arrowWhite);
        background-size: cover;
        background-repeat: none;
        width: 32px;
        height: 32px;
        position: absolute;
        top: 50%;
        right: 6%;
        transform: translateY(-50%);
    }
    &:hover {
        background: var(--primary-hover);
    }
    span {
        color: var(--white);
        font-weight: var(--txt-b);
    }
}
.el_contContact_sm {
    font-size: 1.2rem;
    display: block;
}
.el_contContact_line {
    color: var(--white);
    text-align: center;
    font-weight: var(--txt-b);
    border-radius: 50px;
    background: var(--line);
    display: flex;
    padding: 10px;
    width: calc( ( 320 / 960 ) * 100% );
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    gap: 8px;
    transition-duration: 0.3s;
    @media (max-width: 575.98px) {
        width: 80%;
    }
    &::after {
        content: "";
        display: block;
        background: var(--icon_arrowWhite);
        background-size: cover;
        background-repeat: none;
        width: 32px;
        height: 32px;
        position: absolute;
        top: 50%;
        right: 6%;
        transform: translateY(-50%);
    }
    &:hover {
        background: var(--line-hover);
    }
}

/*======サイドCTA======*/
.el_sideCta {
    position: fixed;
    transition-duration: 1s;
    @media (min-width: 1080px) { 
        top: 20%;
        right: 0;
    }
    @media (max-width: 1079.98px) {
        bottom: 0;
        display: flex;
        gap: 8px;
        z-index: 1;
        width: 100%;
        background: var(--white);
        padding: 16px;
    }
}
.el_sideCta_doc {
    color: var(--white);
    font-weight: var(--txt-b);
    background: var(--primary);
    display: block;
    padding: 24px 14px;
    border-radius: 8px 0 0 8px;
    letter-spacing: 0.2em;
    transition-duration: 0.3s;
    &:hover {
        background: var(--primary-hover);
    }
    @media (min-width: 1080px) { 
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
    }
    @media (max-width: 1079.98px) {
        border-radius: 8px;
        padding: 16px 14px;
        width: 40%;
        text-align: center;
    }
}
.el_sideCta_line {
    color: var(--white);
    font-weight: var(--txt-b);
    background: var(--line);
    display: block;
    padding: 24px 14px;
    border-radius: 8px 0 0 8px;
    letter-spacing: 0.2em;
    transition-duration: 0.3s;
    &:hover {
        background: var(--line-hover);
    }
    @media (min-width: 1080px) { 
        text-orientation: upright;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        margin-top: 16px;
    }
    @media (max-width: 1079.98px) {
        border-radius: 8px;
        padding: 16px 14px;
        width: 60%;
        text-align: center;
    }
    .el_icon_line {
        @media (min-width: 1080px) { 
            margin-bottom: 8px;
        }
        @media (max-width: 1079.98px) {
            margin-right: 8px;
        }
    }
}