@charset "utf-8";
/* CSS Document */

.treatment-cards {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  background: #f7f3ed; /* ベージュ背景 */
  padding: 15px;
  max-width: 870px;
  margin: auto;
  justify-content: space-between;
  box-sizing: border-box;
}

/* 一般カード（部位＋画像＋価格） */
.treatment-card {
  background: white;
  border: 1px solid #d5d0c2;
  border-radius: 12px;
  display: flex;
  align-items: center;
  padding: 10px 15px 10px 15px;
  box-shadow: 0 2px 5px rgba(0,0,0,0.05);
  width: calc(50% - 10px);
  box-sizing: border-box;
	flex-wrap: wrap; /* これも追加すると中で改行可能 */
}

.card-text-fnone {
  flex-basis: 100%;
  width: 100%;
  display: block;
  font-size: 14px;
  line-height: 1.6;
  margin-top: 8px;
}

/* 内服薬カード（横幅100%・テキスト中心） */
.treatment-card.long {
  /*flex-direction: column;*/
display: flex;
align-items: flex-start;
width: 100%;
border: none;
background-color: none;
}

.treatment-card-long {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 1em;
  width: 100%;
  margin: 0 auto;
  border-top:1px dashed #989898;
}
/*白枠背景*/
.treatment-card-long_bk {
  display: flex;
  width: 100%;
 background: white;
  border: 1px solid #d5d0c2;
  border-radius: 12px;
  align-items: center;
  padding: 10px 15px 10px 15px;
  box-shadow: 0 2px 5px rgba(0,0,0,0.05);
	
}



.card-image2 img {
  width: 311px;
  height: auto;
	margin: 0 10px 0 10px;
}

.card-text2 {
  flex: 1;
}

.ruby-part2 {
font-size: 1.5rem;
font-weight: 700;
color: #8e2c57;
margin-bottom: 20px;
margin-top: 5px;
font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝",'Noto Serif JP', serif;
}

.price-line-wrap {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  flex-wrap: wrap;
}

