@charset "UTF-8";
/*
    Template: swell
    Theme Name: INUTONEKO-ah
    Theme URI:
    Description:
    Version: 0.1
    Author:
    Author URI:

    License: GNU General Public License
    License URI: http://www.gnu.org/licenses/gpl.html
*/

/* カラー設定
    メインカラー：#007E66
    リンクカラー：#00bcd4
    テキストカラー：#282828
    アクセント（金色）：#DAC37D
    薄い緑背景：#EEF9F6
    薄い金背景：#FDFBF4
* /

/* 全体調整 */

body{
    font-feature-settings: "palt" 1;
    letter-spacing: 0.1em;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    background-color: #fff;
}

.w-beforeFooter{
    margin: 0 auto;
  }

/* アニメーション */
@keyframes vertical {
    0% { transform:translateY( -10px); }
  100% { transform:translateY(  0px); }
}

@keyframes horizontal {
    0% { transform:translateX( -10px); }
  100% { transform:translateX(  0px); }
}

@keyframes yurayura {
    0% { transform:translateY( -15px) rotate( -10deg); }
  100% { transform:translateY ( 0px) rotate( 5deg); }
}

@keyframes bgiLoop {
    0% { background-position: 0 0;}
  100% { background-position: 1920px 3000px;}
}

.anim_fuwa {
    -webkit-animation: vertical 1s ease-in-out infinite alternate;
    animation: vertical 1s ease-in-out infinite alternate;
}

.anim_yura {
    -webkit-animation: yurayura 1.5s ease-in-out infinite alternate;
    animation: yurayura 1.5s ease-in-out infinite alternate;
}

/* -------- ローディング -------- */
.loading {
    position: -webkit-fixed;
	position: fixed;
	top: 0;
	right: 0;
	background-color: #FFFFFF;
	width: 100%;
	height: 100vh;
	z-index: 99999;
}

.loading .txt,
.loading .logo {
	/* position: absolute; */
	z-index: 1;
}

.loading .txt {
	/* top: 50%; */
	/* left: 50%; */
    white-space: nowrap;
    width: 100%;
}

.loading .txt-jp > div {
	transform-origin: center bottom;
	opacity: 0;
}

.loading .txt-ttl { 
    font-size: 32px;
    letter-spacing: 0.1em;
    color:#DBCD9C;
    margin-bottom: 8px;
}

.loading .txt-en {
    font-size: 20px;
	opacity: 0;
}

.loading .logo {
	top: 40%;
	text-align:center;
	opacity: 0;
    width: 100%;
    position: absolute;
}

.loading .logo img {
	width: 70vw;
    max-width: 520px;
	height: auto;
    margin: 0 auto;
}

.loading .bar-wrap {
	position: absolute;
	top: 0;
	left: 0;
	background-color: #DBCD9C;
	width: 10px;
	height: 100%;
	z-index: 1;
}

.loading .bar {
	background-color: #005caf;
	width: 100%;
	height: 0;
}

.loading .bg1,
.loading .bg2 {
	position: absolute;
	top: 0;
	right: 100%;
	width: 100%;
	height: 100%;
}

.loading .bg1 {
	background-color: #005caf;
	z-index: 2;
}

.loading .bg2 {
	/* background-color: #DBCD9C; */
    background-color: #DAC37D;
	z-index: 3;
}

@media screen and (max-width: 959px){
    .loading .txt-ttl { 
        font-size: 24px;
    }
    
    .loading .txt-en {
        font-size: 12px;
    }
    
    .loading .logo {
        top: 35%;
        opacity: 0;
    }
}



/*-----フローティングバナーの調整-----*/
.reserve {
    position: -webkit-fixed;
	position: fixed;
	bottom: 7vh;
	right: 3vh;
	z-index: 9999;
}

.fullwidefutter {
	z-index: -1;
}

@media screen and (max-width: 598px) {
	.reserve {
       width: 25%;
	}
}

