/*
Theme Name: cocoroneclinicwp
Theme URI: https://cocorone-clinic.com
Description: cocoroneclinicwp記事
Version: 1.0
Author: cocoroneclinicwp
Author URI: https://cocorone-clinic.com
*/

body{
  line-height: 180%;
  font-size: 16px;
}

#header {
  position: absolute;
  width: 92%;
  left: 4%;
  top: 0;
  background: rgba(255,255,255,.9);
  border-bottom-left-radius: 15px;
  border-bottom-right-radius: 15px;
  z-index: 4;
  box-shadow: 0px 5px 5px rgba(0,0,0,0.1);
}

#header .con1 {
  box-sizing: border-box;
  padding: 15px 40px;
  width: 100%;
}

.hd_flex{
  display: flex;
  justify-content: space-between;
  align-items: center;
}

#logo {
  position: relative;
  width: 300px;
}

#logo1ft{
  width: 300px;
}

#logo img,
#logo1ft img{
  height: auto;
  width: 100%;
  padding: 0;
  display: block;
  vertical-align: bottom;
}

#header.m_fixed {
  position: fixed;
}

.hd_info{
  flex: .9;
}

.hd_flex2{
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

.search-box {
  position: relative;
  width: 200px;
}

.search-box input {
  width: 100%;
  padding: 10px 0 10px 40px;
  box-sizing: border-box;
  font-size: 15px;
  background-color: #ffffff;
  border: 1px solid #dddddd;
  border-radius: 5px;
}

.search-box::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 16px;
  height: 17px;
  background: url(images/i_search.png) no-repeat center center;
  background-size: 16px;
}

.hd_info .tel{
  width: 180px;
  margin: 0 15px;
}

.sp_cv .tel{
  width: 90%;
  margin: 0 10px;
  text-align: center;
}

.hd_info .tel p,
.ft_ct .tel p,
.sp_cv .tel p{
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 1px;
  line-height: 20px;
}

.hd_info .tel a,
.ft_ct .tel a,
.sp_cv .tel a{
  font-family: "Hina Mincho", serif;
  font-weight: 500;
}

.hd_info .tel a{
  display: block;
  padding: 2px 0 2px 25px;
  background: url(images/i_tel.png) no-repeat left center;
  background-size: 18px;
  font-size: 24px;
  line-height: 30px;
}

.ft_ct .tel a,
.sp_cv .tel a{
  display: inline-block;
  padding: 2px 40px 2px 40px;
  background: url(images/i_tel.png) no-repeat 15px center;
  background-size: 20px;
  font-size: 28px;
  line-height: 30px;
  text-align: center;
}

.ft_ct .tel,
.ft_ct .btn_reserve,
.ft_ct .line_reserve{
  width: 32.493%;
}

.ft_ct .tel{
  background: #ffffff;
  border-radius: 5px;
  text-align: center;
  padding-top: 8px;
}

.hd_info .btn_reserve{
  width: 150px;
}

.hd_info .btn_reserve a,
.ft_ct .btn_reserve a,
.sp_cv .btn_reserve a{
  display: block;
  font-weight: bold;
  color: #ffffff;
  border-radius: 5px;
  text-align: center;
  -webkit-transition: all .5s ease;
	transition: all .5s ease;
}

.hd_info .btn_reserve a{
  padding: 10px 10px 10px 35px;
  background:#a8c37c url(images/i_calendar.png) no-repeat 10px center;
  background-size: 20px;
}

.ft_ct .btn_reserve a,
.sp_cv .btn_reserve a{
  padding: 22px 4px 22px 40px;
  background: #a8c37c url(images/i_calendar.png) no-repeat 15px center;
  background-size: 22px;
}
 
.hd_info .btn_reserve a:hover{
  background:#7aa03c url(images/i_calendar.png) no-repeat 10px center;
  background-size: 20px;
}

.ft_ct .btn_reserve a:hover,
.sp_cv .btn_reserve a:hover{
  background:#7aa03c url(images/i_calendar.png) no-repeat 15px center;
  background-size: 22px;
}

