@charset "UTF-8";


/* =================================
   2026-01 他社制作サイト改修
   対象：
   ・TOPページ
   ・下層ページ（5P）
   ・グローバルナビ
================================= */


/* ========================================================
  
  Common

======================================================== */
img {
	display: block;
}

/*---------------------------------------------------------
 trt-lead ※既存クラスから変更
---------------------------------------------------------*/
.trt-lead {
	position: relative;
	padding-bottom: 0;
	margin-bottom: min(10vw,120px);
}
.trt-lead.bdr-b {
	padding-bottom: min(6vw,80px);
}
.trt-lead__inbox {
	position: relative;
	min-height: min(37vw,550px);
	margin-inline: auto;
}
.trt-lead__img {
	position: relative;
	max-width: 950px;
}
.trt-lead__txt {
	position: relative;
	background-color: #fff;
	box-sizing: border-box;
}
@media only screen and (min-width: 768px) {

.trt-lead__img {
	position: absolute;
	width: 74%;
	left: 0;
	top: 0;
}
.trt-lead__txt {
	width: 64%;
	max-width: 650px;
	padding: 3.8% 0 4% 5.2%;
	margin-left: auto;
}
.trt-lead__txt p {
	line-height: 2;
}
}

@media only screen and (min-width: 768px) and (max-width: 959px) {

.trt-lead__inbox {
	padding-top: 5%;
}
}

@media only screen and (max-width: 767px) {

.trt-lead {
	margin-bottom: 15%;
}
.trt-lead.bdr-b {
	padding-bottom: 10%;
}
.trt-lead__inbox {
	width: 100%;
}
.trt-lead__txt {
	padding: 7% 8% 0;
}
}


/*---------------------------------------------------------
 Parts
---------------------------------------------------------*/

/* trt-box-bdr
==========================================================*/
.trt-box--bdr {
	position: relative;
	max-width: 1200px;
	margin-inline: auto;
	border: 1px solid rgba(0,0,0,0.2);
}
.trt-box--bdr__title {
	padding: 5% 0;
}
.trt-box--bdr__title .com-h--center {
	margin-bottom: 0;
}
.trt-box--bdr__bg {
	background-color: #f7f7f5;
	padding: min(5.2vw,70px) 5%;
}
.trt-box--bdr__inbox {
	max-width: 1000px;
	margin-inline: auto;
}
.trt-box--bdr__inbox:not(:last-child) {
	padding-bottom: 4.6%;
	margin-bottom: 4.6%;
	border-bottom: 1px solid rgba(0,0,0,0.2);
}

@media only screen and (max-width: 767px) {

.trt-box--bdr__title {
	padding: 8% 0 6%;
}
.trt-box--bdr__bg {
	padding: 8% 5%;
}
.trt-box--bdr__inbox:not(:last-child) {
	padding-bottom: 8%;
	margin-bottom: 9%;
}
}

/* trt-box-note
==========================================================*/
.trt-box--note {
	position: relative;
	max-width: 1200px;
	box-sizing: border-box;
	padding: min(6.5%,80px) 7.5%;
	margin-inline: auto;
	border: 1px solid rgba(0,0,0,0.2);
}
.trt-box--note .com-h--en {
	position: absolute;
	text-align: left;
	color: #666;
	rotate: 90deg;
	transform-origin: left top;
	background-color: #fff;
	padding: 0 2.5em;
	margin: 0;
	left: 0.5em;
	top: 0;
}

@media only screen and (max-width: 767px) {

.trt-box--note {
	padding: 8% 6%;
}
}

/* trt-check
==========================================================*/
.trt-check::before {
	position: absolute;
	content: "";
	width: 4.8em;
	aspect-ratio: 78/34;
	border-left: 1px solid #666;
	border-bottom: 1px solid #666;
	inset: 0 auto auto 50%;
	translate: -50% -50%;
	rotate: -45deg;
}
.trt-check__title {
	position: relative;
	text-align: center;
	font-size: min(3.5vw,250%);
	line-height: 1.6;
	letter-spacing: .12em;
	font-feature-settings: normal;
	padding-top: .5em;
	margin-bottom: .8em; 
}
.trt-check__title p {
	font-size: clamp(12px,50%,20px);
}
.trt-check__inbox {
	background-color: #fff;
	padding: 5.8% 5%;
}
.trt-check__list {
	display: grid;
	row-gap: 1.6em;
	font-size: min(1.6vw,131%);
	line-height: 1.5;
	margin-inline: auto;
}
.trt-check__list > li {
	position: relative;
	box-sizing: border-box;
	padding-left: 2.5em;
}
.trt-check__list > li::before {
	position: absolute;
	display: block;
	content: "";
	width: 1.2em;
	height: 1.2em;
	border: 1px solid rgba(0,0,0,0.2);
	left: 0;
	top: 0;
}
.trt-check .com-txt--center {
	margin-top: 1.8em;
}

@media only screen and (min-width: 768px) {

.trt-check__list {
	justify-content: space-between;
	grid-template-columns: repeat(2,49%);
	max-width: 1020px;
}
}