/* ---------- サイドバー型ヘッダー ---------- */
@media screen and (min-width:960px){
    #body_wrap{
        margin-left: 240px;
    }
    .l-header{
        padding: 32px 0;
    }
    .l-header__logo{
        position: -webkit-fixed;
        position: fixed;
        background: #fff;
        top: 10vh;
        left: 0;
        z-index: 100;
        width: 240px;
        height: 50vh;
        justify-content: space-around;
        flex-direction: column;
        padding: 2em 0;
    }
    .c-headLogo.-txt{
        background: url(assets/img/nagiah_logo_pc_4.svg) 50% 50% no-repeat;
        background-size: contain;
        height: 40vh;
        overflow: hidden;
        text-indent: 100%;
        white-space: nowrap;
    }
    .-txt .c-headLogo__link{
		font-size: 28px;
        padding-left: 24px;
        height: 40vh;
        width: calc(40vh * 0.17); /* 縦横比で計算 */
    }
    .-body-solid .l-fixHeader{
        box-shadow: none;
        padding: 16px 0;
        padding-left: 240px;
    }
    .l-header__inner.l-container{
        max-width: 100%;
    }
    .l-fixHeader__inner.l-container {
        max-width: 100%;
        transform: translateZ(0);
    }
    .l-fixHeader__logo{
        display: none;
    }
    .l-fixHeader:before{
        margin-left: 240px;
    }
    .c-gnav>.menu-item>a{
        padding: 0.5em 0.6em;
    }
    .c-gnav>.menu-item>a .ttl {
        font-size: 0.9em;
    }
    #content{
        padding: 0;
        display: block;
    }
    #main_content{
        
    }
    .page #content{
        max-width: 100%;
        z-index: -1;
    }
    .page #main_content{
        width: 100%;
    }
    #sidebar{
        background-color: #FFF;
        width: 240px !important;
    }
    #sidebar .sidebar_inner{
        position: -webkit-fixed;
        position: fixed;
        display: flex;
        justify-content: center;
        align-items: center;
        z-index: 100;
        left: 0;
        top: 60vh;
        height: 40vh;
        width: 240px;
    }
    #sidebar .swell-block-button__link{
        width: 100%;
    }
    /* フッター調整　*/
    #before_footer_widget .l-container{
        padding: 0 var(--swl-pad_post_content,0);
        max-width: 100%;
    }
    .-sidebar-on .w-beforeFooter .alignfull, .-sidebar-on .w-beforeFooter .alignwide {
        left: -16px;
        width: calc(100% + 32px);
    }
    .-sidebar-on .l-mainContent {
        width: 100%;
    }
}
/* @media screen and (max-width: 1329px){
    .home .-series .l-header__inner{
        flex-wrap: wrap;
        justify-content: flex-end;
    }
} */
@media screen and (min-width: 960px) and (max-width: 1180px){
    .l-header{
        padding: 16px 0;
    }
    .-series .l-header__inner{
        justify-content: start;
    }
    .w-header.pc_{
        display: none;
    }
    .c-gnav>.menu-item>a .ttl {
        font-size: 0.85em;
    }
    .c-gnav>.menu-item>a {
        padding: 0.5em 0.5em;
    }
}
@media screen and (min-width: 960px) {
    .l-header__logo {
		flex-wrap: nowrap !important;}
}
@media screen and (max-width: 959px){
    #sidebar{
        display: none;
    }
    .l-header__logo {
        padding-left: 16px;
    }
    .-txt .c-headLogo__link{
        font-size: 7vw !important;
    }
    .c-headLogo.-txt{
		background: url(assets/img/nagiah-sp-logo-4.svg) 50% no-repeat;
        background-size: contain;
        width:100%;
        overflow: hidden;
        text-indent: 100%;
        white-space: nowrap;
    }
    .l-header__inner .c-catchphrase {
/*         display: block;
        font-size: 11px;
        position: absolute;
        top: 43px;
        letter-spacing: 3px; */
		display: none;
    }
    .l-header__customBtn.sp_{
        display: none;
    }
  }
  @media screen and (min-width: 960px) and (max-height: 768px){
    .l-header__logo{
        top: 5vh;
        height: 45vh;
    }
}

/* ---------- 共通フッター ---------- */

/* 診療時間テーブル */
.hours_table tr{
    border-bottom: 1px solid var(--color_main);
}
.hours_table th:before{
    content: none !important;
}
.hours_table td{
    color: var(--color_main);
}

/* お支払い方法 */
.payment_way h3.is-style-section_ttl{
    font-size: 1.5em;
    margin-bottom: 1em;
    padding-top: 0.5em;
}
.payment_way h3.is-style-section_ttl:after{
    content: '';
    width: 4em;
    border-bottom: 1px solid #565656;
    display: block;
    margin: 0.5em auto 0;
}
/* ---------- トップページ ---------- */

/* メインビジュアル（SVGに影） */
/*
.mv_copy_img{
    filter: drop-shadow(0px 0px 5px rgba(255, 255, 240, 0.8));
}
*/

/* News */
.top_news h3.is-style-section_ttl{
    font-size: 1.5em;
    line-height: 2;
}
.top_news h3.is-style-section_ttl:after{
    content: '';
    width: 1px;
    height: 100%;
    background:#565656;
    position: absolute;
    right: 0;
}
.top_news .p-postList.-type-simple{
    border-top: none;
}
.top_news .-type-simple .p-postList__link{
    border-bottom: none;
}
.top_news .p-postList__meta{
    font-size: 12px;
    line-height: 1;
    margin: 0;
}

