@charset "UTF-8";

/* 日本小動物医療センター（jsamc）
所沢本院（専門医療）をご利用の皆さま：一般向けのトップページ設定 
（総合トップ top.css をもとにして、異なる点のみ）*/


/*-----------------------------------------
基本設定
-------------------------------------------*/
.container-size {
    max-width: 1320px;
    width: 100%;
    margin: 0 auto;
    padding: 0 60px;
    margin-bottom: 120px;
}

.container-size.block_01 {
    margin-bottom: 60px;
}

.container-size.block_02 {
    margin-bottom: 0;
}

.container-size.block_02 .titleTextWrap.center {
    margin: 0 auto;
}

.pc_hidden {
    display: none !important;
}

.sp_hidden {
    display: block !important;
}

@media screen and (max-width: 991px) {
    .sp_hidden {
        display: none !important;
    }

    .pc_hidden {
        display: block !important;
    }
}


/* ハンバーガーメニュー */
.header__menu__item {
    border-right: 1px solid #DDDDDD;
    padding-right: 15px;
    padding-left: 15px;
    text-align: center;
    font-size: 14px;
    line-height: 1.2;
}

.header__menu a {
    padding: 0;
}

@media screen and (max-width: 1238px) {
    .header__logo {
        max-width: 406px;
        min-width: 120px;
        margin-right: 35px;
    }
}

/* メインビジュアル上のロゴ */
.fix_catchcopy img {
    margin-bottom: 10px;
}

/* スライダー */
.slick_block {
    padding-left: 0;
    height: 65vh;
    margin-bottom: 0;
}

/* パンくずリスト */
.breadcrumbs {
    margin-top: 3px;
}


/*-------------------------------------------
block_01 リンクボックス
-------------------------------------------*/
/* リンクボックス 4つ並び */
.tech_wrapper {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: stretch;
}

.tech_title {
    font-weight: normal;
}


/*-------------------------------------------
block_02 施設のご案内
-------------------------------------------*/
.container-size.block_02 .about_us {
    margin-bottom: 60px;
}

.container-size.block_02 .about_us .flex {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0;
}

.container-size.block_02 .titleTextWrap {
    width: 100%;
}

.container-size.block_02 .about_us .flex_img {
    /* ダミーのサイズ、あとで変える */
    width: 50%;
    /*height: 600px;*/
    border: 1px solid #ccc
}

.container-size.block_02 .about_us .flex_img img {
    width: 100%;
}

.container-size.block_02 .about_us .flex_text {
    width: 50%;
    padding-left: 80px;
}

.link_btn {
    margin: 0 0 0 auto;
}

@media screen and (max-width: 1200px) {
    .container-size.block_02 .about_us .flex_text {
        padding-left: 60px;
    }
}

@media screen and (max-width: 991px) {
    .container-size.block_02 .about_us .flex {
        flex-direction: column;
    }

    .container-size.block_02 .about_us .flex_img {
        width: 100%;
        margin-bottom: 30px;
    }

    .container-size.block_02 .about_us .flex_text {
        width: 100%;
        padding-left: 0px;
    }

    .link_btn {
        margin: 0 auto;
    }
}

/*-------------------------------------------
block_03 電話対応時間
block_04 お知らせ
-------------------------------------------*/
/* block_02 と block_03 を flex */
.flex_2colum {
    display: flex;
    justify-content: space-between;
    border-top: 1px solid #33b283;
    padding: 100px 60px;
}

.container-size.tel_news {
    margin-bottom: 0;
}

/* block_03 電話対応時間 */
.flex_2colum .block_03 {
    width: 50%;
    padding-right: 20px;
}

.title20bold {
    font-size: 20px;
    font-weight: bold;
    line-height: 1.4;
    margin-bottom: 5px;
}

.title20bold.address {
    margin-bottom: 15px;

}

.tel {
    font-size: 35px;
    font-weight: bold;
    margin-bottom: 10px;
}