.ft_ct .line_reserve a,
.sp_cv .line_reserve a{
  display: block;
  font-weight: bold;
  color: #ffffff;
  border-radius: 5px;
  text-align: center;
  -webkit-transition: all .5s ease;
	transition: all .5s ease;
}

.ft_ct .line_reserve a,
.sp_cv .line_reserve a{
  padding: 22px 4px 22px 40px;
  background: #22bd61 url(images/line_brand_icon.png) no-repeat 15px center;
  background-size: 26px;
}

.ft_ct .line_reserve a:hover,
.sp_cv .line_reserve a:hover{
  background:#189f4f url(images/line_brand_icon.png) no-repeat 15px center;
  background-size: 26px;
}

/*フッタ*/

.map{
  width: 100%;
}

.map iframe{
  width: 100%;
  height: 380px;
}

footer{
  background: url(images/mv1.jpg) no-repeat center center;
  background-size: cover;
  width: 100%;
  position: relative;
}

footer .con1 {
  width: 92%;
}

.ft_info{
  position: relative;
  z-index: 2;
  background: rgba(255,255,255,.9);
  padding: 40px;
  box-sizing: border-box;
  border-top-left-radius: 15px;
  border-top-right-radius: 15px;
}

.ft_fl{
  display: flex;
  justify-content: flex-start;
  align-items: center;
  padding-bottom: 40px;
}

.ft_fl h2{
  padding-left: 30px;
}

.ft_clm{
  width: 40%;
  float: left;
}

.ft_bx{
  padding-left: 45%;
}

.ft_ct{
  display: flex;
  justify-content: space-between;
  align-items: stretch;
}

.ft_txt{
  padding-top: 30px;
}

.ft_txt p{
  padding-left: 35px;
}

.ft_txt p.i_add{
  background: url(images/i_add.png) no-repeat left center;
  background-size: 20px;
  padding-top: 5px;
  padding-bottom: 5px;
}

.ft_nav{
  padding-top: 30px;
  border-top: 1px solid #dddddd;
  text-align: center;
}

.ft_nav li{
  display: inline-block;
  vertical-align: middle;
  padding: 0 15px;
}

.ft_nav li a{
  font-weight: 500;
}

.ft_nav .sub-menu{
  display: none;
}

#copyright{
  text-align: center;
  padding-top: 20px;
  font-size: 13px;
  line-height: 20px;
  color: #b7b7b7;
}

/*#copyright span{
  color: #c1c1c1;
  padding: 0 15px;
}*/

#copyright a{
  color: #c1c1c1;
}


/*診療時間TABLE*/

.timetable table{
  border: 1px solid #dddddd;
  font-size: 15px;
  padding: 0;
  margin: 0 0 10px;
}

.timetable table th,
.timetable table td{
  font-size: 15px;
  line-height: 120%;
  padding: 10px 5px;
  text-align: center;
}

.timetable table th{
  background: #faf6ec;
}

.timetable table th.cel1{
  width: 120px;
}

.timetable table td{
  background: #ffffff;
  border-top: 1px solid #dddddd;
}

.timetable table td span{
  font-size: 17px;
  font-weight: bold;
}

.sp_cv .timetable{
  margin-top: 20px;
}


/*メインビジュアル*/

.mainvl {
  position: relative;
  /*height: 620px;*/
  width: 100%;
  height: 80vh;
  min-height: 680px;
}

.mainvl::before {
  content: '';
  position: absolute;
  background: url(images/mv_filter.png) no-repeat left top;
  background-size: 765px;
  left: -15px;
  top: -10px;
  width: 100%;
  height: 100%;
  z-index: 2;
}

.subvl {
  position: relative;
  width: 100%;
  height: 250px;
  background: url(images/mv1.jpg) no-repeat left top;
  background-size: cover;
}

.subvl::before {
  content: '';
  position: absolute;
  background: url(images/mv_filter.png) no-repeat left top;
  background-size: 500px;
  left: -15px;
  bottom: -50px;
  width: 400px;
  height: 400%;
  z-index: 2;
}

.mv_ad{
  position: absolute;
  bottom: -50px;
  left: 44%;
  width: 420px;
  z-index: 2;
}