/* 提供している8つのこと */
.offer_block .swell-block-box-menu__item{
    border: #d3c9c6 1px solid !important;
    border-radius: 0.25em;
}
.offer_block .swell-block-box-menu__link{
    flex-direction: row-reverse;
}
.offer_block .swell-block-box-menu__figure{
    margin-right: 0 !important;
    margin-left: 1em;
}
.offer_block .swell-block-box-menu__text{
    font-size: 0.8em;
}

/* 診療メニュー */
.menu_block{
    padding: 1em;
    background: #fff;
    transition: 0.3s all ease-in-out;
}
.menu_block:hover{
    background: #cff2ff;
}
/*.menu_block img{
    max-width: 120px;
}
*/
.menu_block p{
    font-size: 0.9em;
}
.menu_block h4.is-style-section_ttl:after{
    content: '';
    width: 4em;
    border-bottom: 1px solid #565656;
    display: block;
    margin: 1em auto 0;
}
@media screen and (max-width: 959px){
    .menu_block{
        padding: 0.5em;
    }
    /*.menu_block img{
        max-width: 77px;
    }*/
}

/* アクセス */
.access_block h4.is-style-section_ttl{
    font-size: 1.5em;
    margin: 2em auto 1em;
}
.access_block h4.is-style-section_ttl:before, .access_block h4.is-style-section_ttl:after{
    content: '* *';
    display: inline-block;
    vertical-align: middle;
    margin: 0.1em 0.25em 0;
}


/* 診療予約 */
/*.post_content .ttl_reserve:before, .post_content .ttl_reserve:after{
    content: '';
    width: 1em;
    height: 1em;
    border-radius: 0.5em;
    background-color: #565656;
    display: inline-block;
    vertical-align: middle;
    margin: 0 0.25em 0.1em;
}
*/


/* SNS */
.ttl_social_fb:before{
    content: "";
    background-color: var(--color_main);
    display: inline-block;
    height: 1.8em;
    width: 1.8em;
    margin-right: 0.5em;
    -webkit-mask: url("./img/facebook-brands.svg");
    mask: url("./img/facebook-brands.svg");
    -webkit-mask-size: cover;
    mask-size: cover;
    vertical-align: -0.5em;
}
.ttl_social_ins:before{
    content: "";
    background-color: var(--color_main);
    display: inline-block;
    height: 1.8em;
    width: 1.6em;
    margin-right: 0.5em;
    -webkit-mask: url("./img/instagram-brands.svg");
    mask: url("./img/instagram-brands.svg");
    -webkit-mask-size: cover;
    mask-size: cover;
    vertical-align: -0.5em;
}
/* ---------- 共通パーツ ---------- */

/* ヘッダー */
/*
.l-header__logo{
    flex-grow: 3;
}
*/
/*
.w-header{
    background-color: #FFF;
    padding: 0 2em;
}
*/


/* .c-iconBtn{
    background-color: transparent;
} */
.c-iconBtn__icon:before{
    /* color: var(--color_main); */
    font-weight: bold;
}
.c-iconBtn__label {
    font-size: 11px;
    font-weight: bold;
}
.head_tel{
    color: #555;
}
.head_tel_desc{
    text-align: right;
    margin-bottom: 0;
}
ul.head_tel_inner{
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    list-style: none;
    padding-left: 0;
}
.head_tel_icon i{
    font-size: 1.5em;
    transform: rotate(-45deg);
}
.head_tel_note{
    font-size: 0.75em;
    line-height: 1.3;
    padding-left: 1em;
    font-weight: bold;
}
li.head_tel_tel{
    padding-left: 0.5em;
    font-size: 1.4em;
    font-weight: bold;
    margin: 0;
    line-height: 1;
}
.head_tel_tel a{
    text-decoration: none;
    color: #555;
}

/* スマホ用固定フッター */
#fix_bottom_menu{
    bottom: -70px;
}
#fix_bottom_menu .menu_list{
    padding: 0;
	height: 70px;
	flex-direction: row-reverse;
}
#fix_bottom_menu span {
	font-size: 15px;
    font-weight: bold;
}
#fix_bottom_menu .menu-item a{
    padding: 8px 0;
}
#fix_bottom_menu .menu_list li{
    border-right: 1px solid #fff;
	border-left: 1px solid #fff;
}
#fix_bottom_menu .menu_list li:nth-child(1){
    border: none;
}
#fix_bottom_menu .menu_list li:last-child{
    border: none;
}

/* 個別に色変更
.spf_reserv{
    background-color: #82bedc;
}
.spf_tel{
    background-color:#a5d24d;
}
.spf_access{
    background-color:#af8a66;
}
*/