@media only screen and (max-width: 767px) {

.trt-check::before {
	width: 10vw;
}
.trt-check__title {
	font-size: 130%;
	letter-spacing: .08em;
}
.trt-check__inbox {
	padding: 7% 8%;
}
.trt-check__list {
	row-gap: .8em;
	font-size: 100%;
}
.trt-check__list > li {
	padding-left: 2.2em;
}

.trt-check .com-txt--center {
	font-size: 110%;
	margin-top: 1.2em;
}
}

/* trt-col-list
==========================================================*/
.trt-col-list {
	display: grid;
}
.trt-col-list > li {
	position: relative;
	background-color: #f5f5f5;
	background-repeat: no-repeat;
	background-position: right top;
	padding: 10% 6.5%;
}
.trt-col-list dt {
	position: relative;
	text-align: center;
	font-size: min(2.2vw,156%);
	line-height: 1.4;
	margin-bottom: .87em;
}
.trt-col-list dt span {
	display: inline-block;
}
.trt-col-list dt.point {
	text-align: left;
	font-size: min(1.8vw,131%);
	padding-left: 1.2em;
}
.trt-col-list dt.point::before {
	position: absolute;
	content: "";
	background-color: #ab9949;
	width: .66em;
	height: .66em;
	border-radius: 50%;
	left: 0;
	top: .35em;
}

/* list--img */
.trt-col-list.list--img > li {
	background-color: transparent;
	padding-top: 0;
}
.trt-col-list.list--img > li::before {
	position: absolute;
	content: "";
	background-color: #f5f5f5;
	width: 100%;
	height: calc(100% - min(8.4vw,130px));
	left: 0;
	bottom: 0;
	z-index: -1;
}
.trt-col-list.list--img .img {
	width: 70%;
	max-width: 204px;
	margin: 0 auto 10%;
}

/* list--bdr */
.trt-col-list.list--bdr > li {
	background-color: transparent;
	border: 1px solid rgba(0,0,0,0.5);
}

/* list--icon */
.trt-col-list.list--icon > li {
	background-color: transparent;
	padding: 0 11% 5%;
}
.trt-col-list.list--icon .icon {
	display: block;
	width: 45%;
	margin: -5% auto 1em;
}

@media only screen and (min-width: 768px) {

.trt-col-list {
	display: grid;
	justify-content: space-between;
    flex-wrap: wrap;
	row-gap: 1.5em;
}
.trt-col-list.list--col2 {
	grid-template-columns: repeat(2, 48.6%);
}
.trt-col-list.list--col3 {
	grid-template-columns: repeat(3, 32%);
}
.trt-col-list.list--col4 {
	grid-template-columns: repeat(4, 24.2%);
}
.trt-col-list > li {
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 2;
	gap: 0;
}
.trt-col-list > li dl {
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 2;
	gap: 0;
}
.trt-col-list.list--col4 > li {
	padding: 10% 7.9% 14%;
}

/* list--img */
.trt-col-list.list--img > li {
	grid-row: span 3;
	padding-top: 0;
}
.trt-col-list.list--img dt {
	font-size: min(2vw,175%);
	margin-bottom: .4em;
}

/* list--icon */
.trt-col-list.list--icon {
	border-left: 1px solid rgba(0,0,0,0.2);
	grid-template-columns: repeat(3, 33.3%);
}
.trt-col-list.list--icon > li {
	border-right: 1px solid rgba(0,0,0,0.2);
}
}

@media only screen and (max-width: 767px) {

.trt-col-list {
	row-gap: 1em;
}
.trt-col-list > li {
	padding: 8% 6.5%;
}
.trt-col-list dt {
	font-size: 125%
}
.trt-col-list dt.point {
	font-size: 110%;
}

/* list--img */
.trt-col-list.list--img > li::before {
	height: calc(100% - 30vw);
}
.trt-col-list.list--img .img {
	width: 60%;
}

/* list--icon */
.trt-col-list.list--icon > li {
	padding: 8% 4% 7%;
	border-top: 1px solid rgba(0,0,0,0.2);
}
.trt-col-list.list--icon dt {
	display: flex;
	align-items: center;
	justify-content: space-between;
	text-align: left;
}
.trt-col-list.list--icon .icon {
	width: 30%;
	margin: 0;
	translate: none;
}
.trt-col-list.list--icon div {
	width: 64%;
	margin: 0;
	translate: none;
}
}

/* trt-img-list
==========================================================*/
.trt-img-list {
	position: relative;
	display: grid;
}
.trt-img-list .box-img {
	position: relative;
	max-width: max-content;
	margin: 0 auto 6%;
}
.trt-img-list .txt {
	text-align: center;
	font-size: min(2vw,137%);
	letter-spacing: .15em;
	line-height: 1.6;
}
.trt-img-list dt {
	margin-bottom: .3em;
}

@media only screen and (min-width: 768px) {
.trt-img-list {
	justify-content: space-between;
	row-gap: 5em;
}
.trt-img-list.col--2 {
	grid-template-columns: repeat(2,47%);
}
.trt-img-list.col--3 {
	grid-template-columns: repeat(3,31.7%);
}
}