.mainimg {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  overflow: hidden;
}

.mainimg .slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 1.5s ease-in-out;
}

.mainimg .slide.active3 {
  opacity: 1;
}

.mainbox{
  width: 40%;
  position: absolute;
  left: 10%;
  top: 50%;
  transform: translateY(-30%);
  z-index: 3;
}

.mainbox h2 {
  writing-mode: vertical-rl;
  text-orientation: upright;
  white-space: pre;
  font-family: "メイリオ", Meiryo, sans-serif;
  font-size: 30px;
  font-weight: bold;
  letter-spacing: 3px;
  line-height: 55px;
  color: #ffffff;
  text-shadow: 0px 0px 5px rgba(0,0,0,0.1);
}

.mv_info{
  position: absolute;
  right: 5%;
  bottom: 0;
  background: rgba(255,255,255,.9);
  width: 470px;
  box-sizing: border-box;
  border-top-left-radius: 15px;
  border-top-right-radius: 15px;
  z-index: 3;
}

.mv_inr{
  padding: 25px;
}

/*top*/

.news_imp{
  border-radius: 10px;
  border: solid 1px #f3dc95;
  background: #faf6ec;
  box-sizing: border-box;
  position: relative;
  padding: 25px;
}

.news_imp h3{
  padding-right: 100px;
}

.news_imp .date{
  position: absolute;
  right: 25px;
  top: 25px;
}


.ttl{
  padding-top: 30px;
  margin-bottom: 30px;
  position: relative;
  width: 90px;
}

.ttl2{
  display: inline-block;
  padding: 20px 30px;
  position: relative;
}

.ttl h2,
.ttl2 h2{
  font-family: "メイリオ", Meiryo, sans-serif;
  font-size: 30px;
  font-weight: bold;
  letter-spacing: 2px;
}

.ttl h2{
  writing-mode: vertical-rl;
  text-orientation: upright;
  white-space: pre;
}

.ttl h2 span{
  writing-mode: vertical-rl;
  text-orientation: upright;
  white-space: pre;
  font-family: "メイリオ", Meiryo, sans-serif;
  font-size: 22px;
  font-weight: bold;
  line-height: 30px;
  letter-spacing: 1px;
}

.ttl2 h2{
  
}

.ttl .en,
.ttl2 .en{
  font-family: "Alex Brush", cursive;
  font-size: 45px;
  color: #a9c37d;
  display: inline-block;
  transform: rotate(-15deg);
  position: absolute;
}

.ttl .en{
  top: -20px;
  left: -40px;
}

.ttl2 .en{
  top: -15px;
  left: -40px;
}

.ttl_clm{
  position: absolute;
  left: 0;
  top: 70px;
}

#column .ttl_clm{
  top: 0px;
}

.ttl_clm2{
  text-align: center;
  margin-bottom: 30px;
}

.con_clm{
  padding-left: 90px;
}

#philosophy .con_clm{
  padding-top: 50px;
  padding-bottom: 30px;
}

#shiryo2 .con_clm{
  min-height: 400px;
}

.con_list li{
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 60px;
  padding-bottom: 60px;
  border-bottom: 1px solid #dddddd;
}

.con_list li:nth-child(even){
  flex-direction : row-reverse;
}

.con_list li:last-child{
  margin-bottom: 0px;
  border-bottom: none;
}

.con_list2 li{
  padding-bottom: 60px;
}

.con_list2 li:last-child{
  padding-bottom: 0px;
}

.li_txt{
  flex: .9;
}

.li_img{
  width: 450px;
}

.li_img img{
  border-radius: 10px;
}

.li_ttl{
  padding: 10px 0 20px;
  margin-bottom: 20px;
}

.btn,
.more_btn{
  min-width: 300px!important;
  display: inline-block;
}

.btn a,
.pagenav li a,
.more_btn{
  border: 1px solid #7aa03c;
  color: #7aa03c;
  border-radius: 100px;
  font-size: 16px!important;
  font-weight: 500;
  text-align: center;
  padding: 10px 20px!important;
  -webkit-transition: all .5s ease;
	transition: all .5s ease;
}