.tel::before {
    display: inline-block;
    content: "";
    width: 23px;
    height: 23px;
    background-image: url(../img/common/icon_tel_black.jpg);
    background-repeat: no-repeat;
    margin-right: 7px;
}

.flex_2colum .block_03 .caution {
    font-size: 14px;
    line-height: 1.7;
    color: #E14E78;
    margin-top: 15px;
}

.flex_2colum .block_03 .link_btn {
    margin: auto 0 0 0;
}

/* お知らせ */
.flex_2colum .block_04 {
    width: 50%;
}
.flex_2colum .block_04 .stageRowBox {
    margin-bottom: 0;
}

.flex_2colum .block_04 .stageRowBox.news {
    width: 100%;
}

.stageRowBox.news .news_flex-items {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #eee;
}

.stageRowBox.news .inner-flex {
    width: 230px;
    flex-shrink: 0;
    /* display: flex;
    justify-content: space-between;
    align-items: center; */
    padding: 30px 0;
}


.stageRowBox.news .date {
    display: inline-block;
    width: 100px;
    height: auto;
    font-size: 14px;
    margin: 0;
}

.stageRowBox.news .tag {
    display: inline-block;
    width: 100px;
    /* flex-shrink: 0; */
    background-color: #0E5D2F;
    color: #fff;
    border-radius: 3px;
    font-size: 12px;
    margin: 0;
    padding: 8px 0;
    text-align: center;
}

.stageRowBox.news .tag.blue {
    background-color: #325FB7;
}

.stageRowBox.news .news {
    position: relative;
    width: calc(100% - 230px);
    height: auto;
    font-size: 16px;
    margin-bottom: 0;
    padding: 30px 0;
}

.stageRowBox.news .news .news-link {
    width: 98%;
    display: block;
    padding-right: 50px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-decoration: none;
    color: #333;
}

.stageRowBox.news .news::after {
    position: absolute;
    display: inline-block;
    content: "";
    width: 8px;
    height: 8px;
    top: 45%;
    right: 10px;
    border-top: 2px solid #33b283;
    border-right: 2px solid #33b283;
    transform: rotate(45deg);
}

@media screen and (max-width: 1121px) {
    .flex_2colum {
        flex-direction: column;
        margin-bottom: 300px;
    }

    .flex_2colum .block_03 {
        width: 100%;
    }

    .flex_2colum .block_04 {
        width: 100%;
    }

    .stageRowBox_news {
        margin-bottom: 60px;
    }

    .stageRowBox.news .flex-items .inner-flex {
        margin: 0 auto 0 0;
    }
}


@media screen and (max-width: 768px) {
    .stageRowBox.news .news_flex-items {
        flex-direction: column;
    }
    .stageRowBox.news .inner-flex {
        width: 100%;
        padding: 15px 0 7px;
    }
    .stageRowBox.news .news {
        width: 100%;
        padding: 7px 0 15px;
        margin-left: 100px;
    }
    .stageRowBox.news .news::after {
        top: -10px;
    }
}

/*-------------------------------------------
block_03 診療科目
-------------------------------------------*/
.container-size.block_05 {
    border-top: 1px solid #33b283;
    padding-top: 120px;
}

.container-size.block_05 .tech_wrapper {
    display: flex;
    flex-wrap: wrap;
    /*justify-content: space-between;*/
    row-gap: 60px;
}

.tech_block_3colum {
    position: relative;
    width: 30%;
    display: flex;
}

.tech_block_3colum .tech_img_box {
    height: auto;
}

.tech_block_3colum .tech_title {
    font-size: 20px;
    line-height: 1.2;
}

.tech_block_3colum .arrow_box {
    position: absolute;
    
    right: 0;
    display: flex;
    justify-content: end;
    align-items: center;
}

.container-size.block_05 .link_btn {
    margin: 0 auto;
}