@media only screen and (max-width: 767px) {
.trt-img-list {
	row-gap: 3em;
}
.trt-img-list .box-img {
	width: 80%;
}
.trt-img-list .txt {
	font-size: 105%;
}
.trt-img-list.col--3 {
	row-gap: 2em;
}
.trt-img-list.col--3 > *:not(:last-child) {
	padding-bottom: 8%;
	border-bottom: 1px solid #f0f0f0;
}
}

/*---------------------------------------------------------
 trt-rank
---------------------------------------------------------*/
.trt-rank {
	position: relative;
	display: flex;
	column-gap: 1.2em;
	font-size: 94%;
	line-height: 1.5;
	letter-spacing: .12em;
	white-space: nowrap;
	padding: .8em 2.5%;
	margin-bottom: 1.6em;
	border-top: 1px solid rgba(0,0,0,0.2);
	border-bottom: 1px solid rgba(0,0,0,0.2);
}

@media only screen and (min-width: 768px) {
/* .trt-rank {
	width: 58%;
} */
}

@media only screen and (max-width: 767px) {
.trt-rank {
	justify-content: center;
	column-gap: .8em;
	font-size: 90%;
	padding: 1em 1%;
}
}

/*---------------------------------------------------------
 trt-mer-dem
---------------------------------------------------------*/
.trt-mer-dem {
	margin-top: 6%;
}
.trt-mer-dem > dl {
	position: relative;
	padding: 9.6% 5% 1em 0;
	border-top: 1px solid rgba(0,0,0,0.2);
	border-right: 1px solid rgba(0,0,0,0.2)
}
.trt-mer-dem dt {
	position: absolute;
	font-size: min(2vw,125%);
	line-height: 1.5;
	letter-spacing: .1em;
	font-feature-settings: normal;
	background-color: #fff;
	padding-right: 2.5em;
	left: 0;
	top: -0.6em;
}
.trt-mer-dem .com-list > li {
	font-size: 94%;
	margin-bottom: 1.2em;
}