.btn a,
.pagenav li a{
  display: block;
}

.btn a:hover,
.pagenav li a:hover,
.more_btn:hover{
  color: #ffffff;
  background: #7aa03c;
}

.tag_box{
  border-radius: 10px;
}

.tag_box h3{
  color: #ffffff;
  text-align: center;
  padding: 10px 10px;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
}

.inr_box{
  padding: 15px 20px;
}

.inr_box a,
.inr_box span,
.cate a,
.cate span,
.tag_box2 a,
.tag_box2 span{
  font-size: 15px;
  font-weight: 500;
  line-height: 22px;
  padding: 2px 10px;
  margin-right: 8px;
  border-radius: 30px;
  display: inline-block;
}

.inr_box a,
.inr_box span{
  margin: 5px 2px;
}

.inr_box span{
  color: #333333;
}

.nayami{
  border: 1px solid #a9c37e;
}

.nayami h3{
  background: #a9c37e;
}

.nayami a,
.nayami span,
.cate a,
.cate span{
  background: #f2f2f2;
}

.nayami a,
.cate a,
.cate span{
  color: #7aa03c;
}

.shikkan,
.editor{
  border: 1px solid #c3b37f;
}

.shikkan h3,
.editor h3{
  background: #c3b37f;
}

.shikkan a,
.shikkan span,
.tag_box2 a,
.tag_box2 span{
  background: #f8f4ec;
}

.tag_box2 a,
.shikkan a{
  color: #eca826;
}

.ad_2,
.ad_3,
.ad_4,
.ad_5{
  position: absolute;
  z-index: 1;
}

.ad_2{
  width: 440px;
  right: -120px;
  top: 0px;
}

.ad_3{
  width: 420px;
  left: -100px;
  top: 600px;
}

.ad_4{
  width: 670px;
  left: -150px;
  bottom: -100px;
}

.ad_5{
  width: 540px;
  right: -100px;
  bottom: -100px;
}