.bubble-note {
  background-color: #8e2c57;
	color: #FFFFFF;
  padding: 10px;
  border-radius: 20px;
  font-size: 14px;
  white-space: nowrap;
	text-align: center;
	line-height: 20px;
}
/*吹き出し文字の改行*/
.br_toning-price{
	display: block;
}
/*吹き出し*/
.balloon-price-set {
    display: flex;
    align-items: center;
    position: relative;
    max-width: 300px;
    /*margin-left: 15px;*/
    padding: 0.5em 1.2em;
    border-radius: 20px;
	/*background: #F5E0E1;*/
	color:#864052;
	background-color: #9A4E61;
    /*background-color: #8e2c57;*/
    color: #FFFFFF;
}
.balloon-price-set::before {
    position: absolute;
    right: -9px;
    width: 20px;
	top:18px;
    height: 30px;
	margin-bottom: 5px;
	background-color: #9A4E61;
	/*background: #F5E0E1;*/
    /*background-color: #8e2c57;*/
    clip-path: polygon(0 0, 100% 50%, 0 100%);
    content: '';
}
.price-hosokulink{
	font-size: 14px;
	text-align: right;
	margin-top: 10px;
}
.price-info {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.price-2 {
  margin: 0;
  font-size: 19px;
  line-height: 20px;
  color: #8e2c57;
}
.price-3 {
  margin: 0;
  font-size: 19px;
  line-height: 20px;
  color: #8e2c57;
	text-align: right;
}
.price-4 {
  margin: 0;
  font-size: 16px;
  line-height: 20px;
  color: #8e2c57;
}
.title-card.decorated-title {
  background-image: url("../particular/images/rubytoning/toning-pricettl-back.png");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  padding: 25px;/* 上下に余白多めにするとフレームに収まりやすい */
  position: relative;
}

.title-card.decorated-title .section-title {
  position: relative;
  z-index: 2;
  background-color: transparent; /* 背景不要 */
  padding-top: 20px;
}

.treatment-card .card-text{
	flex-grow: 1;
	width: auto;
}

/* ルビートーニング＿カード内の画像 */
.card-image {
  max-width: 150px;
  margin-right: 16px;
  flex-shrink: 0;
}

.card-image img {
  width: 100%;
  height: auto;
}

/* スキンボトックス＿カード内の画像 */
.card-image_s {
  max-width: 150px;
  margin-right: 16px;
  flex-shrink: 0;
}

.card-image_s img {
  width: 100%;
  height: auto;
}

/* カード内テキスト */
.card-text .part {
font-size: 1.2rem;
color:#864052;
margin-bottom: 5px;
background: #F5E0E1;
text-align: center;
padding: 5px 5px 3px 5px;
border-radius:20px;	
font-weight: 700;
}
.card-text_long_c{
	margin: 0 auto;
}
.card-text_long_c .parts_4{
	font-size: 1.2rem;
color:#864052;
	margin-top: 10px;
margin-bottom: 5px;
background: #F5E0E1;
text-align: center;
padding: 5px 5px 3px 5px;
border-radius:20px;	
font-weight: 700;
}
.card-long_c_price{
	color:#864052;
	text-align: center;
}

.card-text .price {
/*  color: #555;*/
  color: #801648;
  font-size: 1.5rem;
  text-align: center;
/*	font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝",'Noto Serif JP', serif;*/
}

.card-text_long_c .price_5{
	font-size: 1.2rem;
	font-weight: 500;
}

.price_kome{
  font-size: 12px;
  text-align: right;
  color: #464646;
}
.card-text .price .small {
  font-size: 0.9rem;
}

.card-text .note {
  color: #aa4e3e;
  font-size: 0.9rem;
  margin-bottom: 6px;
  font-weight: 500;
}

/* タイトルカード専用（枠なし・背景と同化・見出しスタイル） */
.title-card {
  justify-content: center;
  text-align: center;
  border: none;
  box-shadow: none;
  background: #f7f3ed;
  width: calc(50% - 10px);
  padding-top: 12px;
  padding-bottom: 8px;
}

.title-card .section-title {
  font-size: 1.5rem;
  line-height: 2rem;
  font-weight: bold;
  color: #801648;
  margin: 0 auto;
  padding-bottom: 6px;
  display: inline-block;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝",'Noto Serif JP', serif;
  font-weight:700;
}

table.treatment-schedule_table{
	margin: 0 auto;
	width: 100%;
}

table.treatment-schedule_table tr td{
	padding: 15px;
}

.treatment-schedule_tag{
	background-color: #FBF7ED;
	font-weight: 700;
	color: #555555;
}






.aftercare-section {
  background-color: #f8f6ee;
  padding: 1.5rem;
  border-radius: 8px;
}

.aftercare-intro {
  font-weight: bold;
  font-size: 16px;
  text-align: center;
  margin-bottom: 0.5rem;
  color: #5F5F5F;
}

.aftercare-list {
  display: flex;
  gap: 1.5rem;
  justify-content: space-between;
  flex-wrap: nowrap;
}

.aftercare-card {
  flex: 1;
  min-width: 0;
  background-color: #ffffff;
  padding: 1.2rem 1rem;
  border-radius: 8px;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
}

/* 新しいラップ要素 */
.aftercare-content {
  display: block;
  text-align: center;
}

.aftercare-content img {
  margin-bottom: 15px;
  margin: 0 auto;
  display: block;
  padding-bottom:15px;
  width: 100px;
  height: auto;
}

.aftercare-text h3 {
  font-size: 18px;
  margin-bottom: 0.5rem;
  color: #923B3D;
  text-align: center;
}

.aftercare-text p {
  font-size: 14px;
  line-height: 24px;
  color: #444;
  text-align: left;
}



/* スマホ対応 */
@media screen and (max-width: 680px) {
  .aftercare-list {
    flex-direction: column;
    gap: 0.75rem;
  }

  .aftercare-card {
    padding: 1rem;
  }

/*ルビートーニング　術後のケア*/	
  .aftercare-content {
    display: flex;
    align-items: center;
    gap: 10px;
    text-align: left;
  }

  .aftercare-content img {
    width: 75px;
    height: auto;
    margin: 0;
    padding: 0;
  }

  .aftercare-text h3 {
    font-size: 16px;
    margin-bottom: 4px;
    text-align: left;
  }

  .aftercare-text p {
    font-size: 12px;
    line-height: 1.4;
  }
	
	
}




/*-------------------------------------
ルビートーニング4つの特徴
-------------------------------------*/
.feature-section {
  display: flex;
  flex-direction: column;
	gap:20px;/*枠と枠の間の余白*/
	margin-top: -80px;
  padding: 80px;
}

.feature-item {
  position: relative; /* ← 追加 */
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 40px;
  padding: 40px 5px; /* 背景との重なり余白調整 */
  z-index: 1;
}

.feature-item img{
box-shadow: 0px 0px 18px -6px #7a7a7a;
border-radius: 10px;
}

.feature-bg {
  position: absolute;
  top: 10px;
  left: 5%;
  width: 90%;
  height: calc(100% - 10px); /* 上下に少し余白 */
  border-radius: 20px;
  z-index: 0;
	background-color: #F8F2F2;
}

/* z-index を上に保つ */
.feature-image, .feature-text {
  position: relative;
  z-index: 1;
}

.feature-item.reverse {
  flex-direction: row-reverse;
}

.feature-image img {
  width: 250px;
  max-width: 100%;
  border-radius: 10px;
 }

.feature-text {
  flex: 1;
min-width: 260px;
 font-family: 'Noto Sans JP', sans-serif;
}

/*特徴の見出し部分*/
.feature-text h3 {
  position: relative;
  font-size: 1.4rem;
  color: #a20044;
  padding-left: 88px; /* 73px + 15px */
 line-height: 1.3;           /* そのまま */
  margin: 0.6rem 0 0.9rem;     /* 下を少しだけ増やす */
  padding-bottom: 0.15rem;     /* 1行の詰まりを消す */
  font-weight: 700;
}
/* point画像 共通 */
.feature-text h3::before{
  content:"";
  position: absolute;
  left: 0;
  top: 0.05em;          /* ここは微調整OK */
  width: 73px;
  height: 57px;
  display: block;       /* ←重要：width/heightを効かせる */
  background-repeat: no-repeat;
  background-size: contain;
}
/* 各point画像 */
.feature-text h3.point-01::before{ background-image:url("../particular/images/rubytoning/point-01.png"); }
.feature-text h3.point-02::before{ background-image:url("../particular/images/rubytoning/point-02.png"); }
.feature-text h3.point-03::before{ background-image:url("../particular/images/rubytoning/point-03.png"); }
.feature-text h3.point-04::before{ background-image:url("../particular/images/rubytoning/point-04.png"); }

/*.feature-text h3.point-02::before {
content: "";
display: inline-block;
width: 73px;
height: 57px;
margin-right: 15px;
background-image: url("../particular/images/rubytoning/point-02.png");
background-repeat: no-repeat;
vertical-align: middle;
background-size: contain;
background-repeat: no-repeat;
}
.feature-text h3.point-03::before {
content: "";
display: inline-block;
width: 73px;
height: 57px;
margin-right: 15px;
background-image: url("../particular/images/rubytoning/point-03.png");
background-repeat: no-repeat;
vertical-align: middle;
background-size: contain;
background-repeat: no-repeat;
}
.feature-text h3.point-04::before {
content: "";
display: inline-block;
width: 73px;
height: 57px;
margin-right: 5px;
background-image: url("../particular/images/rubytoning/point-04.png");
background-repeat: no-repeat;
vertical-align: middle;
background-size: contain;
background-repeat: no-repeat;
}*/

.feature-text p {
  font-size: 1rem;
  line-height: 1.6;
}


@media screen and (max-width: 768px) {
	  .feature-section {
    padding: 60px 20px 30px 20px; /* 左右余白を小さく、上下余白を適度に */
    gap: 5px;
  }
  .feature-item {
    flex-direction: column !important; /* 縦並びにする */
    text-align: center; /* テキスト中央寄せ */
    padding: 30px 0;
    gap: 20px;
    margin-top: 20px;
  }

.feature-bg {
  top: 0px;
  left: 0%;
  width: 100%;
}
	
  .feature-image {
    display: flex;
    justify-content: center; /* 画像中央揃え */
    width: 100%;
  }
 .feature-image img {
    max-width: 90%;
    height: auto;
  }
  .feature-text {
    width: 100%;
    padding: 0px;
    text-align: left;
  }

	
  .feature-text h3 {
    font-size: 1.1rem; /* 少し小さめ */
	ne-height: 1.7;  
    margin-bottom: 8px;
  }
  .feature-text h3::before {
    display: block; /* 中央上にアイコン画像 */
    margin: 0 auto 10px auto;
  }

  .feature-text p {
    font-size: 0.9rem;
    line-height: 1.8;
  }

  .feature-bg {
    left: 0;
    width: 100%;
    height: 100%;
  }
	
/* スキンボトックス＿カード内の画像 */
.card-image_s {
	margin: 0 auto;
}

	
}






@media screen and (max-width: 900px) {
/*吹き出し*/
.balloon-price-set {
    display: block;
    max-width: 100%;
    padding: 5px 20px 5px 20px;
    border-radius: 15px;
	margin-bottom: 0;
}
.balloon-price-set::before {
	display: none;
}
/*吹き出し文字の改行*/
.br_toning-price{
	display: none;
}
  }

/* スマホ対応（1列表示に） */
@media screen and (max-width: 768px) {
  .treatment-card {
    width: 100%;
    flex-direction: row;
  }

  .treatment-card-long {
    width: 100%;
    flex-direction: column;
	    padding: 1em 0 1em 0;
  }
	
.price-line-wrap {
	align-items: center;
}
	
.part2 {
font-size: 1.3rem;
text-align: center;
}

/*吹き出し文字の改行*/
.br_toning-price{
	display: block;
}
/*吹き出し*/
.balloon-price-set {
    display: flex;
    align-items: center;
    position: relative;
    max-width: 100px;
    padding: 1em;
    border-radius: 20px;
}
.balloon-price-set::before {
	display: block;
    position: absolute;
    right: -9px;
    width: 20px;
    height: 35px;
	background-color: #9A4E61;
	/*background: #F5E0E1;*/
    /*background-color: #8e2c57;*/
    clip-path: polygon(0 0, 100% 50%, 0 100%);
    content: '';
}

.price-info {
  gap: 5px;
}
.price-2 {
  font-size: 1.1rem;
}
.price-3 {
  font-size: 1.1rem;
}
	
  .title-card {
    width: 100%;
  }
}

/* さらに小さいスマホ対応 */
@media screen and (max-width: 470px){
/*吹き出し文字の改行*/
.br_toning-price{
	display: none;
}
/*吹き出し*/
.balloon-price-set {
    display: block;
	max-width: 100%;
    padding: 5px 15px 5px 15px;
    border-radius: 20px;
	margin: 0 auto;
}
.price-info {
  display: block;
	margin: 0 auto;
}
.price-hosokulink{
	text-align: center;
}

.balloon-price-set::before {
	display: none;
}
}
	

	