.trt-mer-dem .merit { border-color: rgba(171,153,173,0.5);}
.trt-mer-dem .merit dt { color: #ab9949;}

/* PC,Tablet (Portrait)
------------------------------------------*/
@media only screen and (min-width: 768px) {
.trt-mer-dem {
	display: grid;
    justify-content: space-between;
	grid-template-columns: 48% 48%;
}
.trt-mer-dem .com_h__en {
	margin-bottom: 1.2em;
}
}
/* Mobile (Portrait)
------------------------------------------*/
@media only screen and (max-width: 767px) {
.trt-mer-dem {
	margin-top: 10%;
}
.trt-mer-dem > dl:first-of-type {
	margin-bottom: 6%;
}
.trt-mer-dem dt {
	font-size: 105%;
}
}


/* trt-prog-list
==========================================================*/
.trt-prog-list {
	position: relative;
	max-width: 993px;
	display: grid;
    grid-template-columns: repeat(4,25%);
	margin-inline: auto;
}
.trt-prog-list li {
	position: relative;
}
.trt-prog-list .img_item {
	position: relative;
	width: 82%;
	max-width: max-content;
	margin: 0 auto .6em;
}
.trt-prog-list .img_item::after {
	position: absolute;
	content: "";
	background: url(../images/treatment/general/icon_arrow.svg) no-repeat center center;
	background-size: 100% 100%;
	width: 8%;
	height: 100%;
	left: 112%;
	top: 50%;
	translate: -50% -50%;
}
.trt-prog-list li:last-of-type .img_item::after {
	display: none;
}
.trt-prog-list .txt {
	position: relative;
	text-align: center;
	font-size: 93%;
	line-height: 1.5;
	letter-spacing: .08em;
	padding: 0 5%;
}
.trt-prog-list .txt dt {
	text-align: center;
	color: #666;
	font-size: min(2.8vw,187%);
	letter-spacing: .1em;
	line-height: 1.3;
	margin-bottom: .2em;
}
.trt-prog-list .txt dd {
	font-size: 94%;
}

/*5列*/
.trt-prog-list.col5 {
    grid-template-columns: repeat(5,20%);
}

@media only screen and (min-width: 768px) {

/*5列*/
.trt-prog-list.col5 {
	width: 106%;
	max-width: 1140px;
	left: 50%;
	translate: -50% 0;
}
}

@media only screen and (max-width: 767px) {

/* trt-prog-list */
.trt-prog-list {
   min-width: max-content;
}
.trt-prog-list > li {
    width: 44vw;
}
.trt-prog-list .img_item {
	width: 70%;
	margin-bottom: .8em;
}
.trt-prog-list .img_item::after {
	font-size: 120%;
	left: 120%;
}
.trt-prog-list .txt {
	font-size: 78%;
	letter-spacing: .02em;
}
.trt-prog-list .txt dt {
	font-size: 150%;
}
}


/*---------------------------------------------------------
 Feature
---------------------------------------------------------*/

/* trt-fea-list
==========================================================*/
.trt-fea-list {
	counter-reset: feaCounter;
}
.trt-fea-list > div {
	padding-bottom: 5.5%;
	margin-bottom: 5.5%;
	border-bottom: 1px solid #f0f0f0;
}
.trt-fea-list > div:last-child {
	padding-bottom: 0;
	margin-bottom: 0;
	border-bottom: none;
}
.trt-fea-list__no {
	color: #666;
	counter-increment: feaCounter;
	font: var(--font_eng);
	line-height: 1;
	letter-spacing: .06em;
	margin-bottom: 2em;
}
.trt-fea-list__no::after {
	content: '( 'counter(feaCounter, decimal-leading-zero)' )';
	font-size: 168%;
	vertical-align: -0.1em;
	margin-left: .6em;
}
.trt-fea-flt .com-flt__img__abs {
	width: 35%;
	max-width: 195px;
	margin-top: -24%;
}
.trt-fea-flt .com-flt__img__abs .deco {
	position: absolute;
	width: 103%;
	max-width: 200px;
	left: 86%;
	top: 35%;
}
.trt-fea-flt .com-flt__img__abs.pos--l {
	margin-left: 5.6%;
}
.trt-fea-flt .com-flt__img__abs.pos--r {
	margin-left: auto;
	margin-right: 5.6%;
}

.trt-fea-list .com-box--bg {
	max-width: 1270px;
	margin-inline: auto;
}

.trt-fea-point {
	background-color: rgba(171,153,73,0.08);
	margin-top: 4.2%;
}
.trt-fea-point .com-h--en {
	text-align: left;
	color: #666;
	font-size: 100%;
	margin-bottom: 1em;
}

@media only screen and (min-width: 768px) {

.trt-fea-flt .com-flt__img--l,
.trt-fea-flt .com-flt__img--r {
	width: 50%;
	max-width: 650px;
}
.trt-fea-flt .com-flt__txt--l,
.trt-fea-flt .com-flt__txt--r {
	width: 45%;
}

.trt-fea-point .com-flt__img--r {
	width: 45%;
	max-width: 495px;
}
}

@media only screen and (max-width: 767px) {

.trt-fea-list > div {
	padding-bottom: 8%;
	margin-bottom: 10%;
}
.trt-fea-list__no {
	font-size: 80%;
	margin-bottom: 1.5em;
}
.trt-fea-flt .com-flt__img--l,
.trt-fea-flt .com-flt__img--r {
	width: 100%;
}
.trt-fea-flt .com-flt__img__abs {
	width: 40%;
	margin-top: -30%;
}

.trt-fea-point .com-flt__img--r {
	width: 95%;
}
}



/*---------------------------------------------------------
 PRICE
---------------------------------------------------------*/
.trt-price {
	margin-top: 8%;
}
.trt-price-ttl {
	font-size: clamp(1rem,2.2vw,143%);
	line-height: 1.5;
	padding-bottom: .8em;
    margin-bottom: .5em;
    border-bottom: 1px solid rgba(0,0,0,0.2);
}
.trt-price-ttl + p {
	margin-top: 1.2em;
}
.trt-price-h {
	font-size: clamp(1rem,2.2vw,120%);
	line-height: 1.5;
	padding-bottom: .8em;
    margin-bottom: .5em;
}
.trt-price-h span {
	display: inline-block;
	color: #FFF;
	font-size: 80%;
	vertical-align: 0.1em;
	background-color: #5a5a5a;
	padding: .1em .4em;
	margin-left: .4em;
}

/* trt-price-tbl
==========================================================*/
.trt-price-tbl {
	width: 100%;
	max-width: 735px;
	font-size: min(1.4vw,106%);
	line-height: 1.4;
	border-spacing: 0 1em;
	border-collapse: separate;
}
.trt-price-tbl caption {
	caption-side: bottom;
	font-size: clamp(10px,100%,13px);
	margin-top: 1em;
}
.trt-price-tbl caption ul {
	display: flex;
	flex-wrap: wrap;
	gap: .2em 1em;
}
.trt-price-tbl th small {
	display: inline-block;
	font-size: 80%;
}
.trt-price-tbl .txt-price {
	text-align: right;
	font-size: 147%;
	line-height: 1.2;
	letter-spacing: .06em;
}
.trt-price-tbl .txt-price small {
	display: block;
	font-size: 72%;
}
.trt-price-tbl .txt-price small span {
	font-size: 83%;
}

.trt-price-tbl.type--bg {
	border-spacing: 0 4px;
}
.trt-price-tbl.type--bg tr {
	background-color: #f5f5f5;
}
.trt-price-tbl.type--bg th,
.trt-price-tbl.type--bg td {
	box-sizing: border-box;
	padding: 1em 3%;
}
.trt-price-tbl.type--bg th {
	vertical-align: middle;
}

@media only screen and (max-width: 767px) {

.trt-price-tbl {
	font-size: 90%;
	border-spacing: 0 .7em;
}
.trt-price-tbl .txt-price {
	font-size: 125%;
	white-space: nowrap;
}

.trt-price-tbl.type--bg {
	border-spacing: 0 2px;
}
.trt-price-tbl.type--bg th,
.trt-price-tbl.type--bg td {
	padding: .8em 4%;
}
}


/*---------------------------------------------------------
 PLAN ※既存クラスから変更
---------------------------------------------------------*/
.trt-plan-wrap {
	max-width: 1220px;
	margin-inline: auto;
}
.trt-plan-item {
	margin-bottom: 10%;
}
.trt-plan-item:last-of-type {
	margin-bottom: 0;
}

@media only screen and (min-width: 960px) {

.trt-plan-item {
	display: grid;
	justify-content: space-between;
	grid-template-columns: 50% 44%;
}
.trt-plan-item__img img + img {
	margin-top: 15px;
}
}

@media only screen and (min-width: 768px) and (max-width: 959px) {

.trt-plan-item__img {
	width: 70%;
	margin: 0 auto 4%;
}
.trt-plan-item__img.img--col2 {
	display: grid;
	grid-template-columns: 50% 50%;
	column-gap: 1%;
	width: 100%;
}

.trt-plan-item .trt-price-tbl {
	font-size: min(106%);
}
}

@media only screen and (max-width: 767px) {

.trt-plan-item {
	margin-bottom: 12%;
}
.trt-plan-item__img {
	width: 90%;
	margin: 0 auto 5%;
}
.trt-plan-item__img img + img {
	margin-top: 10px;
}
}

/* trt-plan-app
==========================================================*/
.trt-plan-app {
	display: grid;
	justify-content: space-between;
	grid-template-columns: 22% 73%;
}
.trt-plan-app:not(:first-child) {
    margin-top: 10px;
}
.trt-plan-app .title {
	font-size: min(1.8vw,112%);
	line-height: 1.5;
	margin-bottom: .2em;
}

@media only screen and (max-width: 767px) {

.trt-plan-app:not(:first-child) {
    margin-top: 4%;
}
.trt-plan-app .title {
	font-size: 105%;
}
.trt-plan-app p {
	font-size: 90%;
}
}


/*---------------------------------------------------------
 FLOW
---------------------------------------------------------*/

/* trt-flow-list
==========================================================*/
.trt-flow-list {
	counter-reset: flowCounter;
	max-width: 1120px;
	margin-inline: auto;
}
.trt-flow-list > li {
	position: relative;
	padding-bottom: min(10%,120px);
	margin-bottom: 30px;
}
.trt-flow-list > li:last-of-type {
	padding-bottom: 0;
	margin-bottom: 0;
}
.trt-flow-list > li::before {
	position: absolute;
	content: "";
	background-color: rgba(102,102,102,0.5);
	width: 1px;
	height: 100%;
	left: 58%;
	top: 0;
	z-index: -1;
}
.trt-flow-list > li:last-of-type::before {
	display: none;
}

.trt-flow-list__img {
	max-width: 555px;
	aspect-ratio: 555/423;
}
.trt-flow-list__img img {
	width: 100%;
	max-width: none;
	height: 100%;
	object-fit: cover;
}
.trt-flow-list__txt {
	position: relative;
	background-color: #fff;
	padding-bottom: 2em;
}
.trt-flow-list__txt .com-h--accent small {
	display: block;
	margin: 0;
}
.trt-flow-list__no {
	counter-increment: flowCounter;
	color: rgba(102,102,102,0.2);
	font-size: min(7.5vw,570%);
	line-height: 0.7;
	letter-spacing: .06em;
	margin-bottom: .4em;
}
.trt-flow-list__no::after {
	content: counter(flowCounter, decimal-leading-zero);
}

@media only screen and (min-width: 768px) {

.trt-flow-list > li {
	display: grid;
	justify-content: space-between;
	align-items: flex-start;
	grid-template-columns: 50% 46%;
}
}

@media only screen and (max-width: 767px) {

.trt-flow-list > li {
	padding-bottom: 12%;
	margin-bottom: 20px;
}
.trt-flow-list > li::before {
	left: 50%;
}
.trt-flow-list__img {
	width: 90%;
	margin-inline: auto;
}
.trt-flow-list__txt {
	padding: 8% 0 1em;
}
.trt-flow-list__no {
	font-size: 12vw;
}
}




/*---------------------------------------------------------
 FAQ
---------------------------------------------------------*/

/* trt-faq-list
==========================================================*/
.trt-faq-list > li:not(:last-of-type) {
	margin-bottom: 5%;
}
.trt-faq-list .faq__q,
.trt-faq-list .faq__a {
	position: relative;
	box-sizing: border-box;
	padding: 3% 5% 3% 12%;
}
.trt-faq-list .faq__q {
	min-height: 6em;
	font-size: 125%;
	margin-bottom: 1.6em;
}
.trt-faq-list .faq__a {
	background-color: #f5f5f5;
	border-bottom: 1px solid #666;
}
.faq__deco {
	position: absolute;
	display: block;
	width: 1.2em;
	height: 100%;
	text-align: center;
	color: #666;
	font-size: min(6vw,5rem);
	left: 2.5%;
	line-height: 1;
	top: 0;
}
.trt-faq-list .faq__q .faq__deco::after {
	position: absolute;
	content: "";
	display: block;
	background-color: currentColor;
	width: 1px;
	height: calc(100% - 1.2em);
	left: 40%;
	bottom: 0;
	translate: -50% 0;
}
.trt-faq-list .faq__a .faq__deco {
	top: -0.3em;
}

.faq__col2 {
	margin-top: 3.5%;
}
.faq__col2 dt {
	text-align: center;
	font-size: min(2vw,1.18rem);
	line-height: 1.4;
	letter-spacing: .12em;
	background-color: #fff;
	padding: .6em;
	margin-bottom: 1em;
	border-radius: 100vmax;
}

@media only screen and (min-width: 768px) {

.trt-faq-list {
	width: 94%;
	max-width: 1130px;
	margin-left: auto;
}
.faq__col2 {
	display: grid;
	justify-content: space-between;
	grid-template-columns: repeat(2,48%);
}
}

@media only screen and (max-width: 767px) {

.trt-faq-list > li:not(:last-of-type) {
	margin-bottom: 7%;
}
.trt-faq-list .faq__q,
.trt-faq-list .faq__a {
	padding: 6% 5% 6% 18%;
}
.trt-faq-list .faq__q {
	min-height: 2em;
	font-size: 115%;
	padding-bottom: 0;
}
.faq__deco {
	font-size: 10vw;
	left: 1.5%;
	top: .3em;
}

.faq__col2 {
	margin-top: 6%;
}
.faq__col2 > dl:nth-of-type(n+2) {
	margin-top: 7%;
}
.faq__col2 dt {
	font-size: 105%;
	margin-bottom: .8em;
}
}


/*---------------------------------------------------------
 OTHER
---------------------------------------------------------*/

/* trt-fukidashi
==========================================================*/
.trt-fukidashi {
	position: relative;
	width: 90%;
	max-width: 1000px;
	text-align: center;
	font-size: min(3vw,218%);
	line-height: 1.4;
	letter-spacing: .14em;
	font-feature-settings: normal;
	padding-bottom: 1.2em;
	margin: 0 auto 2em;
	box-shadow: 0 35px 20px -25px rgba(0,0,0,0.1);
}
.trt-fukidashi [lang="en"] {
	color: #f0f0f0;
	font-size: 228%;
	line-height: 1;
	margin-bottom: -0.1em;
}
.trt-fukidashi span {
	font-size: 114%;
}
.trt-fukidashi::before {
	position: absolute;
	display: block;
	content: "";
	background-color: #fff;
	width: 1em;
	height: .85em;
	clip-path: polygon(0 0, 100% 0, 50% 100%);
	inset: calc(100% - 1px) 0 auto 0;
	margin: auto;
}

@media only screen and (max-width: 767px) {

.trt-fukidashi {
	font-size: 130%;
	letter-spacing: .1em;
}
}

/* trt-message-flt
==========================================================*/
.trt-message .com-h--center {
	margin-bottom: 2em;
}
.trt-message-flt .com-h--accent {
	margin-bottom: .8em;
}
@media only screen and (min-width: 768px) {

.trt-message-flt .com-flt__img--l {
	width: 48%;
}
.trt-message-flt > div:last-of-type {
	padding-top: 5%;
}
.trt-message-flt .com-h--accent {
	font-size: min(2.2vw,156%);
}
.trt-message-flt p {
	line-height: 2.2;
}
}

@media only screen and (max-width: 767px) {

.trt-message-flt .com-flt__img--l {
	width: 90%;
}
.trt-message-flt .com-h--accent {
	text-align: center;
}
}

/* trt-box--risk
==========================================================*/
.trt-box--risk ul {
	max-width: 1000px;
	font-size: 94%;
	margin-inline: auto;
}



/* ========================================================
  
  Pages

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

/*---------------------------------------------------------
 general
---------------------------------------------------------*/
#general .kv_img-on_inner:before {
	background-image: url(../images/treatment/general/kv.jpg);
}