.profile_flex{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.profile_img{
  width: 280px;
  border-radius: 10px;
  overflow: hidden;
}

.profile_img2{
  width: 200px;
  border-radius: 10px;
  overflow: hidden;
}

.profile_flex dl,
.profile_txt{
  flex: .9;
}

.profile_txt{
  padding-top: 10px;
}

.profile_flex dt,
.profile_flex dd{
  padding-top: 20px;
}

.profile_flex dt:first-of-type,
.profile_flex dd:first-of-type{
  padding-top: 0px;
}

.profile_flex dt{
  width: 100px;
  text-align: center;
  font-size: 1.1rem;
  float: left;
  clear: left;
  font-weight: bold;
}

.profile_flex dd{
  padding-left: 100px;
}

.profile_flex li{
  padding-left: 15px;
  position: relative;
}

.profile_flex li::before{
  content: '・';
  position: absolute;
  left: 0;
  top: 0;
}

.news_list li{
  border-top: 1px solid #dddddd;
  padding: 20px 0;
}

.news_list li:last-child{
  border-bottom: 1px solid #dddddd;
}

.news_list h3{
  padding-top: 5px;
  font-size: 16px;
}

.date{
  color: #7a7a7a;
  font-size: 15px;
}

.catearea1{
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.catearea1 .date{
  width: 100px;
}

.news_flex{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.news_flex h3{
  padding-top: 0px;
  flex: 1;
}

.ac_flex{
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.ac_map{
  width: 370px;
}

.ac_map img{
  border-radius: 10px;
  border: 1px solid #dddddd;
  margin-bottom: 20px;
}

.ac_txt{
  flex: .9;
}

/*page*/

.postbtn{
  padding-top: 40px;
  border-top: 1px solid #dddddd;
}

.page-numbers {
  display: flex;
  gap: 10px;
  justify-content: center;
}

.page-numbers li {
  list-style: none;
}

.page-numbers a,
.page-numbers span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 50%; 
  border: 1px solid #7aa03c;
  text-decoration: none;
  font-size: 14px;
  color: #7aa03c;
  transition: 0.3s;
}

.page-numbers .current {
  background: #7aa03c;
  color: #fff;
  border-color: #7aa03c;
}

.page-numbers a:hover {
  background: #fff;
  color: #7aa03c;
  border-color: #f2f2f2;
}

.page-numbers .prev,
.page-numbers .next {
  font-size: 16px;
}


/*archive　single*/

.singlebox{
  padding: 20px 0 40px;
}

.archive{
  padding: 20px 0 0px;
  width: 250px;
}

.widget{
  
}

.widget_title{
  font-size: 18px;
  font-weight: 500;
}

.archive label{
  display: none;
}

.widget select{
  
}

.pagenav{
  padding: 30px 0;
  position: relative;
}

.pagenav ul{
  display:-webkit-box;
  display:-moz-box;
  display:-ms-flexbox;
  display:-webkit-flex;
  display:-moz-flex;
  display:flex;
  -webkit-box-lines:multiple;
  -moz-box-lines:multiple;
  -webkit-flex-wrap:wrap;
  -moz-flex-wrap:wrap;
  -ms-flex-wrap:wrap;
  flex-wrap:wrap;
  justify-content: flex-start;
}

.pagenav li{
  width: 23%;
  margin: 10px 1%;
  box-sizing: border-box;
}

.pagenav li a{

}

.singlebox p,
.postconts p{
  font-size: 16px;
  font-weight: 400;
  line-height: 30px;
}

.singlebox h2,
.postconts h2{
  font-size: 20px;
  font-weight: 700;
  line-height: 36px;
  letter-spacing: 1px;
}

.singlebox h3,
.postconts h3{
  font-size: 20px;
  font-weight: 700;
  line-height: 36px;
  letter-spacing: 1px;
}

.singlebox h4,
.postconts h4{
  font-size: 18px;
  font-weight: 700;
  line-height: 40px;
}

.singlebox h5,
.postconts h5{
  font-size: 16px;
  font-weight: 700;
}

.editor{
  max-width: 700px;
  margin: 0 auto;
}

.related-list {
  position: relative;
}

.related-list.is-closed {
  max-height: 500px; 
  overflow: hidden;
}

.related-list.is-closed::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 120px;
  background: linear-gradient(to bottom, rgba(255,255,255,0), #fff);
}

.more_btn_wrap {
  text-align: center;
  margin-top: 20px;
}

.more_btn{
  cursor: pointer;
}

.tag_box2{
  /*display: flex;
  justify-content: flex-start;
  align-items: center;*/
}

.tag_box2 p{
  display: inline-block;
}

.fix_btn{
  display: none;
}

/********************************************
 * 共通要素
 ********************************************/

.shadow {
  filter: drop-shadow(0px 0px 8px rgba(0,0,0,0.1));
}

.t_inline{
  display: inline-block;
}


.line1{
  border-top: 1px solid #dddddd;
}

.txt_s{
  font-size: 13px;
  line-height: 20px;
}

.txt_ns{
  font-size: 15px;
  line-height: 28px;
}

.txt_n,
.postconts h4,
.postconts h5{
  font-size: 20px;
  line-height: 32px;
  font-weight: 700;
}

.txt_m,
.postconts h3{
  font-size: 24px;
  line-height: 40px;
  font-weight: 700;
}

.txt_b{
  font-size: 34px;
  line-height: 45px;
  letter-spacing: 1px;
  font-weight: 700;
}

.txt_c{
  text-align: center;
}

.txt_r{
  text-align: right;
}

.txt_l{
  text-align: left!important;
}

.mgat{
  margin: 0 auto;
}

.wid_1{
  width: 220px;
}

.wid_2{
  width: 300px;
}

.pc_none{
	display:none;
}

.pdb_no{
  padding-bottom: 0;
}


@media screen and (max-width: 1300px) {
.ttl .en{
  top: -30px;
  left: -20px;
}
  
.ft_ct .tel a{
  padding: 2px 7px 2px 25px;
  background: url(images/i_tel.png) no-repeat 6px center;
  background-size: 14px;
  font-size: 24px;
  line-height: 30px;
  text-align: left;
}
}

.youtube_center .wp-block-embed__wrapper{
	text-align:center;
}