@media screen and (max-width: 1121px) {
    .container-size.block_05 .link_btn {
        margin: 60px auto 0 auto;
    }
    .tech_block_5colum .tech_title {
        font-size: 18px;
    }
}

@media screen and (max-width: 991px) {
    .tech_block_3colum {
        position: relative;
        width: 31%;
    }
}

@media screen and (max-width: 768px) {
    .tech_block_3colum {
        position: relative;
        width: 48%;
    }
}
@media screen and (max-width: 500px) {
    .tech_block_3colum .tech_title {
        font-size: 16px;
    }
}

/*-------------------------------------------
block_05 診療科目
-------------------------------------------*/
.container-size.block_05 {
    border-top: 1px solid #33b283;
    padding-top: 120px;
}

.container-size.block_05 .tech_wrapper {
    display: flex;
    flex-wrap: wrap;
    /*justify-content: space-between;*/
    row-gap: 60px;
}

.tech_block_5colum {
    position: relative;
    width: 30%;
    display: flex;
}

.tech_block_5colum .tech_img_box {
    height: auto;
}

.tech_block_5colum .tech_title {
    font-size: 20px;
    line-height: 1.2;
}

.tech_block_5colum .arrow_box {
    position: absolute;
    
    right: 0;
    display: flex;
    justify-content: end;
    align-items: center;
}

.container-size.block_05 .link_btn {
    margin: 0 auto;
}

@media screen and (max-width: 1121px) {
    .container-size.block_05 .link_btn {
        margin: 60px auto 0 auto;
    }
    .tech_block_5colum .tech_title {
        font-size: 18px;
    }
}

@media screen and (max-width: 991px) {
    .tech_block_5colum {
        position: relative;
        width: 31%;
    }
}

@media screen and (max-width: 768px) {
    .tech_block_5colum {
        position: relative;
        width: 48%;
    }
}
@media screen and (max-width: 500px) {
    .tech_block_5colum .tech_title {
        font-size: 16px;
    }
}

/*-------------------------------------------
block_06 アクセス
-------------------------------------------*/
.container-size.block_06 .stageRowBox {
    margin-bottom: 0;
}

.container-size.block_06 .access .flex {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0;
}

.container-size.block_06 .access .flex_img {
    width: 54%;
    padding-left: 80px;
}

.container-size.block_06 .access .flex_img iframe {
    width: 100%;
    height: 600px; 
}
.container-size.block_06 .access .flex_img iframe {
    width: 100%;
    height: 600px; 
}
@media screen and (max-width: 1121px) {
    .container-size.block_06 .access .flex_img iframe {
        height: 500px;
    }
}
@media screen and (max-width: 768px) {
    .container-size.block_06 .access .flex_img iframe {
        height: 400px;
    }
}
.container-size.block_06 .access .flex_text {
    width: 46%;
    padding-left: 0;
}

.block_06 .tel_box p {
    line-height: 1;
}
.block_06 .tel_box .title20bold {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 5px;
}
.block_06 .tel_box .tel {
    margin-top: 8px;
}


.block_06 .title20bold.address {
    font-size: 20px;
    font-weight: bold;
    line-height: 1.5;
    margin-bottom: 15px;
}

.block_06 .tel {
    font-size: 35px;
    font-weight: bold;
    margin-bottom: 10px;
}

.block_06 .tel::before {
    display: inline-block;
    content: "";
    width: 23px;
    height: 23px;
    background-image: url(../img/common/icon_tel_black.jpg);
    background-repeat: no-repeat;
    margin-right: 7px;
}
.block_06 .font_14 p {
    font-size: 14px;
}


@media screen and (max-width: 991px) {
    .container-size.block_06 .access .flex {
        flex-direction: column;
    }

    .container-size.block_06 .access .flex_img {
        width: 100%;
        padding-left: 0;
    }

    .container-size.block_06 .access .flex_text {
        width: 100%;
        margin-bottom: 30px;
    }
}