/*---------------------------------------------------------
 perio
---------------------------------------------------------*/
#perio .kv_img-on_inner:before {
	background-image: url(../images/treatment/perio/kv.jpg);
}

/*---------------------------------------------------------
 surgery
---------------------------------------------------------*/
#surgery .kv_img-on_inner:before {
	background-image: url(../images/treatment/surgery/kv.jpg);
}

/*---------------------------------------------------------
 cleaning
---------------------------------------------------------*/
#cleaning .kv_img-on_inner:before {
	background-image: url(../images/treatment/cleaning/kv.jpg);
}

/*---------------------------------------------------------
 ceramic
---------------------------------------------------------*/
#ceramic .kv_img-on_inner:before {
	background-image: url(../images/treatment/ceramic/kv.jpg);
}

/*---------------------------------------------------------
 denture
---------------------------------------------------------*/
#denture .kv_img-on_inner:before {
	background-image: url(../images/treatment/denture/kv.jpg);
}

/* denture - problem
==========================================================*/
#denture #problem {
	text-align: center;
}
#denture .prb-illust {
	width: 25%;
	max-width: 252px;
	margin: 0 auto;
}
#denture #problem .com-h--center {
	font-size: min(3.2vw,250%);
	margin-bottom: .2em;
}
#denture #problem .com-h--center span {
	position: relative;
	font-size: 147%;
}
#denture #problem .com-h--center span.line::before {
	position: absolute;
	content: "";
	background: url(../images/treatment/denture/problem_draw.svg) no-repeat center bottom;
	background-size: contain;
	width: 2.6em;
	height: .5em;
	left: 45%;
	bottom: 0;
	translate: -50% 0;
	z-index: -1;
}

