@charset "utf-8";

/* ================================
   フローティングメニュー
.floating_parent{
	display: block;
	width: 80%;
	position: fixed;
	right: 0;
	bottom: 0;
	z-index: 999;
	text-align: center;
	padding: 0;
	background-color: rgba(255,255,255,0.7);
	height: 150px;
	pointer-events: auto; /* 下の要素に通さない 
}
.floating_wrap{
	width: 980px;
	margin: 0 auto;
	padding-top: 10px;
	text-align: center;
}
.floating_switch{
	margin: 5px auto 15px auto;
	text-align: center;
}

   ================================ */

.floating_parent{
  position: fixed;
  bottom: 0;
  z-index: 999;
  background-color: rgba(255,255,255,0.7);
  pointer-events: auto;
}

/* #content と同じ基準幅 */
.floating_wrap{
  width: 980px;
  margin: 0 auto;
  padding: 10px 0;
  text-align: center; /* ← 中央基準はここ */
}

/* innerは基準を作らない */
.floating_inner{
  width: 100%;
}

/* 上 */
.floating_top img{
  display: block;
  margin: 0 auto;
  max-width: 100%;
  height: auto;
}

/* テキスト */
.floating_text{
  margin: 6px 0;
  font-size: 14px;
  line-height: 1.4;
}

/* 下 */
.floating_bottom{
  display: flex;
  justify-content: center;
  gap: 20px;
}

.floating_bottom a{
  display: block;
}

.floating_bottom img{
  display: block;
  max-width: 100%;
  height: auto;
}

/* 閉じる */
.floating_close{
  position: absolute;
  top: 5%;
  right: -12px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: none;
  background: #000;
  color: #fff;
  font-size: 18px;
  cursor: pointer;
}

.floating_wrap {
  width: 100%; /* 980px固定はやめる */
  margin: 0 auto;
  padding: 10px 0;
  text-align: center; /* ここで中央揃え */
}

.floating_inner {
  max-width: 980px; /* ここで幅制限 */
  margin: 0 auto;
}

.floating_top img {
  display: block;
  margin: 0 auto;
  max-width: 100%;
  height: auto;/*
  margin-bottom: 10px;*/
}

.floating_bottom {
  display: flex;
  justify-content: center;
  gap: 20px;
  max-width: 980px;
  margin: 0 auto;
}

.floating_bottom a {
  display: block;
}




/* ================================
   アコーディオンメニュー
   ================================ */
.accordion01 {
	margin: 4rem auto;
	max-width: 80%;
	z-index: 1000;
}

.toggle {
	display: none;
}

.faq {
	position: relative;
	margin-bottom: 1rem;
}

/* Q / A 共通 */
.question,
.anser {
	transform: translateZ(0);
	transition: all 0.3s;
	font-weight: 500;
	font-style: normal;
	font-size: 1.2em;
	
}

/* ================================
   Q（質問）
   ================================ */
.question {
	border: solid 0px #999;
	background: #e5f8f7;
	display: block;
	color: #333;
	padding: 1rem 2.2rem 1rem 3.2rem;
	position: relative;
}

.question > span {
	font-family: "Zen Maru Gothic", sans-serif;
	font-size: 2.2em;
	color: #42c2af;
	font-weight: 900;
	position: absolute;
	left: 0.8rem;
	top: 50%;
	transform: translateY(-50%);
	line-height: 1;
	pointer-events: none;
}

/* ================================
   A（回答）
   ================================ */
.anser {
	max-height: 0;
	overflow: hidden;
}

.anser div {
	margin: 0;
	padding: 2rem 1rem 2rem 3.2rem;
	line-height: 1.8;
	position: relative;
}

.anser div > span {
	font-family: "Zen Maru Gothic", sans-serif;
	display: inline-block;
	font-size: 2em;
	color: #ff7171;
	font-weight: 900;
	line-height: 1;
	padding-left: 1rem;
	width: 2.2rem;
	margin-left: -3.2rem;
	vertical-align: top;
}

/* ================================
   開閉アイコン (+ と ×)
   ================================ */
.question:after,
.question:before {
	content: "";
	position: absolute;
	right: 1.25rem;
	top: 0;
	bottom: 0;
	margin: auto;
	width: 2px;
	height: 0.75rem;
	background-color: #999;
	transition: all 0.3s;
}

.question:after {
	transform: rotate(90deg);
}

.toggle:checked + .question + .anser {
	max-height: 500px;
	transition: all 1.5s;
}

.toggle:checked + .question:before {
	transform: rotate(90deg) !important;
}

/* ================================
   アコーディオン見出し
   ================================ */
.accordion-title {
	text-align: center;
	font-size: 2em;
	margin-bottom: 20px;
	color: #4dbbaa;
	font-family: "Zen Maru Gothic", sans-serif;
	font-weight: 700;
	font-style: normal;
}

/* ================================
   フォントクラス
   ================================ */
.zen-maru-gothic-regular { font-weight: 400; font-family: "Zen Maru Gothic", sans-serif; }
.zen-maru-gothic-medium  { font-weight: 500; font-family: "Zen Maru Gothic", sans-serif; }
.zen-maru-gothic-bold    { font-weight: 700; font-family: "Zen Maru Gothic", sans-serif; }
.zen-maru-gothic-black   { font-weight: 900; font-family: "Zen Maru Gothic", sans-serif; }


/*診療報酬イメージ*/
 
.text05 {
    line-height: 1.263;
    border-left: 5px solid #a5dbd9;
    padding-left: 10px;
    margin-bottom: 20px;
    margin-left: auto;
    margin-right: auto;
    width: 95%;
    line-height: 1.6;
}

.shinryoubox{
    align-items: center;
    width: 90%;
	margin-left:auto;
    margin-right: auto;
    margin-bottom: 20px;
    padding: 3%;
	background-color: #e3f3f1;
}
.shonryobox p{
	font-size: 90%;
}

.shinryo-img{
    width: 97%;
    margin-left:auto;
    margin-right: auto;
    padding: 2%;
	background-color: #fff;
}

.shinryo-fl{
	display: flex;
    padding: 1%;
    justify-content: space-between;
    margin-left:auto;
    margin-right: auto;
}

.shinryo-img01{
	width: 35%;
}

.shinryo-img02{
    width: 65%;
	
}
.shinryo-img02 img{
    width: 100%;
		
}

.titlef04 {
    font-size: 110%;
    font-weight: 700;
    color: #000;
    text-align: center;
    background-color: #e0e0e0;
    margin-bottom: 10px;
	align-items: center;
    padding: 4px;
    margin-left: 20%;
    margin-right: 20%;
	
}

/*注釈*/
.annotation{
    font-size: 84.7%;
    line-height: 1.5;

}

/* ×で閉じたら完全に非表示 */
body.floating-killed .floating_parent,
body.floating-killed #floating-banner {
    display: none !important;
    visibility: hidden !important;
}