/* スマホ用メニュー */
.p-spMenu__inner{
    padding-top: 56px;
}
.p-spMenu__inner::before {
	background-color: #ffffff;
}
.p-spMenu__body{
    padding: 0 8vw 10vw;
}
.p-spMenu__nav{
    margin-top: 0;
}
.p-spMenu__logo a{
    font-size: 1.25em !important;
    padding: 0 0 0.75em 0;
}
.p-spMenu__logo a:hover{
    color: #fff !important;
    background: #005caf !important;
}
.p-spMenu__logo a:before{
    content: none;
}
.p-spMenu__logo:before{
    content: '市原市の動物病院';
    font-size: 0.75em;
    width: 100%;
    display: block;
    margin-bottom: 0.25em;
}
.c-listMenu a{
    border-bottom:1px dashed var(--color_border);
}
.c-listMenu a:hover{
    color: #fff;
    background: #005caf;
}
.c-gnav .sub-menu a:before, .c-listMenu a:before {
    left: auto;
    right: 2px;
}
.c-listMenu .children a:before, .c-listMenu .sub-menu a:before {
    left: auto;
    right: 2px;
}
.c-listMenu .children ul a:before, .c-listMenu .sub-menu ul a:before {
    left: auto;
    right: 2px;
}

.spMenu_sns{
	font-size: 3em;
}
/*.spMenu_sns{
    position: absolute;
    top: -0.25em;
    right: 40px;
    font-size: 2em;
    gap: 0 !important;
}*/
.c-widget__title.-spmenu{
    display: none;
}
[data-spmenu=closed] .p-spMenu {
    transition-delay: 0.3s;
}

/* 背景 */
/*.bg_tooth{
    background: url(assets/img/bg_tooth.png) 50% 50% no-repeat;
    background-size: contain;
}*/


/* ボタン */
.btn-white a{
    background: #FFF;
    color: #565656;
}
.btn-white a:hover{
    background: var(--color_main);
    color: #FFF;
}
.is-style-btn_normal a:hover{
    background: #FFF;
    color: var(--color_main);
    transition: 0.3s;
}
.btn-cta a{
    font-size: 1.2em;
    width: 100%;
}
.footer-button-tel a{
    background: transparent;
    color: #555;
    border-top: dashed 1px #555;
    border-bottom: dashed 1px #555;
    font-size: 1.5em;
}
.footer-button-tel a span:first-child{
    font-weight: normal;
}

/* 見出し */
h1.c-pageTitle{
    font-size: 2em;
    font-weight: normal;
}
h2.is-style-default{
    font-size: 1.5em;
}
h2.is-style-section_ttl{
    font-size: 2.2em;
}
h2.is-style-section_ttl span.ttl_sub{
    font-size: 0.7em;
    letter-spacing: 0.1em;
    display: block;
    margin-top: 0.25em;
}

h3.is-style-section_ttl{
    font-size: 1.8em;
    letter-spacing: 0.02em;
}

/* フォーム */
.contact_form span.form_required{
	display:inline-block;
	margin-left: 1em;
	font-size:0.75em;
	padding:0.25em 1em;
	background-color: var(--color_main);
	color: #ffffff;
	position: absolute;
	right: 1em;
}
.post_content .td_to_th_.contact_form tbody tr>:first-child {
    padding-right: 4em;
}
.gcal-sunday a, .gcal-sunday span{color: #f00 !important;}
.gcal-saturday a, .gcal-saturday span{color: #0af !important;}
.special-holiday a, .special-holiday span{color: #f00 !important;}
.jp-holiday a, .jp-holiday span{color: #f00 !important;}
.mwform-tel-field input[type="text"] {width: 70px !important;}

.submit_button{
    background: var(--color_main);
    border: 1px solid var(--color_main);
    color: #fff;
    border-radius: 0.25em;
    display: block;
    letter-spacing: 0.1em;
    line-height: 1.5;
    margin: 1.5em auto 0.5em;
    padding: 0.5em;
    position: relative;
    text-decoration: none;
    width: 300px;
}
.submit_button:hover{
    background: #FFF;
    border: 1px solid var(--color_main);
    color: var(--color_main);
}
input[name="submitBack"]{
    background: #FFF;
    border: 1px solid var(--color_main);
    color: var(--color_main);
    margin-top: 0;
}
input[name="submitBack"]:hover{
    background: #dedede;
    border: 1px solid var(--color_main);
    color: var(--color_main);
}

@media screen and (max-width: 598px) {
	.top-schedule-balloon {
           writing-mode: vertical-lr;
	}
}

/* フローティングボタン */
.float_btn{
    position: fixed;
    right: 0;
    top: 20%;
    z-index: 99999;
}
.float_btn a{
    -ms-writing-mode: tb-rl;
	-webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    text-orientation: upright;
    border-radius: 4px 0 0 4px;
}
.float_btn a span{
    text-align: center;
	letter-spacing: 0.2em;
}
.swell-block-button .__icon:not(.-right) {
	margin-left: .1em;
}
@media screen and (max-width: 598px) {
    .float_btn{
        display: none;
    }
}