#denture .prb-title .com-txt--fuki {
	font-size: min(3.6vw,2.5rem);
	margin-bottom: 0;
}
#denture .prb-title .com-txt--fuki span {
	font-size: 122%;
}
#denture .prb-title .com-txt--fuki::before,
#denture .prb-title .com-txt--fuki::after {
	height: 2.2em;
	bottom: -0.5em;
}
#denture .prb-title [lang="en"] {
	color: rgba(102,102,102,0.1);
	font-size: min(10vw,8.21rem);
	line-height: 1;
	margin: -0.1em auto -0.5em;
}
#denture .prb-img-wrap {
	position: relative;
	width: 96%;
	max-width: 1092px;
	margin: 0 auto 3%;
}
#denture .prb-img-wrap ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
#denture .prb-img-wrap ul > li {
	font-size: min(2.6vw,1.87rem);
	font-feature-settings: normal;
    width: min(11.2em);
    height: min(11.2em);
}
#denture .prb-img-wrap ul > li p:last-of-type {
	font-size: 60%;
	letter-spacing: .04em;
	margin-top: .6em;
}
#denture .prb-img-wrap div {
	position: absolute;
	width: 46%;
	max-width: 493px;
	left: 50%;
	top: 38%;
	translate: -50% -50%;
}

@media only screen and (min-width: 768px) {

#denture .prb-img-wrap ul > li {
	width: 31%;
}
#denture .prb-img-wrap ul > li:nth-of-type(1) {
	margin: 0 auto auto 6.7%;
}
#denture .prb-img-wrap ul > li:nth-of-type(2) {
	margin: 0 6.7% auto auto;
}
#denture .prb-img-wrap ul > li:nth-of-type(3) {
	margin: 2% 19% auto 0;
}
#denture .prb-img-wrap ul > li:nth-of-type(4) {
	margin: 2% 0 auto 19%;
}
#denture .prb-img-wrap ul > li:nth-of-type(5) {
	margin: -10% auto auto;
}

#denture #problem .com-txt--center {
	font-size: min(2vw,143%);
}
}

@media only screen and (max-width: 767px) {

#denture .prb-illust {
	width: 40%;
}
#denture #problem .com-h--center {
	font-size: 130%;
}
#denture #problem .com-h--center + p {
	text-align: left;
}

#denture .prb-title .com-txt--fuki {
	font-size: 4.5vw;
}
#denture .prb-img-wrap ul {
	column-gap: 2.5%;
}
#denture .prb-img-wrap ul > li {
	font-size: 4vw;
}
#denture .prb-img-wrap ul > li:nth-of-type(n+3) {
	margin-top: 20%;
}
#denture .prb-img-wrap ul > li:last-of-type {
	margin-top: -4%;
}
#denture .prb-img-wrap ul > li p:last-of-type {
	font-size: 70%;
}
#denture .prb-img-wrap div {
	width: 65%;
	top: 35%;
}

}

/*---------------------------------------------------------
 kids
---------------------------------------------------------*/
#kids .kv_img-on_inner:before {
	background-image: url(../images/treatment/kids/kv.jpg);
}

/* kids - family
==========================================================*/
#family {
	background-image: url(../images/treatment/kids/family-bg.png);
	background-size: 74% auto;
}
.fam__lead {
	position: relative;
}
.fam__title {
	max-width: 587px;
	margin: 0 auto 7%;
}
.fam__point {
	display: flex;
	justify-content: space-between;
}
.fam__point > li {
	width: 47.6%;
	max-width: 235px;
}
.fam__col3 p {
	font-size: min(1.8vw,125%);
}
.fam__col3 p span {
	display: block;
	font-size: 150%;
}

@media only screen and (min-width: 768px) {

.fam__lead {
	position: relative;
	padding-left: 50%;
}
.fam__point {
	position: absolute;
	width: 45%;
	max-width: 494px;
	left: 22%;
	bottom: 0;
	translate: -50% 0;
}
}

@media only screen and (min-width: 768px) and (max-width: 959px) {

.fam__lead {
	padding-left: 34%;
}
.fam__point {
	flex-direction: column;
	row-gap: 1em;
	left: 25%;
}
}

@media only screen and (max-width: 767px) {

#family {
	padding-top: 25%;
}
.fam__point {
	margin-top: 6%;
}
.fam__col3 p {
	font-size: 90%;
}
.fam__col3 p span {
	font-size: 130%;
}
}


/*---------------------------------------------------------
 orthodontics
---------------------------------------------------------*/
#orthodontics .kv_img-on_inner:before {
	background-image: url(../images/treatment/orthodontics/kv.jpg);
}

/* orthodontics - type-wrap
==========================================================*/
.ortho-type-wrap .com-h--radi {
	max-width: 20em;
}
.ortho-type-wrap figure .fz--sm {
	margin-bottom: .2em;
}

@media only screen and (min-width: 960px) {

.ortho-type-wrap figure {
	display: grid;
	justify-content: space-between;
	grid-template-columns: 41% 54%;
}
}

@media only screen and (max-width: 959px) {

.ortho-type-wrap figure .img {
	width: 70%;
	margin: 0 auto 5%;
}
.ortho-type-wrap figcaption div {
	text-align: center;
} 
}

/* orthodontics - col-support
==========================================================*/
.ortho-col-support > li::after {
	position: absolute;
	content: "";
	background: url(../images/treatment/orthodontics/icon_arrow.svg) no-repeat;
	background-size: contain;
	width: 14%;
	aspect-ratio: 1;
	left: 103%;
	top: 50%;
	translate: -50% -50%;
	border-radius: 50%;
	box-shadow: 0 0 8px rgba(0,0,0,0.15);
	z-index: 1;
}
.ortho-col-support > li:last-of-type:after {
	display: none;
}

@media only screen and (max-width: 767px) {

.ortho-col-support > li::after {
	left: 50%;
	top: calc(100% + 0.5em);
	rotate: 90deg;
}
}


/* orthodontics - col-pattern
==========================================================*/
.ortho-col-pattern > li {
	background-size: 37% auto;
}
.ortho-col-pattern > li:nth-of-type(1) {
	background-image: url(../images/treatment/orthodontics/col_bg_cross.png);
}
.ortho-col-pattern > li:nth-of-type(1) dt::before {
	background-color: rgba(102,102,102,0.5);
}
.ortho-col-pattern > li:nth-of-type(2) {
	background-image: url(../images/treatment/orthodontics/col_bg_circle.png);
	background-color: rgba(171,153,73,0.08);
}


/* orthodontics - merit
==========================================================*/
.ortho-merit .title-wrap [lang="en"] {
	position: relative;
	color: #666;
	font-size: min(4vw,297%);
	letter-spacing: .06em;
	line-height: 0.8;
}

.ortho-merit__col {
	margin-top: 3%;
}
.ortho-merit__col .icon {
	width: 31%;
	max-width: 106px;
	margin: 0 auto 5%;
}
.ortho-merit__col .com-h--center {
	color: #666;
	font-size: min(2vw,156%);
	margin-bottom: .2em;
}

.ortho-merit__method {
	background-color: #fff;
	margin: 3% auto 4%;
}
.ortho-merit__method dt {
	text-align: center;
	color: #fff;
	font-size: min(2vw,143%);
	line-height: 1.3;
	letter-spacing: .12em;
	background-color: rgba(0,0,0,0.3);
	box-sizing: border-box;
	padding: 1em 3%;
}
.ortho-merit__method dd {
	box-sizing: border-box;
	padding: 1.6em 4%;
}

@media only screen and (min-width: 768px) {

.ortho-merit > * {
	max-width: 1120px;
	margin-inline: auto;
}
.ortho-merit .title-wrap {
	display: flex;
}
.ortho-merit .title-wrap [lang="en"] {
	padding-right: .8em;
	margin-right: .8em;
	border-right: 1px solid #2d2737;
}
.ortho-merit .title-wrap > .com-h--accent {
	margin-bottom: 0;
}

.ortho-merit__method {
	display: grid;
	grid-template-columns: 30% 70%;
}
.ortho-merit__method dt {
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.ortho-merit__method .com-list {
	font-size: min(2vw,125%);
}
}

@media only screen and (max-width: 767px) {

.ortho-merit .title-wrap [lang="en"] {
	font-size: 5vw;
	padding-bottom: .8em;
	margin-bottom: .8em;
	border-bottom: 1px solid #2d2737;
}

.ortho-merit__col > li {
	display: grid;
	justify-content: space-between;
	align-items: center;
	grid-template-columns: 25% 68%;
	row-gap: 1em;
}
.ortho-merit__col .icon {
	grid-column: 1/2;
	grid-row: 1/2;
	width: 100%;
	margin: 0;
}
.ortho-merit__col .com-h--center {
	grid-column: 2/3;
	grid-row: 1/2;
	text-align: left;
	font-size: 110%;
	margin-bottom: 0;
}
.ortho-merit__col p {
	grid-column: 1/3;
	grid-row: 2/3;
}

.ortho-merit__method {
	margin: 6% auto 8%;
}
.ortho-merit__method dt {
	font-size: 105%;
}
.ortho-merit__method dd {
	padding: 1em 6% 1.5em;
}
}






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



@media only screen and (min-width: 768px) {

}

@media only screen and (min-width: 768px) and (max-width: 959px) {

}

@media only screen and (max-width: 767px) {


}