/*
 * What follows is the result of much research on cross-browser styling.
 * Credit left inline and big thanks to Nicolas Gallagher, Jonathan Neal,
 * Kroc Camen, and the H5BP dev community and team.
 */

/* ==========================================================================
   Base styles: opinionated defaults
   ========================================================================== */

html, body {
	text-align:center;
	font-family: dnp-shuei-gothic-kin-std, sans-serif;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	color: #3e3a39;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: .1em;
	line-height: 2.0em;
	padding: 0;
	margin: 0;
	background: #fff;
	-webkit-text-size-adjust: 100%;
}

/*
 * Remove text-shadow in selection highlight:
 * https://twitter.com/miketaylr/status/12228805301
 *
 * Vendor-prefixed and regular ::selection selectors cannot be combined:
 * https://stackoverflow.com/a/16982510/7133471
 *
 * Customize the background color to match your design.
 */

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

/*
 * A better looking default horizontal rule
 */

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}

/*
 * Remove the gap between audio, canvas, iframes,
 * images, videos and the bottom of their containers:
 * https://github.com/h5bp/html5-boilerplate/issues/440
 */

audio,
canvas,
iframe,
img,
svg,
video {
    vertical-align: middle;
}

/*
 * Remove default fieldset styles.
 */

fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

/*
 * Allow only vertical resizing of textareas.
 */

textarea {
    resize: vertical;
}
h1, h2, h3, h4, h5, h6, p, address, ul, ol, li, dl, dt, dd, table, caption, th, td, img, form {
    margin: 0;
    padding: 0;
    border: none;
    line-height: 100%;
    font-style: normal;
    font-weight: normal;
    font-size: 100%;
    list-style-type: none;
    border-collapse: collapse;
    vertical-align: top;
}

/* ==========================================================================
   Commons styles
   ========================================================================== */
a{text-decoration: none; color: inherit}
a:focus, *:focus { outline:none;}
a[href^="tel:"] {
	pointer-events: none;
	cursor: text;
}
img{border: 0px;}
p,h1,h2,h3,h4,h5{margin: 0;padding: 0}
ul,li,dl{margin: 0;padding: 0;list-style: none}
.b{font-weight: bold}
.fw_n{font-weight: normal}
.tx_und{text-decoration: underline}
.tx_cent{text-align: center}
.tx_right{text-align: right}
.tx_left{text-align: left}
.disp_blk{display: block}
.marker_tp_1 {background:rgba(0, 0, 0, 0) linear-gradient(transparent 55%, rgba(203,84,86,.85) 0%) repeat scroll 0 0; }
.fc_base{color: #2da4db!important}
.fc_red{color: #f81111}
.fc_pink{color: #f587a1}
.fc_pink_2{color: #fba6c2!important}
.fc_pup,.txt_col01{color: #eb6d80}
.fc_ora,.orange{color: #fbb731}
.fc_ora_2{color: #e28522!important}
.fc_green{color: #79ac00;}
.fc_blk_0,.txt_col04{color: #524a42;}
.fc_brown{color: #6a3906}
.fc_blue{color: #4472c4}
.fc_wht,.txt_white{color: #ffffff}
.fs_140p{font-size: 140%}
.fs_60{font-size: 60px}
.fs_58{font-size: 58px}
.fs_56{font-size: 56px}
.fs_54{font-size: 54px}
.fs_52{font-size: 52px}
.fs_50{font-size: 50px}
.fs_48{font-size: 48px}
.fs_46{font-size: 46px}
.fs_41{font-size: 41px}
.fs_40{font-size: 40px!important}
.fs_38{font-size: 38px}
.fs_37{font-size: 37px}
.fs_36{font-size: 36px}
.fs_33{font-size: 33px}
.fs_31{font-size: 31px}
.fs_30{font-size: 30px!important}
.fs_28{font-size: 28px}
.fs_26{font-size: 26px}
.fs_24{font-size: 24px}
.fs_20{font-size: 20px!important}
.fs_22{font-size: 22px!important}
.fs_18{font-size: 18px}
.fs_15{font-size: 15px}
.fs_16{font-size: 16px}
.fs_14{font-size: 14px}
.fs_13{font-size: 13px}
.fs_12{font-size: 12px}
.lh_28{line-height: 28px}
.bx_sdw_1{box-shadow:1px 1px 3px 1px #f2f2f2;}
.flex_wrapper{
　　display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
}
.flex-wrap_par{
	flex-wrap: wrap;
	display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;	
	display: flex;		
}
.hover:hover{
  opacity: 1;
  -webkit-animation: flash 1s;
  animation: flash 1.5s;
	transition-property: all;
  	transition: 0.15s linear;	
}
@-webkit-keyframes flash {
  0% {
    opacity: .4;
  }
  100% {
    opacity: 1;
  }
}
@keyframes flash {
  0% {
    opacity: .4;
  }
  100% {
    opacity: 1;
  }
}
.hover_0{
	transition-property: all;
  	transition: 0.15s linear;
}
.hover_0:hover{
	opacity: 0.5;
}
.pc{display: block}
.tab{display: none!important}		
.sp{display: none!important}
*, *:before, *:after {
    -webkit-box-sizing: border-box;
       -moz-box-sizing: border-box;
         -o-box-sizing: border-box;
        -ms-box-sizing: border-box;
            box-sizing: border-box;
}
.max_img{
	max-width: 100%;
	height: auto;
	display: block;
}
.img_w100{width: 100%; height: auto}
img.centered {
	display: block;
	margin-left: auto;
	margin-right: auto;
	}
img.alignright {
	padding: 4px;
	margin: 0 0 2px 10px;
	display: inline;
	}
img.alignleft {
	padding: 4px;
	margin: 0 10px 2px 0;
	display: inline;
	}
.alignright {
	float: right;
	}
.alignleft {
	float: left;
	}
.clear{clear: both}
.fs_21{font-size: 21px}
.fs_24{font-size: 24px}
/*-------------------------------------
ラッパー
--------------------------------------*/
.wrap_1250{
	max-width: 1250px;
	height: auto;
	margin: 0 auto;
	position: relative;
}
.wrap_1000{
	max-width: 1000px;
	height: auto;
	margin: 0 auto;
	position: relative;
}
.wrap_800{
	max-width: 800px;
	height: auto;
	margin: 0 auto;
	position: relative;
}
/*-------------------------------------
背景色
--------------------------------------*/
.bg_type_1 {
	background-color: #fff6f2
}
.bg_type_2 {
	background-color: #E0EEF5
}
.bg_type_3 {
	background-color: #ffffff
}

/*-------------------------------------
ボックス
--------------------------------------*/
.vx_type_1 {
	background: #fff6f2;
    padding: 70px 5% 75px;
    position: relative;
    overflow: hidden;
}
.vx_type_1 .med_check_title {
    font-weight: bold;
    text-align: center;
    margin-bottom: 55px;
}
.vx_type_1 .med_check_title dt {
    font-size: 125%;
    letter-spacing: 0.1em;
    margin-bottom: .8em;
    font-weight: 600;
}
.vx_type_1 .med_check_title dd span {
    font-size: 185%;
    letter-spacing: 0.15em;
    background: url(../img/check_icon.svg) no-repeat right center;
    padding: 5px 50px 5px 0;
    background-size: 45px 35px;
}
.vx_type_3{
    border: 7px solid #fff;
	padding: 6px;
    position: relative;	
}
.vx_type_3 .inn{
	width: 100%;
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
    padding: 35px 25px;
}
.vx_type_3.flt .inn{
	width: 100%;
    border-right: 3px solid #fff;
    border-bottom: 3px solid #fff;
    padding: 0 25px 35px!important;
}
.vx_type_3.blue{
    border: 7px solid #2da4db;
	padding: 6px;
    position: relative;	
}
.vx_type_3.ora{
    border: 7px solid #f0b688;
	padding: 6px;
    position: relative;	
}
.vx_type_3.blue .inn{
	width: 100%;
    border-right: 3px solid #2da4db;
    border-bottom: 3px solid #2da4db;
    padding: 35px 25px;
}
.vx_type_3.ora{
    border: 7px solid #f0b688;
	padding: 6px;
    position: relative;	
}
.vx_type_3.ora .inn{
	width: 100%;
    border-right: 3px solid #f0b688;
    border-bottom: 3px solid #f0b688;
    padding: 35px 25px;
}
.vx_type_3 .inn p{
	line-height: 1.8;
	letter-spacing: .05em;
}
.vx_type_3 .inn .in_tit{
	display: block;
	margin: 24px 0 14px;
}
.vx_type_3 .inn .in_tit.non_mgn{
	margin: 0 0 14px;
}
.vx_type_3 .inn .in_tit span{
	padding: 3px 10px;
	background-color: #f0b688;
	color: #FFF;
	font-size: 20px;
	font-weight: bold;
	text-align: center
}
.vx_type_3 .inn .in_tit.big span{
	font-size: 26px;
	display: block;
	color: #2da4db;	
	background-color: transparent;
	border: 1px solid #2da4db
}
.vx_type_3 .inn .in_tit span.green{
	background-color: #e2f138;
	color: #2da4db
}
.vx_type_3 .inn .in_tit span.blue{
	background-color: #2da4db;
}
.vx_type_3 .inn .vxz{
	margin: 0 0 55px;
	padding-bottom: 55px;
	border-bottom: 1px dotted #2da4db;
	clear: both;
	justify-content: space-between
}
.vx_type_3 .inn .vxz:last-of-type{
	margin: 0 0 0;
	padding-bottom: 0;
	border-bottom: none;
}
.vx_type_3 .inn .vxz .vx{
	width: 48%;
}
.vx_type_3 .inn .vxz .vx img{
	border: 1px solid #8DD3F4;
}

.med_check_li {
    max-width: 1050px;
    margin: 0 auto;
}
.med_check_li ul {
    justify-content: space-between
}
.med_check_li li {
    padding-bottom: 24px;
    margin-bottom: 18px;
    border-bottom: rgba(147,128,104,0.50) 1px solid;
    line-height: 1.7em;
    width: 48%;
}
.med_check_li li p, .med_check_li li dt {
    background: url(../img/check_box.svg) no-repeat left 6px;
    background-size: 25px;
    padding: 3px 0 3px 45px;
    font-weight: 700;
    font-size: 115%;
	line-height: 1.5
}
/*-------------------------------------
見出し
--------------------------------------*/
.h_type_1 {
	font-size: 34px;
    letter-spacing: .05em;
    line-height: 1.2em;
    margin-bottom: .5em;
	text-align: center
}
.h_type_2 {
    background: #2da4db;
    background-size: 2.2em auto;
	border-radius: 40px 0 0 0;
    padding: .5em 3%;
    text-align: center;
    color: #fff;
    font-size: 200%;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.6em;
    margin-bottom: 40px;
}	
.h_type_3 {
	padding-top: 90px;
    margin-bottom: 55px;
    text-align: center;
    color: #2da4db;
    font-size: 205%;
    font-weight: bold;
    letter-spacing: .12em;
    line-height: 1.6em;
    position: relative;
}	
.h_type_3::before {
	content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 35px;
    margin: 0 auto;
    width: 26px;
    height: 26px;
	background-image: url("../img/tooth_ico_1.png")
}
.h_type_3::before {
	content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 35px;
    margin: 0 auto;
    width: 26px;
    height: 26px;
	background-image: url("../img/tooth_ico_1.png")
}
.h_type_3.fc_ora_2::before {
	background-image: url("../img/tooth_ico_1_ora.png")
}

.h_type_4 {
	padding: 34px 10px;
    margin-bottom: 40px;
    text-align: center;
    font-size: 205%;
    font-weight: bold;
    letter-spacing: .12em;
    line-height: 1.6em;
    position: relative;
	border-bottom: 1px solid #e28522;
	border-top: 1px solid #e28522
}	
.h_type_4.blue {
	border-bottom: 1px solid #2da4db;
	border-top: 1px solid #2da4db
}	
.h_type_2 span,.h_type_4 span {
    display: block;
	font-size: 16px;
}	
.h_type_5{
	font-size: 140%;
    font-weight: 600;
    color: #888888;
    letter-spacing: 0.05em;
    margin-bottom: 15px;
    position: relative;
    line-height: 1.3em;
}
.h_type_5 i{
    padding-right: 0.4em;
}
.h_type_6{
	display: inline-block;
	padding: 26px 10px;
	font-size: 140%;
    font-weight: 600;
    letter-spacing: 0.05em;
    margin-bottom: 15px;
    position: relative;
    line-height: 1.3em;
	border-bottom: 1px solid #2da4db;
	border-top: 1px solid #2da4db	
}
.h_type_7{
	padding: 26px 10px;
	font-size: 140%;
    font-weight: 600;
    letter-spacing: 0.05em;
    margin-bottom: 15px;
    position: relative;
    line-height: 1.3em;
	text-align: center;
	border-bottom: 1px solid #2da4db;
	border-top: 1px solid #2da4db	
}
.h_type_7.fc_ora_2{
	border-bottom: 1px solid #f09b37;
	border-top: 1px solid #f09b37	
}
.h_type_8{
	padding: 26px 10px;
	font-size: 160%;
    font-weight: 600;
	color: #2da4db;
    letter-spacing: 0.05em;
    margin-bottom: 15px;
    line-height: 1.3em;
	text-align: center;
	border-bottom: 2px solid #2da4db;
}
.vx_type_3.ora .h_type_8{
	color: #f0b688;
	border-bottom: 2px solid #f0b688;
}

/*-------------------------------------
ボタン
--------------------------------------*/
.btn_type_1{
    width: 100%;
    max-width: 250px;
    margin: 0 auto;
}
.btn_type_1 a{
    display: block;
    padding: 1.0em 0;
    background: rgba(205,187,141,0.2);
    border-radius: 50px;
    line-height: 1.2em;
    letter-spacing: .15em;
    position: relative;	
}
/*-------------------------------------
anime
--------------------------------------*/

/*-------------------------------------
余白
--------------------------------------*/
.sec_pad_1{
	padding: 60px 0
}
.sec_pad_1_b{
	padding-bottom: 60px
}
.sec_pad_1_t{
	padding-top: 60px;
}
.pl_40{padding-left: 40px}
.mt_10{margin-top: 10px}
.mt_20{margin-top: 20px}
.mt_30{margin-top: 30px!important}
.mt_40{margin-top: 40px!important}
.mt_42{margin-top: 42px}
.mt_60{margin-top: 60px}
.ml_40{margin-left: 40px}
.mr_40{margin-right: 40px!important}
.mr_30{margin-right: 30px!important}
.mr_30{margin-right: 30px!important}
.mb100 {margin-bottom: 100px!important;}
.mb90 {margin-bottom: 90px;}
.mb75 {margin-bottom: 75px;}
.mb70 {margin-bottom: 70px;}
.mb60 {margin-bottom: 60px;}
.mb55 {margin-bottom: 55px;}
.mb40 {margin-bottom: 40px;}
.mb35 {margin-bottom: 35px;}
.mb30 {margin-bottom: 30px;}
.mb25 {margin-bottom: 25px;}
.mb20 {margin-bottom: 20px;}
figure{margin: 0;padding: 0}
.no_links{
	pointer-events: none;
	cursor: default;
	text-decoration:none;
}
/* -------------------------------------
loopslider
------------------------------------- */
#loopslider {
  margin: 0 auto;
  width: 100%;
  height: 360px;
  text-align: left;
  position: relative;
  overflow: hidden;
}
#loopslider ul {
  float: left;
  overflow: hidden;
  display: inline-block;
}
#loopslider ul li {
  width: 1600px;
  height: 360px;
  float: left;
  display: inline;
  overflow: hidden;
}
#loopslider ul:after {
  content: " ";
  height: 0;
  clear: both;
  display: block;
  visibility: hidden;
}
#loopslider ul li img {
  max-width: none;
}
.tx_sdw_1{
    text-shadow: 1px 1px 0 #9f9f9f, -1px -1px 0 #9f9f9f, -1px 1px 0 #9f9f9f, 1px -1px 0 #9f9f9f, 0px 1px 0 #9f9f9f, 0-1px 0 #9f9f9f, -1px 0 0 #9f9f9f, 1px 0 0 #9f9f9f;	
}
/* ==========================================================================
   Author's custom styles
   ========================================================================== */
header.general{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;	
	padding: 40px 2%;
	justify-content: space-between;
	align-items: center;
	/* background: url("../img/deco_h.png") no-repeat left top; */
	/* background-size: 145px auto; */
	z-index: 9999
}
header.general h1{
	padding: 0 0 0 5%
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}
.tbl_time01 thead th {
    padding: 9px 0 12px;
	letter-spacing: .05em
}
.tbl_time01 {
    width: 100%;
    width: 338px;
	font-size: 13px;
}
.tbl_time01.day8 {
    max-width: 350px;
}
.tbl_time01 table {
	background: #fff;
	border-top: 1px solid;
	border-bottom: 1px solid;
	border-color: #434343;
}
.tbl_time th{font-weight: bold}
.tbl_time td span, .tbl_time .tbl_caption span {
	color: #2da4db;
	font-size: 8px
}
.tbl_time01.day8 thead th:first-child, .tbl_time01.day8 tbody th {
    width: 40%;
}
.tbl_time01 table {
    width: 100%;
}
.tbl_time01 tbody td {
    padding: 0 0 8px;
}
.tbl_time01 thead th:not(:first-child), .tbl_time01 tbody td {
    width: calc(50% / 6);
    text-align: left;
}
.tbl_time01 tbody td {
    font-size: 87.5%;
    padding-left: .05em;
}
.tbl_time01.day8 thead th:not(:first-child), .tbl_time01.day8 tbody td {
    width: calc(54% / 7);
}
.tbl_caption {
    margin-top: 10px;
    line-height: 1.5;
	letter-spacing: .08em;
	font-size: 12px;
	font-weight: 600;
	text-align: left
}
.cvz{
	margin-right: 40px;
	font-weight: 500
}
.cvz .telz span.cap{
	padding-right: 20px;
	font-size: 13px;
	line-height: 1.25;
	font-weight: bolder;	
	letter-spacing: .05em
}
.cvz .telz a{
	align-items: center
}
.cvz .telz a img{
	max-width: 30px
}
.cvz .telz a span{
	padding-left: 12px;	
	font-size: 36px;
	font-weight: bold;
	letter-spacing: .08em;
	line-height: 1;
	color: #292929
}
@media all and (-ms-high-contrast: none){
.cvz .telz span.cap {
    padding-top: 10px
}	
.cvz .telz a span{
	padding-top: 22px;	
}
}

.cvz .mailz {
	margin-top: 10px
}
.cvz .mailz .vx a{
	width: 100%;
	height: 100%;
	padding: 14px 0;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	flex-wrap: wrap;
}
header.general .cvz .mailz .vx.arrw a::after,
.time_info .infoz .cvz .mailz .vx.arrw a::after,
.cvz.tp_under .mailz .vx.arrw a::after{
    right: 3%;
	top: calc(50% - 14px);
	margin: auto;
	font-size: 14px;
    color: #FFF;
}
.cvz .mailz .rza{
	width: 60%;
	background-color: #e2f138
}
.cvz .mailz .vx a p {
	margin-left: 10px;
	line-height: 1.1
}
.cvz .mailz .vx a p span.nom{
	font-size: 18px;
}
.cvz .mailz .vx a p span.big{
	font-size: 30px;
	letter-spacing: .1em
}
.cvz .mailz .free{
	text-align: center;
	width: 40%;
	background-color: #f0b688
}
.cvz .mailz .free a {
	display: block
}
.cvz .mailz .free a p{
	text-align: center;
	margin: 6px 0 0 0
}
.cvz .mailz .free a p span{
}
.home .fv{
	width: 100%;
	position: relative;
	top: 0;
	left: 0;
}
.home .fv .slick {
    position: relative
}
.home .fv .slick li::before, .home .fv .slick li::after {
    content: "";
    position: absolute;
    z-index: 8888;
    width: 100%;
    left: 0;
}
.home .fv .slick li::before {
	height: 40%;
	top: 0;
background: -moz-linear-gradient(top, rgba(255,255,255,1) 30%, rgba(255,255,255,0) 100%);
background: -webkit-linear-gradient(top, rgba(255,255,255,1) 30%,rgba(255,255,255,0) 100%);
background: linear-gradient(to bottom, rgba(255,255,255,1) 30%,rgba(255,255,255,0) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#00ffffff',GradientType=0 );
}
.home .fv .slick li::after {
	height: 20%;
	bottom: 0;
background: -moz-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 100%);
background: -webkit-linear-gradient(top, rgba(255,255,255,0) 0%,rgba(255,255,255,1) 100%);
background: linear-gradient(to bottom, rgba(255,255,255,0) 0%,rgba(255,255,255,1) 100%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#ffffff',GradientType=0 );
}
.home .fv .slick li {
}
.home .fv .slick li img.mn {
	width: 100%;
    height: 960px;
    object-fit: cover;
    object-position: center;
    font-family: 'object-fit: cover;';
}
.home .fv .slick li figure img {
	position: absolute;
	top:0;
	left: 0;
	right: 0;
	bottom: 0;
	margin:auto;
}
.slick-dots {
	position: absolute;
	z-index: 10;
	bottom: 120px;
	left: 0;
	right: 0;
    margin: 0 auto;
    padding: 0;
	width: 30%;
    max-width: 150px;
	line-height: 2px;
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: center;
    align-items: center;
	opacity: 0.7;
}
.slick-dots li {
    position: relative;
    width: 18%;
    height: 2px;
    margin: 0;
    padding: 0;
    cursor: pointer;
}
.slick-dots li button {
    font-size: 0;
    line-height: 0;
    display: block;
    width: 100%;
    height: 2px;
    cursor: pointer;
    color: transparent;
    border: 0;
    outline: none;
	padding: 0;
	margin: 0;
    background: #009f9e;
	-webkit-transition: background-color 1.0s;
	-moz-transition: background-color 1.0s;
	transition: background-color 1.0s;
}
.slick-dots li button:hover,
.slick-dots li button:focus,
.slick-dots li.slick-active button {
    outline: none;
    background: #e2933d;
}
nav.general{
	position: absolute;
	width: 100%;
	margin-top: -100px;
}
nav.general .cvz{
	display: none
}
nav.general ul{
	padding: 1.5vw 2%;
    text-align: center;
	background-color:rgba(45,164,219,.88);
    letter-spacing: .25em;
    line-height: 1.4em;
}
nav.general ul li{
	flex: 1;
	position: relative;
	padding: 16px 0;
	border-left: solid 1px rgba(255,255,255,0.5);
}
nav.general ul li:first-child{
	border-left: none
}
nav.general ul li a{
	color: #FFF;
	display: block;
	width: 100%;
	text-align: center;
}
nav.general ul li a p{
	padding-bottom: 16px;
	font-weight: bold;
	line-height: 1.5;
}
nav.general ul li a span{
	display: block
}
nav.general ul > li::before {
    content: "";
    position: absolute;
    width: 4px;
    height: 4px;
    border-radius: 10px;
    background: #ffff86;
    left: 0;
    right: 0;
    bottom: 100%;
    margin: auto;
    opacity: 0;
    -webkit-transition: opacity 0.7s;
    -moz-transition: opacity 0.7s;
    transition: opacity 0.7s;
}
nav.general ul > li.select::before {
    opacity: 1;
}
nav.general ul > li:hover::before {
	opacity: 1;	
}
nav.general ul > li.select a,
nav.general ul > li:hover > a,
nav.general ul > li:hover > span {
	color: #ffff86;
}
nav.general ul > li a span {
	font-size: 12px
}
nav.general.fixed .for_fix{
	display: flex;
}
nav.general.fixed{
	width: 100%;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 9999;
	margin-top: 0;
  	animation: SlideIn 1.6s;
}
@keyframes SlideIn {
  0% {
    opacity: 0;
    transform: translateY(-64px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

nav.general.fixed ul{
	width: 74%;
	max-width: 100%;
	padding: 0.5vw 0;
	align-items: center
}
nav.general.fixed ul li {
    padding: 8px 0;
}
nav.general.fixed ul li a p {
    padding-bottom: 8px;
	font-size: 1vw
}
nav.general.fixed .cvz{
	display: block;
	width: 26%;
	margin-right: 0;
}
nav.general.fixed .cvz .telz {
    margin-top: 0;
	padding: 2%;
	height: 50%;
	justify-content: center;
	align-items: center;
	background-color:rgba(45,164,219,1);
	color: #FFF
}
nav.general.fixed .cvz .telz a span {
	color: #FFF;
	font-size: 2vw
}

nav.general.fixed .cvz .mailz {
    margin-top: 0;
	height: 50%;
	align-content: center;
	justify-content: center
}
nav.general.fixed .cvz .mailz .vx a {
	padding: 3%;	
}
nav.general.fixed .cvz .mailz .vx a img {
	display: block;
	max-width: 100%
}

nav.general.fixed .cvz .mailz .vx a p span.nom {
    font-size: 1vw;
}
nav.general.fixed .cvz .mailz .vx a p span.big {
    font-size: 1.5vw;
}
nav.general.fixed .cvz .mailz .free a {
    display: block;
}
nav.general.fixed .cvz .mailz .free a img{
	max-width: 100%;
	display: block;
	margin: 0 auto
}
nav.general.fixed .cvz .mailz .free a p{
    margin: 0 0 0 0
}
nav.general.fixed .cvz .mailz .free a p span{
    font-size: 1vw;
}

.sub_m_tgt{cursor: pointer}
.sub_m_cov{display: none}
.sub_menu{
	background-color: #e0f5ff;
	z-index: 99999
}
.sub_menu .vx{
	width: 25%;
}
.sub_menu .vx a {
    display: block;
	text-align: left;
    padding: 1.0em;
    position: relative;
	font-weight: bold;
	transition-property: all;
  	transition: 0.1s linear;
	border: 1px solid rgba(255,255,255,.3)
}
.sub_menu .vx a:hover {
    background-color: rgba(255,255,255,0.8);		
}
.arrw a{
	position: relative;
}
.arrw a::after{
	position: absolute;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f0a9";
	right: 6%;
	color: #747474
}
.taisetsu {
    background: url(../img/concept_bg@2x.jpg) no-repeat right top;
    background-size: 900px auto;
    position: relative;
    padding-top: 150px;
}
.taisetsu::before {
    content: "";
    position: absolute;
    z-index: 0;
    width: 100%;
    height: 30%;
    left: 0;
    top: 0;
    opacity: 0.15;
    background: rgb(247,199,44);
    background: -moz-linear-gradient(top, rgba(247,199,44,1) 0%, rgba(255,255,255,1) 70%);
    background: -webkit-linear-gradient(top, rgba(247,199,44,1) 0%,rgba(255,255,255,1) 70%);
    background: linear-gradient(to bottom, rgba(247,199,44,1) 0%,rgba(255,255,255,1) 70%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f7c72c', endColorstr='#ffffff',GradientType=0 );
}
.taisetsu .lead, .taisetsu .box01 {
    position: relative;
    z-index: 1;
}
.taisetsu .lead h2 {
    width: 70%;
}
.taisetsu .lead p {
    margin-top: 30px;
    width: 100%;
    max-width: 660px;
    font-size: 110%;
    letter-spacing: .05em;
    line-height: 2.0em;
    padding-bottom: 40px;
}
.blocklink, .blocklink_out, .blocklink_ank {
    cursor: pointer;
}
.taisetsu .lead, .taisetsu .box01 {
    position: relative;
    z-index: 1;
}
.taisetsu .box01 {
    margin-bottom: 60px;
}
.taisetsu .box01 .img_list {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto 30px;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: flex-start;
    align-items: flex-start;
    position: relative;
    z-index: 0;
}
.taisetsu .box01 .img_list li {
    position: relative;
    text-align: left;
}
.taisetsu .box01 .img_list li:first-child {
    width: 55%;
    padding-top: 30px;
}
.taisetsu .box01 .img_list li p {
    position: relative;
    z-index: 0;
}
ul img {
    vertical-align: top;
    margin: 0;
}
img {
    max-width: 100%;
    height: auto;
    width: auto\9;
    border-top-style: none;
    border-right-style: none;
    border-bottom-style: none;
    border-left-style: none;
    vertical-align: top;
}
.taisetsu .box01 .img_list li .caption {
    position: absolute;
    z-index: 1;
    width: 100%;
    box-sizing: border-box;
    left: 0;
    bottom: 0;
    background: -moz-linear-gradient(left, rgba(45,164,219,0.7) 30%, rgba(45,164,219,0) 100%);
    background: -webkit-linear-gradient(left, rgba(45,164,219,0.7) 30%,rgba(45,164,219,0) 100%);
    background: linear-gradient(to right, rgba(45,164,219,0.7) 30%,rgba(45,164,219,0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#b3f7c72c', endColorstr='#00f7c72c',GradientType=1 );
    padding: 1.0em;
    color: #fff;
    font-size: 120%;
    font-weight: bold;
    letter-spacing: .05em;
    line-height: 1.2em;
}
.taisetsu .box01 .img_list li:last-child {
    width: 45%;
}
.taisetsu .box01 .txt_box {
    position: relative;
    z-index: 1;
}
.taisetsu .box01 .txt_box h3 {
    position: absolute;
    width: 25%;
    text-align: right;
    right: 4%;
    top: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
.flex_box {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
}
.taisetsu .box01 .txt_box .flex_box {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: center;
    align-items: center;
}
.taisetsu .box01 .txt_box .flex_box p {
    width: 236px;
}
.taisetsu .box01 .txt_box .flex_box dl {
    width: calc(97% - 207px);
    max-width: 930px;
}
.taisetsu .box01 dt, .taisetsu .box02 dt {
    font-size: 200%;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.6em;
    margin-bottom: .5em;
}
.taisetsu .box01 .txt_box .flex_box dt {
    width: 70%;
}
.taisetsu .box01 .txt_box .flex_box dd {
    width: 100%;
    max-width: 600px;
	line-height: 2em;
	font-weight: 500
}
.taisetsu .box02 {
    background: #2da4db url(../img/concept_img2_1@2x.jpg) no-repeat left center;
    background-size: contain;
    color: #fff;
    position: relative;
    padding: 60px 0;
}
.taisetsu .box02 .guie_box {
    position: absolute;
    z-index: 0;
    left: 0;
    bottom: 0;
    width: 45%;
}
.taisetsu .box02 .guie_box p {
    background: -moz-linear-gradient(left, rgba(255,255,255,0.95) 50%, rgba(255,255,255,0) 100%);
    background: -webkit-linear-gradient(left, rgba(255,255,255,0.95) 50%,rgba(255,255,255,0) 100%);
    background: linear-gradient(to right, rgba(255,255,255,0.95) 50%,rgba(255,255,255,0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#f2ffffff', endColorstr='#00ffffff',GradientType=1 );
    text-align: left;
}
.taisetsu .box02 .flex_box {
    position: relative;
    z-index: 1;
    width: 90%;
    max-width: 850px;
    margin-left: auto;
    margin-right: 0;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-align-items: center;
    align-items: center;
}
.taisetsu .box02 .flex_box h3 {
    width: 35%;
}
.taisetsu .box02 .flex_box dl {
    width: 62%;
}
.taisetsu .box01 dt, .taisetsu .box02 dt {
    font-size: 200%;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.6em;
    margin-bottom: .5em;
}
.taisetsu .box02 dd {
    line-height: 2em;
}
.taisetsu .box0345 {
    padding: 40px 0 100px;
    position: relative;
}
.taisetsu .box0345::before {
    content: "";
    position: absolute;
    z-index: 0;
    width: 100%;
    height: 20px;
    left: 0;
    bottom: 0;
    opacity: 0.15;
    background: -moz-linear-gradient(top, rgba(0,0,0,0) 0%, rgba(0,0,0,0.65) 100%);
    background: -webkit-linear-gradient(top, rgba(0,0,0,0) 0%,rgba(0,0,0,0.65) 100%);
    background: linear-gradient(to bottom, rgba(0,0,0,0) 0%,rgba(0,0,0,0.65) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00000000', endColorstr='#a6000000',GradientType=0 );
}
.taisetsu .box0345 ul {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-left: -6%;
}
.taisetsu .box0345 li {
	position: relative;	
    width: 27.3333%;
    margin-left: 6%;
    text-align: center;
}
.taisetsu .box0345 li:nth-child(odd) h3 {
    position: absolute;
    z-index: 1;
    text-align: left;
    width: 70%;
    padding-left: 8%;
}
.taisetsu .box0345 li:nth-child(even) h3 {
    position: relative;
    z-index: 1;
    text-align: left;
    width: 70%;
    padding-left: 8%;
    padding-top: 120px;
}
.taisetsu .box0345 li:nth-child(odd) p {
    position: relative;
    z-index: 0;
    padding-top: 120px;
}
.taisetsu .box0345 li:nth-child(even) p {
    position: absolute;
    z-index: 0;
}
.taisetsu .box0345 li dt {
    font-size: 160%;
    font-weight: bold;
    letter-spacing: .05em;
    line-height: 1.6em;
    margin: 1.0em 0 .5em;
}
.taisetsu .box0345 li dd {
    text-align: left;
    line-height: 2em;	
}
.taisetsu .box0345 li:nth-child(even) {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}
.taisetsu .box0345 li:nth-child(even) h3 {
    -webkit-order: 1;
    order: 1;
    margin-top: -1.0em;
}
.taisetsu .box0345 li:nth-child(even) h3 {
    -webkit-order: 1;
    order: 1;
    margin-top: -1.0em;
}
.taisetsu .box0345 li:nth-child(even) dl {
    -webkit-order: 2;
    order: 2;
}
.time_info{
	margin-top: 100px;	
	border-top: 3px solid #2da4db;
	border-bottom: 3px solid #2da4db
}
.time_info .infoz{
	justify-content: center
}
.home .news h2{
	margin-bottom: 30px
}
.home .news dl{
	padding: 30px;
    height: 250px;
}
.home .news dl dt{
	font-size: 14px;
	color: #181310;
	margin-bottom: 10px
}
.home .news dl dd{
	margin-bottom: 34px;
	font-weight: 550;
	line-height: 1.8
}
.home .news dl dd:last-child{
	margin-bottom: 0
}
.home .news .btn_type_1{
	margin-top: 30px
}
.med_lead {
    background: url("../img/medi_bg.jpg") no-repeat center center;
    background-size: cover;
    padding: 100px 0 80px;
}
.w1320 {
    width: 94%;
    padding: 0 3%;
    max-width: 1320px;
    margin: 0 auto;
    text-align: left;
}
.med_lead .w1320 {
    text-align: center;
    color: #fff;
}
.med_lead h2 {
    font-size: 150%;
    font-weight: bold;
    letter-spacing: .05em;
    line-height: 1.2em;
    margin-bottom: .8em;
}
.fw_light {
    font-weight: 400;
}
.med_lead h2 span {
    display: block;
    font-size: 340%;
    letter-spacing: .05em;
    line-height: 1.2em;
}
.med_lead p {
    line-height: 2.0em;
}
.med_lead .abs_box {
    position: relative;
    margin: 50px 0 30px;
}
.med_lead .abs_box h3 {
    width: 28%;
    max-width: 360px;
    position: absolute;
    left: 0;
    top: 0;
}
.change_img img {
    margin-left: auto;
    margin-right: auto;
}
.med_lead .abs_box ul {
    width: 70%;
    max-width: 903px;
    margin-left: auto;
    margin-right: 0;
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}
.med_lead .abs_box li {
    width: calc(33.3333% - 1px);
    margin-left: 1px;
    margin-bottom: 1px;
}
.med_lead .abs_box li a {
    display: block;
    padding: 1.3em 0;
    background: -moz-radial-gradient(center, ellipse cover, rgba(255,255,255,1) 30%, rgba(255,255,255,0.8) 100%);
    background: -webkit-radial-gradient(center, ellipse cover, rgba(255,255,255,1) 30%,rgba(255,255,255,0.8) 100%);
    background: radial-gradient(ellipse at center, rgba(255,255,255,1) 30%,rgba(255,255,255,0.8) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#ccffffff',GradientType=1 );
    font-size: 120%;
    letter-spacing: .1em;
    line-height: 1.4em;
    position: relative;
	color: #3e3a39;	
}
.med_lead .abs_box li a span {
    font-size: 110%;
    font-weight: bold;
}
.med_lead .abs_box .arrw a::after {
    right: 3%;
	bottom: 3%;
	font-size: 16px
}
.w1200 {
    width: 94%;
    padding: 0 3%;
    max-width: 1200px;
    margin: 0 auto;
    text-align: left;
}
.first {
    text-align: center;
    padding-top: 70px;
    padding-bottom: 70px;
    position: relative;
}
.first .in_box {
    width: 70%;
    margin: 0 auto;
}
.first h3 {
    font-size: 200%;
    font-weight: bold;
    letter-spacing: .05em;
    line-height: 1.2em;
    margin-bottom: .5em;
}
.sp_abs_box p{
    line-height: 2.0em;
	font-weight: 500;
	letter-spacing: .02em
}
.first .btn {
    width: 80%;
    max-width: 600px;
    margin: 1.5em auto 0;
}
.first .btn a {
    display: block;
    background: #f0b688;
    box-shadow: 0px 5px 15px 0px rgb(0 0 0 / 15%);
    padding: 1.6em 0;
    border-radius: 50px;
    font-size: 130%;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.2em;
    position: relative;
}
.first .abs {
    position: absolute;
    z-index: 1;
    width: 15%;
    right: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    text-align: left;
}
.first .arrw a::after {
    color: #FFF;
}
.yobo {
    background: url(../img/yobo_bg@2x.jpg) no-repeat left top;
    background-size: contain;
    position: relative;
    padding-top: 80px;
    padding-bottom: 60px;
}
.yobo::before {
    content: "";
    position: absolute;
    z-index: 0;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    opacity: 0.25;
    background: -moz-linear-gradient(top, rgba(255,255,134,1) 0%, rgba(255,255,134,0) 100%);
    background: -webkit-linear-gradient(top, rgba(255,255,134,1) 0%,rgba(255,255,134,0) 100%);
    background: linear-gradient(to bottom, rgba(255,255,134,1) 0%,rgba(255,255,134,0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffff86', endColorstr='#00ffff86',GradientType=0 );
}
.yobo .w1200 {
    position: relative;
    z-index: 1;
}
.yobo .l_img {
    width: 32%;
    max-width: 340px;
    position: absolute;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
.yobo .r_box {
    width: 58%;
    max-width: 700px;
    margin-left: auto;
    margin-right: 0;
}
.yobo .r_box h3 {
    font-size: 270%;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.4em;
    margin-bottom: .5em;
}
.fw_normal {
    font-weight: 500;
}
.yobo .r_box h3 span {
    display: block;
    font-size: 75%;
    letter-spacing: .1em;
    line-height: 1.2em;
    margin-bottom: .2em;
}
.yobo .r_box .arrw a::after {
    right: 0;
    color: #f0b688;
}
.yobo .r_box h3 i {
    color: #f0b688;
    font-size: 90%;
    margin-left: .2em;
}
.yobo .r_box p {
    line-height: 2em;
}
.med_pickup {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
}
.med_pickup li {
    width: 50%;
    background-repeat: no-repeat;
    background-position: left center;
    background-size: contain;
    box-sizing: border-box;
    padding: 60px 3% 50px;
    padding-left: 18%;
    text-align: left;
    color: #fff;
    position: relative;
	text-shadow:1px 1px 0 #7a7a7a,-1px 1px 0 #7a7a7a,1px -1px 0 #7a7a7a,-1px -1px 0 #7a7a7a;
}
.med_pickup li:first-child {
    background-color: #2da4db;
    background-image: url(../img/imp_bg@2x.jpg);
}
.med_pickup li::before {
    content: "";
    position: absolute;
    z-index: 0;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    opacity: 0;
}
.med_pickup li:first-child::before {
    background: #2da4db;
}
.med_pickup li > div {
    position: relative;
    z-index: 1;
}
.med_pickup li h3 {
    font-size: 240%;
    font-weight: bold;
    letter-spacing: .15em;
    line-height: 1.2em;
    margin-bottom: .3em;
}
.med_pickup li p {
    line-height: 2em;
	letter-spacing: .05em
}
.med_pickup li:last-child {
    background-color: #f09b37;
    background-image: url(../img/yobo_bur_bg@2x.jpg);
}
.med_pickup li:last-child::before {
    background: #f09b37;
}
.med_pickup li h3 i {
    margin-left: .2em;
}
.med_pickup li h3 span {
    display: block;
    font-size: 50%;
    letter-spacing: .1em;
    line-height: 1.6em;
    margin-bottom: .4em;
}
.med_other {
    padding-top: 60px;
    padding-bottom: 100px;
}
.med_other ul {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-left: -1.3333%;
}
.med_other li {
    width: 24%;
    margin-left: 1%;
    margin-bottom: 1%;
    text-align: center;
    background: #cdbb8d;
    position: relative;
}
.med_other li a {
    display: flex;
	flex-wrap: wrap;
	justify-content: center;
    padding: 1.4em 0;
	height: 100%;
	align-items: center;
    color: #fff;
    font-size: 120%;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.2em;
}
.med_other li.arrw a::after {
    color: #FFF;
}
.rec_box {
    position: relative;
    padding: 100px 0;
}
.rec_box::before {
    content: "";
    position: absolute;
    z-index: 0;
    width: 100%;
    height: 30px;
    left: 0;
    top: 0;
    opacity: 0.15;
    background: -moz-linear-gradient(top, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0) 100%);
    background: -webkit-linear-gradient(top, rgba(0,0,0,0.65) 0%,rgba(0,0,0,0) 100%);
    background: linear-gradient(to bottom, rgba(0,0,0,0.65) 0%,rgba(0,0,0,0) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#a6000000', endColorstr='#00000000',GradientType=0 );
}
.bnr_recruit {
    max-width: 750px;
    margin: 0 auto;
    background: url(../img/bnr_recruitment@2x.png) no-repeat left top;
    background-size: cover;
    text-align: center;
    color: #ffffff;
    position: relative;
}
.bnr_recruit dl {
    padding: 30px 0;
}
.bnr_recruit dt {
    font-size: 450%;
    letter-spacing: 0.1em;
    margin-bottom: 10px;
    line-height: 1em;
    font-weight: 400;
}
.bnr_recruit dd {
    color: #ffffff;
    font-size: 120%;
    line-height: 1.4em;
    font-weight: bold;
}
.bnr_recruit dd span {
	padding-top: 12px;
	display: inline;
    color: #ffff00;
}
.bnr_recruit dd a {
	position: absolute;
	width: 100%;
	height: 100%
}
.bnr_recruit i {
    position: absolute;
    right: 20px;
    bottom: 20px;
    font-size: 150%;
}
.bnr_recruit a {
    position: absolute;
    left: 0;
    top: 0;
	width: 100%;
	height: 100%;
}
.top .bnr_recruit {
    background-image: url(../img/bnr_kakaritsuke.png);
}
.top .bnr_recruit dt {
    font-size: 380%;
}
.top .bnr_recruit dt span {
    font-size: 50%;
}

#page_top {
	display: none;
    position: fixed;
    bottom: 60px;
    right: 0;
    z-index: 1000;
    width: 6%;
    max-width: 65px;
}

footer{background: #eef6f3}
footer .btnz .vx{
	width: 33.33333333%;
	padding: 1.6vw 1vw;
	background: #737373;
	position: relative;
	text-align: center;
	color: #FFF;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	flex-wrap: wrap;	
}
footer .btnz .vx a{
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0
}
footer .btnz .vx.arrw a::after {
    right: 3%;
	bottom: 3%;
	font-size: 20px;
    color: #FFF;
}
footer .btnz .tel{
	background: rgba(45,164,219,1)
}
footer .btnz .tel p {
	margin-bottom: 1.3vw;	
	justify-content: center;
	align-items: center;
}
footer .btnz .vx p span{
	display: block;
	padding-left: 14px;	
	font-size: 1.2vw;
}
footer .btnz .tel .num{
	font-size: 2.2vw;
}
footer .btnz .rza{
	background: #e2f138
}
footer .btnz .rza{
	background: #e2f138
}
footer .btnz .rza p,
footer .btnz .mail p{
	margin-top: 1vw;		
	display: block;
	width: 100%;
}
footer .btnz .rza p .big{
	font-size: 2.1vw;
	line-height: 3vw
}
footer .btnz .mail{
	background: #f0b688
}
footer .btnz .mail p .big{
	font-size: 1.5vw;
}
footer .mn_stg article{
	justify-content: space-between
}
footer .mn_stg .vx{
	width: 48%;
	text-align: left
}
footer .mn_stg .info h2 {
    font-size: 200%;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.2em;
    margin-bottom: 1.0em;
}
footer .mn_stg .info p {
    line-height: 2.0em;
	margin-bottom: 1.5em;
}
footer .tbl_time01 {
    font-size: 18px;
}
footer .tbl_time01.day8 {
	width: 100%;
    max-width: 100%;
}
footer .tbl_time01 table {
    background-color: transparent;
    border-top: 1px solid;
    border-bottom: 1px solid;
    border-color: #434343;
}
footer .tbl_time01 thead th {
    padding: 18px 0 24px;
    letter-spacing: .05em;
}
footer .tbl_time01 tbody td {
    padding: 0 0 24px;
}
footer .tbl_time td span, .tbl_time .tbl_caption span {
    font-size: 14px;
}
footer .tbl_caption {
    font-size: 1rem;
}
footer .copyright {
    margin-top: 1.0em;
    font-size: 85%;
    letter-spacing: .15em;
    line-height: 1.4em;
}
.ggmap {
position: relative;
padding-bottom: 76.25%;
padding-top: 30px;
height: 0;
overflow: hidden;
}
 
.ggmap iframe,
.ggmap object,
.ggmap embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
footer .mapz .map_link {
	width: 100%;
    text-align: right;
    margin-top: 1.0em;
}
footer .mapz .map_link a {
    color: #cdbb8d;
    font-size: 140%;
	padding-right: 26px;
    letter-spacing: .1em;
    line-height: 1.2em;
}
footer .mapz .map_link.arrw a::after {
    right: 0;
    color: #cdbb8d;
}
footer .mapz .circz {
	margin-top: 30px;
  	justify-content: space-between
}
footer .mapz .circz .vx {
  	width: 30.333333333%;
  	padding-top: 30.333333333%;
  	border-radius: 50%;
  	/* background-color: #FFF; */
	position: relative
}
footer .mapz .circz .vx .inn {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	flex-wrap: wrap;	
}
footer .mapz .circz .vx .inn p {
	width: 100%;
	text-align: center;
	line-height: 1.4	
}
footer .mapz .circz .vx .inn .smo {
	padding: 10px 10px 6px;
	font-size: 0.6vw
}
footer .mapz .circz .vx .inn .big {
	padding: 0 10px;	
	font-size: 0.8vw;
	font-weight: bold
}
.under header.general {
   background-color: rgba(255,255,255,0.88);
}
.under .fv{
	position: relative;
	overflow: hidden
}
.under .fv figure img{
	display: block;
	width: 100%;
	height: 570px;
    object-fit: cover;
    object-position: center;
    font-family: 'object-fit: cover;';
}
.under .fv h2 {
    position: absolute;
    z-index: 1;
    left: 0;
    right: 0;
    top: 50%;
    text-align: center;
    color: #fff;
    font-size: 260%;
    font-weight: bold;
    letter-spacing: .25em;
    line-height: 1.4em;
}
.under .fv h2 span{
	display: block;
    font-size: 60%;
    letter-spacing: .2em;
    line-height: 1.2em;
    font-weight: 400;
}
.under .fv::after {
    content: "";
    position: absolute;
    z-index: 0;
    width: 100%;
    left: 0;
    height: 30%;
    bottom: 0;
    background: -moz-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 100%);
    background: -webkit-linear-gradient(top, rgba(255,255,255,0) 0%,rgba(255,255,255,1) 100%);
    background: linear-gradient(to bottom, rgba(255,255,255,0) 0%,rgba(255,255,255,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#ffffff',GradientType=0 );
}
.under .sec_1 {
	margin-top: 100px
}
.under .lead_box dl {
    text-align: center;
}
.under .lead_box dl dt {
    font-size: 235%;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.6em;
    margin-bottom: 15px;
}
.under .lead_box dl dt h2 {
    font-size: 100%;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.6em;
    margin-bottom: 15px;
}
.under dd {
    line-height: 1.8em
}
.maternity .medical .in_box1,.surgery .medical .in_box1 {
    margin-bottom: 60px;
}
.medical .sec_2 {
    margin: 0 auto 60px;
}
.med_flt .img_l, .med_flt .img_r {
    text-align: center;
    width: 35%;
    max-width: 480px;
    margin-bottom: .5em;
}
.med_flt .img_r {
    float: right;
    margin-left: 4%;
}
.med_flt .img_l {
    float: left;
    margin-right: 4%;
}
.med_flt .txt_l {
    width: 61%;
    float: left;
}
.med_flt .txt_l.full {
    width: 100%;
    float: none;
}
.med_flt .txt_r {
    float: right;
    width: 61%;
}
.med_style1 dt {
    font-size: 155%;
    letter-spacing: .05em;
    line-height: 1.6em;
    margin-bottom: 15px;
}
.med_flt .med_style1 dt {
    font-weight: 600;
}
.medical .med_box {
    max-width: 1200px;
    margin: 0 auto 60px;
    text-align: left;
	border-bottom: 1px solid #b9ced7
}
.med_side3_box ul,.med_side4_box ul {
    justify-content: space-between;
}
.med_side3_box li {
    width: 48%;
    background: rgba(164,210,235,0.50);
    padding: 34px;
    box-sizing: border-box;
}
.med_side3_box li {
    width: 48.5%;
}
.med_side4_box li {
    width: 31.33333333333%;
    background: rgba(164,210,235,0.50);
    padding: 34px;
    box-sizing: border-box;
}
.med_side4_box li {
    width: 31.33333333333%;
    background: rgba(164,210,235,0.50);
    padding: 34px;
    box-sizing: border-box;
}
.med_side4_box.six_pack li {
    margin-bottom: 3%;
}
p.msg {
    font-weight: 600;
    font-size: 155%;
    letter-spacing: .1em;
    margin-top: 15px;
    text-align: center;
	line-height: 1.5
}
.med_side3_box li dt,.med_side4_box li dt {
    font-size: 155%;
    font-weight: 600;
    line-height: 1em;
    text-align: center;
}
.med_side3_box li dt,.med_side4_box li dt {
    font-size: 160%;
    font-weight: 600;
    color: #2da4db;
    letter-spacing: 0.05em;
    padding-left: 0;
    margin: 10px 0 20px;
    line-height: 1.3em;
}
.med_side3_box li dt span, .med_side4_box li dt span{
	font-size: 14px;
	display: block;
	text-align: center;
	margin-top: 0;
}
.med_frame_box .med_frame_list > li {
    overflow: hidden;
    position: relative;
    padding-bottom: 60px;
}
.dtl_vx{
	flex-flow: row-reverse;
}
.dtl_vx .graph{
	width: 420px;
	justify-content: space-between
}
.dtl_vx .graph dl{
	width: calc(50% - 1px);
	background-color: #f0f0f0;	
}
.dtl_vx .graph dl dt{
	padding: 10px;
	background-color: #9e9c9c;
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	color: #FFF;
	letter-spacing: .1em
}
.dtl_vx .graph dl dd{
	padding: 10px;	
	font-size: 14px;
}
.dtl_vx .graph dl dd img{
	padding: 30px 0 20px
}
.dtl_vx .graph dl dd p{
	line-height: 1.5;
	font-weight: 550;
	text-align: center;

}
.dtl_vx .txt{
	width: calc(100% - 420px);
	padding-right: 2%
}
.dtl_vx .txt{
	width: calc(100% - 420px);
	padding-right: 2%
}
.dtl_vx .txt.full{
	width: 100%;
	padding-right: 0;
	text-align: center
}
.dtl_vx .txt h3,.dtl_vx .txt h2{
	font-size: 140%;
    font-weight: 600;
    color: #888888;
    letter-spacing: 0.05em;
    margin-bottom: 15px;
    position: relative;
    line-height: 1.3em;
}
.dtl_vx .txt h3.ico{
    padding-left: 1em;
    text-indent: -1em;
}
.dtl_vx .txt h3 i,.dtl_vx .txt h2 i{
    padding-right: 0.4em;
}
.dtl_vx .txt p{
    line-height: 1.8
}
.dtl_vx .txt.full p{
	text-align: left
}

.sec_3 .detail .d_m{
    width: 100%;
	margin-top: 40px;
	justify-content: space-between;
	border-bottom: 1px solid #b9ced7;
}
.sec_3 .detail.two .d_m{
	border-bottom: none;
}
.sec_3 .detail .d_m .vx{
    width: 48.5%
}
.sec_3 .detail .d_m .merit{
    background-color: #fbdcc4		
}
.sec_3 .detail .d_m dt{
    padding: 20px 10px;
	text-align: center;
	color: #FFF;
	font-size: 22px;
	font-weight: 550;
	letter-spacing: .05em;
}
.sec_3 .detail .d_m .merit dt{
    background-color: #f6872f	
}
.sec_3 .detail .d_m .demerit dt{
    background-color: #8ac7cc	
}
.sec_3 .detail .d_m dd{
    padding: 30px 40px;
}
.sec_3 .detail .d_m .demerit{
    background-color: #ccf8fc	
}
.sec_3 .detail .d_m dd p{
	margin-bottom: 26px;
	
}
.sec_3 .detail .d_m dd p:last-child{
	margin-bottom: 0;
}
.sec_3 .detail .d_m dd p i{
	width: 25px;
}
.sec_3 .detail .d_m dd p span{
	display: block;
	width: calc(100% - 25px);
}
.sec_3 .detail .d_m .merit dd p i{
    color: #f6872f;
}
.sec_3 .detail .d_m .demerit dd p i{
    color: #8ac7cc;
}
.sec_3 .detail.two .dtl_vx .txt h3,
.sec_3 .detail.two .dtl_vx .txt h2{
    color: #fbb731;
}
.sec_3 .detail.two .dtl_vx .graph dl dt {
    background-color: #f0b688;
}
.sec_3 .detail.two .dtl_vx .graph dl dd {
    background-color: #ffefe3;
}
.rmd_vxz{
	border: 1px solid #2da4db
}
.rmd_vxz .tit{
	padding: 18px 7px;
	font-size: 22px;
	font-weight: bold;
	color: #FFF;
	text-align: center;
	letter-spacing: .08em;
	line-height: 1.5;
	background-color: #2da4db
}
.rmd_vxz .tit .num {
    padding: 3px 10px;
	background-color: #FFF;
	margin-right: 10px
}	
.rmd_vxz article{
	padding: 70px 6%;
	background-color: #eefaff
}
.rmd_vxz article .dtl_vx{
	align-items: flex-start
}
.rmd_vxz article .dtl_vx.one{
	padding-bottom: 60px;
	margin-bottom: 60px;
	border-bottom: 1px solid #b9ced7;
}
.rmd_vxz article .dtl_vx .graph img{
	width: 240px
}
.rmd_vxz article .dtl_vx .graph img{
	width: 100%
}
.dtl_vx .txt {
    width: calc(100% - 240px);
}
nav.und{
	margin-top: 100px;
	padding: 70px 0 45px;
    background-color: #fff5e3;
}
nav.und h2{
    font-size: 150%;
    font-weight: 400;
    line-height: 1.2em;
    letter-spacing: 0.05em;
    text-align: center;
    margin-bottom: 40px;
}
nav.und ul li {
    width: 15.5%;
    margin-left: 1.4%;
    float: left;
    text-align: left;
    margin-bottom: 30px;
}
nav.und ul li:first-child,
nav.und ul li:nth-child(7),
nav.und ul li:nth-child(13){
    margin-left: 0;
}
nav.und ul li a {
    display: block;
    color: #3E3A39;
    font-size: 110%;
    letter-spacing: .15em;
    line-height: 1.0em;
    position: relative;
    padding-left: 1.3em;
}
nav.und ul li a::before {
	position: absolute;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f061";
	left: 0;
	color: #ff7c48
}
.under .rec_box .inn{
	justify-content: space-between
}
.under .rec_box .inn .vx{
	width: 48%;
}
.under .rec_box .inn .nv_nws{
    border-top: solid 1px #a2d5da;
    border-bottom: solid 1px #a2d5da;	
}
.under .rec_box .inn .nv_nws a{
	height: 100%;
	padding-top: 10px;
	justify-content: center;
	align-items: center;
	align-content: center;
	text-align: center;
    font-size: 250%;
    letter-spacing: .05em;
    line-height: 1.2em;
    margin-bottom: 8px;	
	position: relative;
	background-color: transparent;
	transition-property: all;
  	transition: 0.2s linear;
}
.under .rec_box .inn .nv_nws a:hover{
	background-color: #ddf3f5
}
.under .rec_box .inn .nv_nws a span{
	display: block;
	width: 100%;
	margin-top: 12px;
    font-size: 16px;
    letter-spacing: .15em;
    line-height: 1.2em;	
}
.under .rec_box .inn .nv_nws.arrw a::after {
    color: #2da4db;
}
.under .rec_box .bnr_recruit dt {
	padding-top: 10px;
    font-size: 300%;
    letter-spacing: 0.1em;
    margin-bottom: 10px;
    line-height: 1em;
    font-weight: 400;
}
.faq dl {margin-bottom: 50px}
.faq dl:last-child {margin-bottom: 0}
.faq dl dt{
	padding: 0 10px 0 4%;
	margin-left: 40px;
	font-size: 155%;
    font-weight: 600;
	letter-spacing: 0.1em;
	line-height: 1.5;
    padding-bottom: 30px;
    background: url(../img/icon_q.svg) no-repeat left top;
    background-size: 28px 34px;	
}
.faq dl dd {
    background: #fff6f2;
    padding: 40px 4%;
    position: relative;	
}
.faq dl dd p {
    background: url(../img/icon_a.svg) no-repeat left top .4em;
    background-size: 28px 34px;
    padding-left: 60px;
	line-height: 1.8;	
}
.cvz.tp_under .mailz .rza,.cvz.tp_under .mailz .free {
    width: 50%;
}
.surgery .sec_4 p.msg{
	margin: 30px auto 35px
}
.cvz.tp_under .telz,
.contact .sec_2 .cvz .telz{
    justify-content: center;
	margin-bottom: 26px
}
.cvz.tp_under .telz span.cap {
    font-size: 20px;
}
.cvz.tp_under .telz a img {
    max-width: 60px;
}
.cvz.tp_under .telz a span {
    font-size: 50px;
}
.cvz.tp_under .mailz .free a p span {	
	font-size: 20px
}
.cvz.tp_under .mailz .vx a {	
	padding: 30px 0;
}
.box1{
	background-color: #fff6f2
}
.com_index3 {
    padding: 90px 0 0;
    margin-bottom: 85px;
    text-align: center;
    font-size: 205%;
    font-weight: bold;
    letter-spacing: .12em;
    line-height: 1.6em;
    position: relative;
}
.box1 .com_index3 {
    margin-bottom: 75px;
}
.com_index3::before {
	font-family: "Font Awesome 5 Free";
	content: "\f5c9";
	font-weight: 900;
    position: absolute;
    left: 0;
    right: 0;
    top: 35px;
    margin: 0 auto;
	opacity: .6;
	font-size: 22px;
}
.attn_vx{
	background-color: #FFF
}
.w1000 {
    width: 94%;
    padding: 0 3%;
    max-width: 1000px;
    margin: 0 auto;
}
.box1 .w1000 {
    padding: 70px 3% 65px;
}
.com_reserve_coution {
    font-weight: bold;
    font-size: 110%;
    line-height: 1.8em;
    text-align: center;
    margin-bottom: 2em;
}
.box1 .bdr_list {
    margin: 40px 0;
    border-top: 1px solid rgba(62,58,57,0.30);
}
.box1 .bdr_list li {
    border-bottom: 1px solid rgba(62,58,57,0.30);
    padding: .9em 0;
}
.box1 .bdr_list li p {
    max-width: 780px;
    margin: 0 auto;
    padding-left: 1em;
    text-indent: -1em;
	line-height: 1.5;
	
}
.lh_1-5{
	line-height: 1.5
}
.lh_1-8{
	line-height: 1.8
}
.box2 .com_index3 {
    margin-bottom: 10px;
}
.box2 .txt_require {
    text-align: center;
    color: #828282;
    font-weight: 600;
}
.form_area{
	margin-top: 60px;
	border-top: solid 1px rgba(62,58,57,0.30);
}
.form_area .vx{
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.6em;	
	border-bottom: solid 1px rgba(62,58,57,0.30);	
}
.form_area .th{
	width: 30%;
    padding: 40px 1% 40px 4%;
	background: #fae3c4;
    font-size: 125%;
}
.form_area .td{
	width: 70%;
    padding: 40px 5%;
}
.form_area input[type="text"],
.form_area input[type="email"]{
    padding: 16px 5px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    background: #f2f2f2;
    outline: none;
    border: none;
    border-radius: 0;
    -webkit-appearance: none;
    font-size: 16px;
    letter-spacing: .05em;
}
.form_area .td.sepa {
	justify-content: space-between
}
.form_area .td.sepa .vx_s {
    width: 48%;
	align-items: center
}
.form_area .td span {
	padding: 0 6px
}
.form_area .td.sepa .vx_s span {
	width: 13%;
	display: block;
	padding: 0
}
.form_area .td.sepa .vx_s .name_txt {
	width: 100%;
}
.form_area .td .max_txt {
    width: 100%;
}
.form_area .td.sepa.rad {
    justify-content: flex-start
}
.form_area .td.sepa.rad .vx_s {
    width: auto;
	padding-right: 20px
}
.form_area .td.sepa .vx_s label{
    width: auto;
	padding-left: 4px;
	cursor: pointer
}
.form_area .td.sepa.chk .vx_s {
	margin-bottom: 20px
}
.form_area textarea {
    padding: 16px 5px;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    background: #f2f2f2;
    outline: none;
    border: none;
    border-radius: 0;
    -webkit-appearance: none;
    font-size: 16px;
    letter-spacing: .05em;
}
.form_area .td .area_other {
    margin-top: 8px;
    height: 6em;
}
.form_area .td.cal .vx_s {
	margin-bottom: 20px
}
.form_area .td.cal p {
	width: 100%;
	margin-bottom: 16px
}
.vx_s.lst {
	margin-bottom: 0!important
}
.form_area .td .area_comment {
    height: 12em;
}
.form_area .lst_msg{
	line-height: 1.8;
	margin: 40px auto;
	text-align: center
}
.form_area .privacy {
    border: solid 1px #2da4db;
    padding: 30px 4%;
}
.form_area .privacy h5 {
    text-align: center;
	cursor: pointer;
}
.form_area .privacy h5 span::after {
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f055";
    margin-left: .5em;
}
.form_area .privacy .open_box {
    padding-top: 1.0em;
	line-height: 1.8;
	display: none
}
.form_area .privacy .open_box p {
    padding-bottom: 1.0em;
	line-height: 1.8;
}
.form_area .privacy section {
	margin-top: 30px;
    justify-content: space-between;
	position: relative
}
.form_area .privacy section::before {
    content: "";
    position: absolute;
    width: 1px;
    height: 100%;
    background: #2da4db;
    left: 0;
    right: 0;
    top: 0;
    margin: auto;
}
.form_area .privacy section dl {
    width: 46%;
}
.form_area .privacy section dl dt {
    font-weight: bold;
	font-size: 110%;
    margin-bottom: .5em;
}
.list_type_1 li {
    text-indent: -1.5em;
    margin-left: 1.5em;
	line-height: 1.8
}
.list_type_1.l_h li {
	line-height: 2.2
}
.form_area input[type="submit"], .form_area input[type="button"], .form_area input[type="reset"] {
    -webkit-appearance: none;
    width: 100%;
    height: 70px;
    border: none;
    cursor: pointer;
    border-radius: 0;
    font-size: 110%;
    color: #fff;
    font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.0em;
}
.form_area input[type="submit"] {
	background-color: rgba(247,176,31,0.9);
}
.form_area .sub_cov{
	display: block;
    margin: 40px auto 0;
	width: 50%;
	height: 100%;
	position: relative	
}
.form_area .sub_cov::after{
	position: absolute;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f0a9";
	right: 6%;
	top: calc(50% - 20px);
	margin: auto;
	color: #FFF
}
.entry_list, .single_page {
    border-top: solid 1px #2da4db;
}
.arc_vx{
    padding: 60px 3%;
    border-bottom: solid 1px #2da4db;	
}
.arc_vx .entry-inf {
    margin-bottom: 30px;
}
.arc_vx .entry-date {
    font-weight: 400;
    color: #3e3a39;
    line-height: 1.2em;
    margin-bottom: 10px;
    font-size: 120%;
    letter-spacing: 0.2em;
    text-align: center;
}
.arc_vx p:first-child {
    margin-top: 0;
}
.arc_vx .entry-title {
    font-size: 200%;
    letter-spacing: .1em;
    line-height: 1.6em;
    font-weight: normal;
    text-align: center;
}
.arc_vx .entry-title, .arc_vx .entry-title a {
    color: #2da4db;
    text-decoration: none;
    font-weight: normal;
}
.arc_vx .entry-title, .arc_vx .entry-title a {
    color: #2da4db;
    text-decoration: none;
    font-weight: normal;
}
.txt_summary a, .entry-content a {
    color: #2da4db;
    text-decoration: underline;
}
.txt_summary a:hover, .entry-content a:hover {
    text-decoration: none;
}
.arc_vx p.bdy {
    line-height: 1.5
}
.under .pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 60px auto 0;
}
.under .pagination span,
.under .pagination a{
	display: flex;
	justify-content: center;
	align-items: center;	
    width: 53px;
    height: 53px;
    margin: 0 12px 12px 0;
    text-align: center;
    color: #ffffff;
	font-size: 24px;
	font-weight: bold;
}
.under .pagination a {
    transition-property: all;
    transition: 0.1s linear;
    background-color: #ced0d7;
}
.under .pagination a:hover{
	opacity: .7;
	background-color: #2da4db;
}
.under .pagination span.current {
	color: #ffffff;
    background-color: #2da4db;
}
.under .pagination span.dots {
	color: #ced0d7
}
.ortho .rmd_vxz .vx_type_2,
.leave_teeth .rmd_vxz .vx_type_2,
.metalfree .rmd_vxz .vx_type_2{
	margin-top: 42px
}
.vx_type_2 .tx{
	width: 68.3%;
}
.vx_type_2.full .tx,.vx_type_2 .tx.full{
	width: 100%;
}
.vx_type_2 .tx h3{
	background-color: #2CB7DE;
    color: #FFF;
    font-size: 115%;
    padding: 0.5em 2% 0.4em 11%;
	line-height: 1.5;
    position: relative;
	text-indent: -10%
}
.vx_type_2 .tx h3::before {
	padding-right: 6px;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f328";
	font-size: 120%;
}
.vx_type_2.num .tx h3::before {
	padding-right: 6px;
	font-weight: 900;
	content: "\f328";
	font-size: 120%;
}
.vx_type_2.num .tx h3::before {
	margin-right: 6px;
	padding: 3px 6px;
	font-weight: 900;
	border: 1px solid #FFF;
	border-radius: 100%;
	font-size: 120%;
}
.vx_type_2.num .tx h3.one::before {
	content: "1";
}
.vx_type_2.num .tx h3.two::before {
	content: "2";
}
.vx_type_2.num .tx h3.three::before {
	content: "3";
}
.vx_type_2.num .tx h3.four::before {
	content: "4";
}
.vx_type_2.num .tx h3.five::before {
	content: "5";
}
.vx_type_2.num .tx h3.six::before {
	content: "6";
}
.vx_type_2.num .tx h3.seven::before {
	content: "7";
}
.vx_type_2.num .tx h3.eight::before {
	content: "8";
}
.vx_type_2.num .tx h3.nine::before {
	content: "9";
}
.vx_type_2.num .tx h3.ten::before {
	content: "10";
}
.vx_type_2 .tx p {
	padding-top: 12px;	
	line-height: 1.8;
	letter-spacing: .07em;
}
.vx_type_2 .px{
	max-width: 270px;
    width: 27.7%;
    margin-left: 4%;	
}
.ortho .list_type_1{
	margin: 20px 0
}
.ortho .sec_2 p.msg {
    margin-top: 0;
}
.flex_circ{
	margin: 0 0 0 0;
	justify-content: center;
}
.flex_circ .vx{
	width: calc(20% - 36px);
	margin: 46px 18px 0;	
}
.flex_circ .vx figure{
	width: 200px;
    height: 200px;
	margin: 0 auto;
	background-color: #f9eadf;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	flex-wrap: wrap;
	/*aspect-ratio: auto 165 / 165;*/
}
.flex_circ .vx figure img{
	display: block;
	width: 70%;
}
.flex_circ .vx .tx{
	text-align: center
}
.flex_circ .vx .tx {
	text-align: center;
}
.flex_circ .vx .tx h3 {
	margin: 10px auto;
	font-size: 120%;
	line-height: 1.5;	
	letter-spacing: .08em
}
.flex_circ .vx .tx p {
	text-align: left;
	line-height: 1.5;
	font-size: 90%
}
.clinic .sec_1{
    margin-top: 0px;
}
.leave_teeth .medical .sec_2 {
    margin: 60px auto 60px;
}
.leave_teeth .rmd_vxz.sec_3 .vx_type_2:first-of-type {
    margin-top: 0;
}
.box2 .flow_box li {
    position: relative;
    padding-left: 60px;
    margin-left: 15px;
    box-sizing: border-box;
    padding-bottom: 45px;
    margin-bottom: 25px;
}
.box2 .flow_box li::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 28px;
    height: 80%;
    background: rgb(255,255,255);
    background: -moz-linear-gradient(top, rgba(255,255,255,1) 0%, rgba(188,214,226,1) 30%);
    background: -webkit-linear-gradient(top, rgba(255,255,255,1) 0%,rgba(188,214,226,1) 30%);
    background: linear-gradient(to bottom, rgba(255,255,255,1) 0%,rgba(188,214,226,1) 30%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#bcd6e2',GradientType=0 );
}
.box2 .flow_box li::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 28px;
    height: 16px;
    background: url(../img/flow_arrow.svg)no-repeat;
}
.box2 .flow_box li:last-child::before,
.box2 .flow_box li:last-child::after{
	display: none
}

.box2 .flow_box .flex_box .box_l {
    width: 50%;
}
.box2 .flow_box .flex_box .box_l.full {
    width: 100%;
}
.box2 .flow_box .flex_box .box_l > dt {
    font-size: 155%;
    font-weight: 600;
    color: #2da4db;
    line-height: 1.6em;
    letter-spacing: 0.1em;
    margin-bottom: 30px;
}
.box2 .flow_box .flex_box .box_l > dd {
	line-height: 1.8
}
.box2 .flow_box .flex_box .box_r {
    width: 45%;
    max-width: 500px;
    margin-left: 5%;
}
.box2 .flow_box .num {
	width: 40px;
	height: 40px;
	position: absolute;
	top: 0;
	left: -5px;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	flex-wrap: wrap;
	font-size: 20px;
	font-weight: bold;
	color: #2da4db;
	border: 1px solid #2da4db;
	background-color: #FFF
}	
.box2 .flow_box .num {
    left: -5px;
}
.bg_col2 {
    padding: 40px 5%;
}	
.bg_col2.s_pad {
    padding: 2%;
}	
.bg_col2 .flex_box li {
    width: 50%;
    position: relative;
}
.bg_col2 .flex_box li:first-of-type::before {
    content: '';
    position: absolute;
    right: 0;
    top: 0;
    width: 1px;
    height: 100%;
    background-color: rgba(62,58,57,0.20);
}
.bg_col2 .flex_box li dl {
    max-width: 460px;
}
.bg_col2 .flex_box li:nth-child(1) dl {
    padding-right: 6%;
}
.bg_col2 .flex_box li dt {
    font-size: 125%;
    font-weight: bold;
    line-height: 1.6em;
    letter-spacing: 0.15em;
    text-align: center;
    margin-bottom: 15px;
}
.bg_col2 .flex_box li dd p{
    line-height: 1.8;
}
.bg_col2 .flex_box li:nth-child(2) dl {
    margin: 0 0 0 auto;
    padding-left: 6%;
}
.balloon {
    position: relative;
    display: block;
    background-color: #f0b688;
    padding: 16px;
    max-width: 100%;
    text-align: center;
}
.balloon::before {
    content: "";
    position: absolute;
    border: solid 12px transparent;
    border-top: solid 12px #f0b688;
    top: 100%;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}
.balloon p {
    margin: 0;
    padding: 6px;
	color: #FFF;
	font-size: 22px;
	font-weight: bold
}
.vxz_tp_1{margin-top: -20px;}
.vxz_tp_1 .vx{
	width: calc(25% - 20px);
	margin: 20px 10px 0; 
	padding: 10px;
	background-color: #62B7D7;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	flex-wrap: wrap;
	font-size: 17px;
	font-weight: bold;
	text-align: center;
	letter-spacing: .08em;
	line-height: 1.5;
	color: #FFF	
}
.toc dl{
	border-radius: 5px;
	border: 1px solid #6dbce0;
	overflow: hidden
}
.toc dl dt{
	padding: 10px;
	text-align: center;
	font-size: 22px;
	font-weight: bold;
	color: #FFF;
	letter-spacing: .06em;
	line-height: 1.5;
	background-color: #6dbce0
}
.toc dl dt i{
	margin-right: 12px
}
.toc dl dd{
	padding: 3%
}
.toc dl dd ul li a{
	display: block;
	margin-bottom: 16px;
	padding-left: 1em;
	text-indent: -1em;
	font-size: 18px;
	font-weight: bold;
	letter-spacing: .06em;
	line-height: 1.5;
	transition-property: all;
  	transition: 0.1s linear;			
}
.toc dl dd ul li a:hover{
	text-decoration: underline
}
.toc dl dd ul li:last-child a{
	margin-bottom: 0;
}
.beauty .num span{
	width: 55px;
	height: 55px;
	margin: 0 auto;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	flex-wrap: wrap;	
	font-size: 18px;
	font-weight: bold;
	line-height: 1;
	background-color: rgba(255,255,255,.85)
}
.beauty .sec_5 .num span{
	background-color: #f09b37;
	color: #FFF
}
.beauty .num.flat{
	display: inline-block;
	color: #2da4db;
	margin-right: 6px
}
.denture .medical .med_box {
    margin: 0 auto 60px;
}
.denture .medical .in_box1 {
    margin-bottom: 0;
}
.med_point_box {
    padding: 70px 6%;
    background: #fff6f2;
    box-sizing: border-box;
    margin: 0 auto;
}
.medical .in_box1 {
    margin-bottom: 60px;
}
.ortho .medical .in_box1 {
    margin-bottom: 0;
}
.med_point_box .med_flt {
    position: relative;
}
.box02 .med_point_box .med_flt {
    overflow: inherit;
}
.box02 .med_point_box .med_flt .txt_l {
    width: 69%;
}
.med_point_box dt {
    text-align: left;
    font-size: 155%;
    letter-spacing: 0.1em;
    margin-bottom: 20px;
    line-height: 1.5em;
    color: #f09b37;
    font-weight: 600;
}
.med_point_box dd {
    line-height: 1.8
}
.med_point_box .img_r {
    position: absolute;
    right: 0;
    bottom: 0;
}
@media screen and (min-width:1200px){
.box02 .med_point_box .med_flt .img_r {
    top: 0;
}
}
.box02 .med_point_box .med_flt .img_r {
    width: 27%;
    max-width: 280px;
}
.box02 .med_frame_box {
    background: #F4FAFA;
}
.box02 .medical .in_box1 {
    margin-bottom: 60px;
}
.box02 .med_frame_box {
    background: none;
}
.box02 .med_frame_box h3 {
    text-align: center;
    font-size: 155%;
    letter-spacing: 0.1em;
    padding: 1.08em 0;
    font-weight: 600;
    background-color: #2da4db;
    color: #fff;
}
.box02 .med_frame_box .med_frame_list {
    padding: 70px 6%;
    border-bottom: 1px solid #2da4db;
    border-left: 1px solid #2da4db;
    border-right: 1px solid #2da4db;
}
.box02 .med_frame_box.item_box.type1 .med_frame_list {
    border-bottom: 1px solid #6dbce0;
    border-left: 1px solid #6dbce0;
    border-right: 1px solid #6dbce0;
}
.box02 .med_frame_box.item_box.type2 .med_frame_list {
    border-bottom: 1px solid #e06d83;
    border-left: 1px solid #e06d83;
    border-right: 1px solid #e06d83;
}
.box02 .med_frame_box.item_box.type3 .med_frame_list {
    border-bottom: 1px solid #83e06d;
    border-left: 1px solid #83e06d;
    border-right: 1px solid #83e06d;
}

.box02 .med_frame_box.item_box.type1 .med_frame_list > li dt, 
.box02 .med_frame_box.item_box.type1 .med_frame_list > li dt i {
    color: #6dbce0;
}
.box02 .med_frame_box.item_box.type2 .med_frame_list > li dt, 
.box02 .med_frame_box.item_box.type2 .med_frame_list > li dt i {
    color: #e06d83;
}
.box02 .med_frame_box.item_box.type3 .med_frame_list > li dt, 
.box02 .med_frame_box.item_box.type3 .med_frame_list > li dt i {
    color: #83e06d;
}

.box02 .med_frame_box.item_box.type1 h3, .box02 .med_frame_box.item_box.type1 .score {
    background: #6dbce0;
}
.box02 .med_frame_box.item_box.type2 h3, .box02 .med_frame_box.item_box.type2 .score {
    background-color: #e06d83;
}
.box02 .med_frame_box.item_box.type3 h3, .box02 .med_frame_box.item_box.type3 .score {
    background-color: #83e06d;
}

.box02 .med_frame_box .med_frame_list > li {
    overflow: hidden;
    position: relative;
    padding-bottom: 60px;
    margin-bottom: 60px;
}
.box02 .med_flt {
    overflow: hidden;
}
.box02 .med_frame_box .med_flt .img_l, .box02 .med_frame_box .med_flt .img_r {
    width: 31%;
    max-width: 320px;
}
.box02 .item_box .med_flt .img_r {
    margin-left: 6%;
}
.box02 .med_frame_box .med_frame_list > li dt, .box02 .med_frame_box .med_frame_list > li p.title {
    font-size: 140%;
    font-weight: 600;
    color: #2da4db;
    letter-spacing: 0.05em;
    padding-left: 1.3em;
    margin-bottom: 15px;
    position: relative;
    line-height: 1.3em;
}
.box02 .med_frame_box.item_box.type1 .med_frame_list > li dt, 
.box02 .med_frame_box.item_box.type1 .med_frame_list > li dt i {
    color: #6dbce0;
}
.box02 .item_box .score {
    margin: 20px 0;
    background: #2da4db;
    padding: 12px 10px;
}
.box02 .item_box .score ul {
    width: 100%;
}
.box02 .item_box .score li {
    margin: 0 .5em;
    letter-spacing: .1em;
    font-size: 115%;
    font-weight: 600;
    line-height: 1.0em;
    color: #ffffff;
}
.box02 .item_box .score li.icon {
    padding: .2em 0;
    padding-right: 1.8em;
    background-repeat: no-repeat;
    background-position: right top;
    background-size: 1.4em 1.4em;
}
.box02 .item_box li.icon1 {
    background-image: url(../img/type1_s1.svg);
}
.item_box li.icon2 {
    background-image: url(../img/type1_s2.svg);
}
.item_box li.icon3 {
    background-image: url(../img/type1_s5.svg);
}
.item_box li.icon4 {
    background-image: url(../img/type1_s4.svg);
}

.box02 .item_box .score_txt {
    letter-spacing: 0.06em;
    line-height: 1.9em;
}
.flex {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    flex-direction: row;
}
.box02 .med_frame_box .med_frame_list > li dt i {
    color: #009F9E;
    position: absolute;
    left: 0;
    top: 3px;
    font-size: 100%;
}
.box02 .med_frame_box .med_frame_list > li::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    background-image: -webkit-linear-gradient(to right, rgba(62,58,57,0.50), rgba(62,58,57,0.50) 50%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0) 100%);
    background-image: -moz-linear-gradient(to right, rgba(62,58,57,0.50), rgba(62,58,57,0.50) 50%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0) 100%);
    background-image: -ms-linear-gradient(to right, rgba(62,58,57,0.50), rgba(62,58,57,0.50) 50%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0) 100%);
    background-image: -o-linear-gradient(to right, rgba(62,58,57,0.50), rgba(62,58,57,0.50) 50%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0) 100%);
    background-image: linear-gradient(to right, rgba(62,58,57,0.50), rgba(62,58,57,0.50) 50%, rgba(0, 0, 0, 0) 50%, rgba(0, 0, 0, 0) 100%);
    background-size: 10px 10px;
    height: 1px;
}
.box02 .med_frame_box.item_box .med_frame_list > li.hoken dt,
.box02 .med_frame_box.item_box .med_frame_list > li.hoken dt i {
    color: #9E9C9C;
}
.box02 .med_frame_box.item_box .hoken .score {
    background: #9E9C9C;
}
.box02 .med_frame_box .med_frame_list > li:last-child {
    padding-bottom: 0;
    margin-bottom: 0;
}
.box02 .med_frame_box .med_frame_list > li:last-child::after {
	display: none
}
.med_flow_box {
    background: #95cee9;
    padding: 30px 3% 40px;
}
.med_flow_box .flow_index {
    text-align: center;
    font-size: 135%;
    font-weight: 600;
    letter-spacing: 0.1em;
    margin-bottom: 15px;
    line-height: 1.5em;
    color: #FFF;
}
.box03 .med_flow_box .flow_index {
    margin-bottom: 25px;
}
.med_flow_box ul {
    max-width: 876px;
    margin: 0 auto;
}
.box03 .med_flow_box ul {
    max-width: 885px;
    margin: 0 auto;
}
.med_flow_box li {
    width: 15.99%;
    float: left;
    max-width: 140px;
    position: relative;
    text-align: center;
}
.box03 .med_flow_box li {
    width: 20%;
    max-width: 205px;
}
.med_flow_box li p {
    margin: 0 auto;
}
.med_flow_box li .txt {
    text-align: center;
    margin-top: 15px;
    line-height: 1.6em;
    font-size: 95%;
    letter-spacing: 0.05em;
}
.med_flow_box li.flow_arrow {
    width: 5.0125%;
    padding-top: 6%;
    text-align: center;
    max-width: 44px;
    margin-left: auto;
    margin-right: auto;
}
.box03 .med_flow_box li.flow_arrow {
    width: 6.6660%;
    padding-top: 9%;
}
.box03 .med_flow_box li.flow_arrow i:before {
    color: #FFF;
    margin: 0;
	font-style: normal;
	font-family: "Font Awesome 5 Free";
	font-weight: 900;
	content: "\f04b";	
}
.box03 .med_frame_box .med_frame_list > li dt, 
.box03 .med_frame_box .med_frame_list > li p.title {
    font-size: 140%;
    font-weight: 600;
    color: #2da4db;
    letter-spacing: 0.05em;
    padding-left: 1.3em;
    margin-bottom: 15px;
    position: relative;
    line-height: 1.3em;
}
.box03 .txt_box {
    margin-top: 50px
}
.box03 .txt_box dt {
    font-size: 140%;
	font-weight: bold;
	color: #2da4db;
    letter-spacing: 0.1em;
    padding-left: 0;
    margin-bottom: 30px;
    text-align: center;
}
.box03 .txt_box dd li {
    background: url(../img/check_box_w.svg) no-repeat left top .3em;
    background-size: 25px 25px;
    font-weight: 500;
    font-size: 125%;
    padding-left: 45px;
    padding-bottom: .6em;
    margin-bottom: 0.4em;
    border-bottom: rgba(179,170,172,0.50) 1px solid;
	line-height: 1.8
}
.staff .box1  {
    background-color: transparent
}
.staff .box1 .bg_col {
    position: relative;
    padding-top: 120px;
    padding-bottom: 30px;
}
.staff .box1 .bg_col::before {
    content: '';
    position: absolute;
    right: 0;
    bottom: 0;
    width: calc(50% + 250px);
    height: 100%;
    background-color: #fff6f2;
    z-index: 1;
}
.staff .box1 .bg_col .flex_box .box_l {
    width: 45%;
    max-width: 575px;
    margin-right: 8%;
	position: relative;
	z-index: 2
}
.staff .box1 .bg_col .flex_box .box_l .img_box {
    position: relative;
    text-align: center;
}
.staff .box1 .bg_col .flex_box .box_l .img_box .abs_img {
    position: absolute;
    bottom: 8%;
    right: 8%;
    width: 27%;
    max-width: 150px;
}
.name_box {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
    padding-top: 50px;
	flex-wrap: wrap
}
.name_box.one {
	flex-wrap: nowrap
}
.name_box p {
	width: 100%;
    font-size: 205%;
    font-weight: bold;
    letter-spacing: .15em;
}
.name_box p:first-of-type {
    margin-right: .8em;
}
.name_box.one p:first-of-type {
    margin-right: 0;
}
.name_box p span {
    font-size: 65%;
    font-weight: 500;
    padding-right: .6em;
}
.name_box p img {
    vertical-align: middle;
}
.staff .box1 .bg_col .flex_box .box_l .prof_box {
    text-align: center;
    font-size: 95%;
    letter-spacing: .01em;
    padding-top: 6%;
    margin-top: 6%;
    border-top: 1px solid #2da4db;
}
.staff .box1 .bg_col .flex_box .box_l .prof_box li {
    line-height: 1.6em;
    margin-bottom: 2%;
    position: relative;
    padding-left: 3.5em;
    display: inline-block;
}
.staff .box1 .bg_col .flex_box .box_l .prof_box span {
    font-weight: bold;
    color: #2da4db;
    position: absolute;
    left: 0;
}
.staff .box1 .bg_col .flex_box .box_l .prof_box i {
    font-size: 1.3em;
    color: #2da4db;
    vertical-align: bottom;
	padding-right: 4px;
}
.staff .box1 .bg_col .flex_box .box_l .prof_box li:nth-child(2) {
    padding-left:5em;
}
.staff .box1 .bg_col .flex_box .box_r {
    width: 47%;
	position: relative;
	z-index: 2	
}
.staff .box1 .bg_col .flex_box .box_r > dt {
    font-size: 205%;
    font-weight: bold;
    line-height: 1.6em;
    letter-spacing: .1em;
    margin-bottom: 6%;
}
.staff .box1 .bg_col .flex_box .box_r > dd {
    line-height: 1.6;
}
.staff .box1 .bg_col2 {
    padding-top: 80px;
	padding-bottom: 0;
    background: url(../img/dr_bg@2x.jpg)no-repeat right top;
    background-size: 60% auto;
    position: relative;
    z-index: 1;
}
.staff .box1 .bg_col2 .flex_box {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-justify-content: flex-start;
    justify-content: flex-start;
    padding-bottom: 60px;
}
.staff .box1 .btn_type_1 {
    width: 100%;
    max-width: 350px;
    margin: 0;
    padding-bottom: 60px;	
	text-align: center
}
.staff .box1 .bg_col2 .flex_box .box_l {
    width: 34%;
    margin-right: 4%;
    min-width: 450px;
}
.staff .box1 .bg_col2 .flex_box .box_r {
    width: 45%;
}
.staff .box1 .bg_col2 .item > dt {
    color: #81d1f6;
    font-weight: bold;
    letter-spacing: .15em;
    line-height: 1.6em;
    margin-bottom: 10px;
}
.staff .box1 .bg_col2::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 50px;
    background: -moz-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 100%);
    background: -webkit-linear-gradient(top, rgba(255,255,255,0) 0%,rgba(255,255,255,1) 100%);
    background: linear-gradient(to bottom, rgba(255,255,255,0) 0%,rgba(255,255,255,1) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#ffffff',GradientType=0 );
}
.staff .bg_col2 .flex_box li:first-of-type::before {
    display: none
}
.staff .box1 .bg_col2 .ryakureki_list dt {
    clear: both;
    float: left;
    width: auto;
    margin-right: .5em;
	line-height: 1.8	
}
.staff .box1 .bg_col2 .item dd {
    font-size: 95%;
}
.staff .box1 .bg_col2 .ryakureki_list dd {
    float: left;
	line-height: 1.8
}
.staff .box1 .bg_col2 .box_r li {
	width: 100%;
    text-indent: -1.2em;
    margin-left: 1.2em;
	line-height: 1.8	
}
.com_inbox {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
}
.staff .box2 .flex_box {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
}
.staff .box2 .flex_box > li {
    width: 45%;
    margin-bottom: 80px;
    background: #fff6f2;
}
.staff .box2 .flex_box > li > div {
    background: #fff;
}
.staff .box2 .name_box {
    text-align: center;
}
.staff .box2 .name_box p {
    font-size: 155%;
    font-weight: bold;
	line-height: 1.6;	
    letter-spacing: .12em;
}
.staff .box2 .name_box p span {
    font-size: 65%;
    font-weight: 500;
    display: block;
	letter-spacing: .12em;
}
.staff .box2 .name_box p.roma {
    font-size: 65%;
    font-weight: 500;
    letter-spacing: .15em;
    color: #3E3A39;
    opacity: 0.5;
}
.staff .box2 .flex_box .prof_box {
    padding-top: 6%;
    margin-top: 4%;
    border-top: 2px solid #2da4db;
}
.staff .box2 .flex_box .prof_box .vx {
    padding-bottom: 12px;
	margin-bottom: 20px;
	line-height: 1.8
}
.staff .box2 .flex_box .prof_box .dt {
    width: 170px;
    font-weight: bold;
    color: #2da4db;
	border-bottom: 1px solid #2da4db
}
.staff .box2 .flex_box .prof_box .dd {
    width: calc(100% - 170px);
	border-bottom: 1px solid #D3D3D3	
}
.staff .box2 .flex_box .prof_box ul {
	justify-content: center
}
.staff .box2 .flex_box .prof_box li {
	margin: 10px 10px
}
.staff .box2 .flex_box .prof_box li span {
}
.staff .box2 .flex_box .prof_box li i {
	padding-right: 4px
}
.staff .box2 .flex_box .bg_col {
    background: #fff6f2;
    border-radius: 30px 0 0 0;
    padding: 6%;
    margin-top: 16px;
    height: 100%;
}
.staff .box2 .flex_box .bg_col p{
	line-height: 1.8
}
.base_pg{
	padding-bottom: 100px
}
.clinic .med_flow_box ul {
    max-width: 100%;
    margin: 0 auto;
}
.clinic .box03 .med_flow_box li.flow_arrow {
    padding-top: 6%;
}
.clinic .med_flow_box li .txt {
    text-align: left;
}
.access .sec_1 .h_type_3{
	margin-bottom: 0
}
.access .sec_1 .time_info {
    margin-top: 40px;
	border: none
}
.access .sec_1 .tbl_time01.day8 {
    max-width: 100%;
	width: 100%;
    font-size: 18px;	
}
.access .sec_1 .tbl_time01 thead th {
    padding: 26px 0 26px;
    letter-spacing: .05em;
}
.access .sec_1 .tbl_time01 tbody td {
    padding: 0 0 26px;
}
.access .sec_1 .tbl_time td span, .access .sec_1 .tbl_time .tbl_caption span {
    font-size: 14px;
}
.access .sec_1 .tbl_caption {
    margin: 20px 0 60px;
    font-size: 14px;
}
.access .sec_1 .cvz .telz {
    justify-content: center;
	margin-bottom: 30px
}
.access .sec_1 .cvz .telz span.cap {
    font-size: 18px;
}
.access .sec_1 .cvz .telz a span {
    font-size: 50px;
}
.access .sec_2 .vxz {
    margin-top: 40px;
	justify-content: center;
}
.access .sec_2 .vxz .vx {
	margin: 0 10px
}
.access .sec_2 .vxz .vx:last-child {
}
.access .sec_3 .ggmap {
position: relative;
padding-bottom: 26.25%;
padding-top: 30px;
height: 0;
overflow: hidden;
}
 
.access .sec_3 .ggmap iframe,
.access .sec_3 .ggmap object,
.access .sec_3 .ggmap embed {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
.access nav.und {
    margin-top: 0;
}
.access .base_pg {
    padding-bottom: 0;
}
.dentistry .medical .med_box {
    margin: 0 auto 0;
    border-bottom: none;
}
.dentistry .medical .in_box1 {
    margin-bottom: 0;
}
.implant .box03 .txt_box {
    margin-top: 0;
}
.kids .sec_4 ul{
	justify-content: center
}
.kids .sec_4 ul li{
	margin: 0 1% 2%;
	width: 48%;
    background: rgba(164,210,235,0.50);
    padding: 34px;
    box-sizing: border-box;	
}
.kids .sec_4 ul li dt {
	text-align: center;
    font-size: 160%;
    font-weight: 600;
    color: #2da4db;
    letter-spacing: 0.05em;
    padding-left: 0;
    margin: 10px 0 20px;
    line-height: 1.3em;
}
.rec_job_lead {
    text-align: center;
    margin-bottom: 120px;
}
.rec_dh .rec_job_lead h3 {
    color: #fba6c2;
}
.rec_dh p {
    line-height: 1.8
}
.rec_job_lead h3 {
    font-size: 200%;
	font-weight: bold;
    margin-bottom: 40px;
    letter-spacing: 0.1em;
	line-height: 1.5;
	font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro", "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "メイリオ", sans-serif;
}
.rec_job_lead .lead_img {
    margin: 70px auto;
    text-align: center;
}
.rec_merit {
    border-top: 1px solid rgba(62,58,57,0.30);
    border-bottom: 1px solid rgba(62,58,57,0.30);
    padding: 70px 0;
    text-align: center;
    margin-bottom: 100px;
}
.rec_merit dl {
    background: url(../img/bg_arrow.png) no-repeat bottom center;
    background-size: 320px 75px;
    padding-bottom: 30px;
    margin-bottom: 20px;
}
.rec_dh .rec_merit dt, .rec_dh .rec_merit h5 {
    color: #fba6c2;
}
.rec_merit dt {
	line-height: 1.5;
    font-size: 130%;
    font-weight: bold;
    margin-bottom: 20px;
}
.rec_merit dd {
    text-align: left;
    max-width: 700px;
    margin: 0 auto;
}
.rec_merit li {
	text-align: center;
	font-weight: bold;
    margin-bottom: 0.6em;
    text-indent: -1em;
    padding-left: 1em;
	line-height: 1.8
}
.rec_merit h5 {
    font-size: 110%;
	font-weight: bold;
    line-height: 1.6em;
}
.rec_point h6 {
    text-align: center;
    margin: 0 auto 60px auto;
}
.rec_point li {
    margin-bottom: 80px;
    overflow: hidden;
}
.rec_point li:last-child {
    margin-bottom: 0;
}
.rec_point li dl {
    width: calc(64% - 55px);
    float: left;
    padding: 40px 0 0 55px;
    background-size: 170px 120px;
    background-repeat: no-repeat;
    background-position: left top;
}
.rec_point li.rec_point01 dl {
    background-image: url(../img/point_icon01.png);
}
.rec_point li.rec_point02 dl {
    background-image: url(../img/point_icon02.png);
}
.rec_point li.rec_point03 dl {
    background-image: url(../img/point_icon03.png);
}
.rec_point li dt {
    font-size: 120%;
    font-weight: bold;
    line-height: 1.6em;
    margin-bottom: 15px;
}
.rec_point li dd {
    line-height: 1.5;
}
.rec_point li div {
    width: 33%;
    max-width: 390px;
    float: right;
}
.rec_tbl{
    border-top: solid 1px rgba(62,58,57,0.30);	
}
.rec_tbl .vx {
    border-bottom: solid 1px rgba(62,58,57,0.30);
    padding: 40px;
    vertical-align: top;	
}
.rec_tbl .th {
    width: 22%;
    background: rgba(255,255,134,0.4);
    text-align: left;
    font-weight: bold;
    font-size: 110%;
    letter-spacing: normal;
    line-height: 1.4em;
}
.rec_tbl .td {
    width: 78%;
}
.single_page {
    border-top: solid 1px #8dafcb;
}
.single_page article {
    padding: 60px 3%;
    border-bottom: solid 1px #8dafcb;
}
.single_page article .entry-date {
    font-weight: 400;
    color: #3e3a39;
    line-height: 1.2em;
    margin-bottom: 10px;
    font-size: 120%;
    letter-spacing: 0.2em;
    text-align: center;
}
.single_page article p {
    line-height: 1.5
}
.single_page article p:first-child {
    margin-top: 0;
}
.single_page article .entry-title, article .entry-title a {
    text-decoration: none;
    font-weight: normal;
}
.single_page article .entry-title {
    margin-bottom: 30px;
}
.single_page article .entry-title {
    font-size: 200%;
	font-weight: bold;
    letter-spacing: .1em;
    line-height: 1.6em;
    text-align: center;
}
.topics .page_link {
    width: 100%;
    padding: 25px 0;
    border-bottom: solid 1px #8dafcb;
}
.flt_l {
    float: left;
}
.flt_r {
    float: right;
}
.topics .page_link li {
    width: 48%;
}
.topics .page_link li a, .topics .list_link a {
    color: #595757;
    letter-spacing: .1em;
    line-height: 1.4em;
    text-decoration: none;
    -webkit-transition: opacity 0.7s;
    -moz-transition: opacity 0.7s;
    transition: opacity 0.7s;
}
.topics .page_link li.flt_l a {
    text-align: left;
    padding-left: 25px;
    background: url(../img/previouspostslink.png) no-repeat left center;
    background-size: 6px 8px;
}
.topics .page_link li.flt_r a {
    text-align: right;
    background: url(../img/nextpostslink.png) no-repeat right center;
    background-size: 6px 8px;
    padding-right: 25px;
}
.topics .page_link li a {
    display: block;
    text-decoration: none;
    font-size: 105%;
}
.topics .list_link {
    padding-top: 20px;
    text-align: center;
}
.topics .list_link a {
    padding-right: 25px;
    background: url(../img/nextpostslink.png) no-repeat right center;
    background-size: 6px 8px;
    text-decoration: none;
    color: #595757;
    line-height: 1em;
    font-size: 105%;
}
.x_link{
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%
}
.txt_100 .wpcf7-form-control-wrap, .wpcf7-not-valid-tip {
    width: 100%!important;
}
.wpcf7-list-item {
    margin: 0!important;
}
.wpcf_add_set span {
    padding: 0 16px 16px 0!important;
}
	




@media screen and (max-width:1400px){
.cvz.tp_under.hf .telz span.cap {
    font-size: 1.4vw;
}	
.cvz.tp_under .telz a span {
    font-size: 3vw;
}	
}
@media screen and (max-width:1199px){
a[href^="tel:"] {
	pointer-events: auto;
	cursor: pointer;
}	
.tab{display: block!important}		
.pc{display: none!important}		
header.general {
    padding: 2%;
}	
header.general h1 {
    width: 30%
}	
header.general h1 img {
    max-width: 100%
}	
header.general .infoz {
    width: 70%;
	justify-content: flex-end
}
.cvz {
    margin-right: 2vw;
}	
.cvz .telz a span {
    padding-left: 1.5vw;
    font-size: 2vw;
}
.cvz .mailz .vx a p span.nom, .cvz .mailz .free a p span, nav.general.fixed .cvz .mailz .vx a p span.nom {
    font-size: 1.25vw;
}	
.cvz .mailz .vx a p span.big,nav.general.fixed .cvz .mailz .vx a p span.big, .cvz.tp_under .mailz .free a p span {
    font-size: 2vw;
}
.tbl_time01.day8 {
	width: auto;
    max-width: 28vw;
}	
.tbl_caption {
    font-size: 1vw;
}	
nav.general ul > li {
    font-size: 1.25vw;
}	
nav.general ul > li a span {
    font-size: 0.8vw;
}	
nav.general.fixed .cvz .telz span.cap {
	padding-right: 2px;
    font-size: 1vw
}
nav.general.fixed .cvz .telz a span {
    padding-left: 0;
    font-size: 2vw;
}
.cvz .mailz .free a p span {
    font-size: 1vw;
}
footer .mapz .circz .vx .inn img {
	width: 10vw	
}
	
}
@media only screen and (min-width: 768px) and (max-width: 1300px) {
.med_lead .abs_box li a {
	font-size: 1.4vw;
	letter-spacing: normal;
}	
.w1320 {
    width: 100%;
    padding: 0 3%;
}
.first {
    padding-top: 6%;
    padding-bottom: 6%;
}
.first .in_box {
    width: 80%;
}
.first .abs {
    width: 10%;
    right: 3%;
}	
.first .btn {
    margin-top: 1.0em;
}
.first .btn a {
    padding: 1.0em 0;
}	
nav.general.fixed .cvz .mailz .vx a img {
    width: 2vw
}	
.taisetsu {
    background-size: 80%;
    padding-top: 12%;
}
.taisetsu .lead p {
    margin-top: 3%;
    font-size: 105%;
    padding-bottom: 4%;
}
.taisetsu .box01 {
    margin-bottom: 6%;
}
.taisetsu .box01 .img_list {
    margin-bottom: 3%;
}
.taisetsu .box01 .img_list li .caption {
    font-size: 110%;
}
.taisetsu .box02 {
    background-position: left top;
    background-size: 57% auto;
    padding: 5% 0;
}
.taisetsu .box02 .guie_box {
    width: 40%;
}
.taisetsu .box02 .flex_box h3 {
    width: 30%;
}
.taisetsu .box02 .flex_box dl {
    width: 67%;
}
.taisetsu .box01 dt, .taisetsu .box02 dt {
    font-size: 180%;
}
.taisetsu .box01 dt, .taisetsu .box02 dt {
    font-size: 180%;
    margin-bottom: .2em;
}
.taisetsu .box0345 {
    padding: 5% 0 8%;
}
.taisetsu .box0345 ul {
    margin-left: -3%;
}
.taisetsu .box0345 li {
    width: 30.3333%;
    margin-left: 3%;
}
.taisetsu .box0345 li dt {
    font-size: 140%;
}
.taisetsu .box0345 li dt {
    font-size: 140%;
}
.yobo .r_box h3 {
    font-size: 3.4vw;
}
.yobo {
    background-size: 60% auto;
    padding-top: 6%;
    padding-bottom: 6%;
}	
.med_pickup li h3 {
    font-size: 3.0vw;
}
.med_other li a {
    font-size: 100%;
    letter-spacing: .05em;
    padding-right: .5em;
}	
.med_other li a span{
    display: block;
	width: 100%
}	
.bnr_recruit {
    max-width: 500px;
}
.bnr_recruit dl {
    padding: 20px 0;
}
.bnr_recruit dt {
    font-size: 380%;
}
.top .bnr_recruit dt {
    font-size: 3.5vw;
}		
.bnr_recruit dd {
    font-size: 1.3vw;	
    line-height: 1.4em;
}
.bnr_recruit dd a {
    font-size: 110%;
}
#page_top {
    bottom: 30px;
}	
.under .lead_box {
    margin: 10% 0;
}	
.under .lead_box dl dt {
    font-size: 180%;
}
.under .lead_box dl dt h2 {
    font-size: 100%;
}
.h_type_2 {
    font-size: 170%;
    margin-bottom: 6%;
}
.medical .sec_2 {
    margin: 0 auto 80px;
}	
.medical .in_box1 {
    margin-bottom: 40px;
}
.med_flt .img_r {
    margin: 0 0 2% 2%;
    width: 40%;
}
.med_flt .txt_l, .med_flt .txt_r {
    width: 100%;
    float: none;
}
.med_style1 dt {
    margin-bottom: 10px;
    font-size: 140%;
}
.sec_3 .med_frame_box .med_frame_list > li dt, .med_side4_box li dt {
    font-size: 130%;
}	
.sec_3 .detail .d_m dt {
    padding: 14px 6px;
    font-size: 18px;
    letter-spacing: .05em;
}
.sec_3 .detail .d_m dd {
    padding: 10px 20px;
	font-size: 14px
}	
nav.und ul li {
    width: 25%;
    margin-left: 12.5%;
    margin-bottom: 30px;
}
nav.und .w1320 {
    padding: 0 10%;
    width: 80%;
}	
nav.und ul li:nth-child(4),
nav.und ul li:nth-child(10)	{
    margin-left: 0;
}
.faq dl dt {
    font-size: 140%;
    letter-spacing: 0.1em;
    padding-bottom: 20px;	
}	
.faq dl dd {
    padding: 30px 4%;
}
nav.und ul li a {
    font-size: 1.6vw;
    letter-spacing: .1em;
}	
.med_side4_box li {
    width: 32.333%;
	padding: 0.8rem
}
p.msg {
	font-size: 120%;
    letter-spacing: 0.15em;
}
.vx_type_1 .med_check_title {
    margin-bottom: 30px;	
}	
.vx_type_1 .med_check_title dt {
    font-size: 115%;
    margin-bottom: 0.5em;
}	
.vx_type_1 .med_check_title dd span {
    font-size: 175%;
}	
.med_check_li li {
    padding-bottom: 15px;
    margin-bottom: 15px;
    width: 49%;
}
.med_check_li li p, .med_check_li li dt {
    background-size: 20px;
    padding: 3px 0 3px 35px;
    font-size: 105%;
}	
.form_area .th {
  	padding: 20px 1% 20px 1%;
}	
.form_area .td {
    padding: 20px 1%;
}	
.sub_menu .vx a {
	font-size: 1.2vw	
}	
.flex_circ .vx{
	width: calc(33.33333% - 20px);	
	margin: 26px 10px 0 0;	
}
.box02 .med_frame_box .med_frame_list > li dt, .box02 .med_frame_box .med_frame_list > li p.title {
    font-size: 125%;
    margin-bottom: 15px;
}
.box02 .item_box .score {
    /* margin: 13px 0 20px; */
    padding: 7px 10px;
}	
.box02 .item_box .score li {
    font-size: 100%;
}	
.med_flow_box li .txt {
    font-size: 80%;
    line-height: 1.4em;
    margin-top: .5em;
}	
.med_flow_box {
    padding: 20px 3%;
}	
.box03 .txt_box dd li {
    background-size: 20px 20px;
    font-size: 115%;
    padding-left: 35px;
}	
.staff .box1 .bg_col .flex_box .box_l {
    width: 47%;
    margin-right: 5%;
}	
.name_box p {
    font-size: 185%;
}
.name_box p {
    font-size: 185%;
}	
.staff .box1 .bg_col .flex_box .box_r {
    width: 48%;
}	
.staff .box1 .bg_col .flex_box .box_r > dt {
    font-size: 185%;
}
.staff .box1 .bg_col2 {
    padding: 60px 0 0 0;
    background-size: 60% auto;
}	
.staff .box1 .bg_col2 .flex_box .box_l {
    width: 52%;
    margin-right: 4%;
    min-width: inherit;
}	
.staff .box1 .bg_col2 .box_l .ryakureki_list dt {
    width: auto;
}	
.staff .box1 .bg_col2 .flex_box .box_r {
    width: 44%;
}	
.staff .box2 .flex_box > li {
    width: 48%;
    margin-bottom: 60px;
}	
.rec_point li dt {
    font-size: 120%;
    margin-bottom: 10px;
}
.rec_point li dl {
    width: calc(62% - 30px);
    padding: 30px 0 0 30px;
    background-size: 130px auto;
}
.rec_point li div {
    width: 35%;
}
.single_page article .entry-date {
    margin-bottom: 15px;
}
.single_page article .entry-title {
    margin-bottom: 20px;
}	
.single_page article .entry-title {
    font-size: 180%;
}	
}
@media screen and (max-width:768px){
nav.und ul li a {
    font-size: 1.8vw;
    letter-spacing: .1em;
}		
}
@media screen and (max-width:767px){
/* ==========================================================================
   Commons styles
   ========================================================================== */
.flex_wrapper, .flex-wrap_par{
    display: block;
}
.flex_sp{
	display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
	flex-wrap: wrap;
}	
.pc{display: none!important}
.tab{display: none!important}
.sp{display: block!important}	
.wrap_1250, .wrap_1000, .wrap_800 {
    width: 100%;
    height: auto;
    margin: 0 auto;
	padding: 0 0.8rem
}
.sec_pad_1{
	padding: 40px 0
}
.sec_pad_1_b{
	padding-bottom: 40px
}
.sec_pad_1_t{
	padding-top: 40px;
}
.rec_box {
    padding: 10% 0;
}	
.rec_box::before {
    height: 1.5em;
}	
.bnr_recruit {
    width: 90%;
}	
.bnr_recruit dl {
    padding: 5% 0;
}
.bnr_recruit dt,
.top .bnr_recruit dt{
    font-size: 10vw;
    margin-bottom: 5px;
}
.top .bnr_recruit dt{
    font-size: 8vw;
}
.bnr_recruit dd {
    line-height: 1.6;
}
.bnr_recruit dd a {
    font-size: 3vw;
}	
body {
    font-size: 4.2vw;
    letter-spacing: normal;
    line-height: 1.8em;
	overflow-x: hidden
}
header.general {
    margin-bottom: 3%;
    background-size: contain;
    padding: 10px 0;
    display: block;	
}	
header.general .infoz {
    display: none
}	
header.general h1 {
    width: 70%;
}
.sub_m_tgt {
    display: none
}		
.drawer-hamburger {
    position: fixed;
    z-index: 10001;
    top: 0;
    display: block;
    box-sizing: content-box;
    width: 50px;
    height: 40px;
    padding-top: 20px;
    text-align: center;
    color: #2da4db;
    font-weight: 400;
    font-style: normal;
    font-size: 10px;
    letter-spacing: .1em;
    line-height: 1.2em;
    border: none;
    outline: 0;
    background: transparent;
    border-radius: 0;
    -webkit-transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0);
}
.drawer-hamburger, .drawer-open .drawer-navbar .drawer-hamburger {
    right: 0;
}
.drawer-hamburger-icon {
    position: relative;
    left: 0;
    right: 0;
    top: 5px;
    margin: 0 auto;
    display: block;
}
.drawer-hamburger-icon, .drawer-hamburger-icon:before, .drawer-hamburger-icon:after {
    width: 22px;
    height: 2px;
    -webkit-transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: all .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
    background-color: #0062b1;
    margin: 0 auto;
}
.drawer-hamburger-icon:before, .drawer-hamburger-icon:after {
    position: absolute;
    top: -8px;
    left: 0;
    content: ' ';
}
.drawer-hamburger-icon:after {
    top: 8px;
}
.drawer-open .drawer-hamburger {
    right: 0;
}	
.drawer-open .drawer-hamburger-icon:before, .drawer-open .drawer-hamburger-icon:after {
    top: 0;
}
.drawer-open .drawer-hamburger-icon:before {
    -webkit-transform: rotate(
45deg
);
    -ms-transform: rotate(45deg);
    transform: rotate(
45deg
);
}	
.drawer-open .drawer-hamburger-icon:after {
    -webkit-transform: rotate(
-45deg
);
    -ms-transform: rotate(-45deg);
    transform: rotate(
-45deg
);
}
.drawer-open .drawer-hamburger-icon {
    background-color: transparent;
}	
.drawer-hamburger .menu_txt {
    position: absolute;
    bottom: 5px;
    left: 0;
    right: 0;
    margin: auto;
}
.drawer-nav {
    position: fixed;
    z-index: 501;
    top: 0;
    overflow: hidden;
    width: 16.25rem;
    height: 100%;
    background-color: rgba(255,255,255,0.95);
}
.drawer-nav {
    position: fixed;
    z-index: 10000;
    top: 0;
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    width: 16.25rem;
    height: 100%;
    background-color: rgba(255,255,255,0.95);
	
}
.drawer-nav {
    right: -16.25rem;
    -webkit-transition: right .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
    transition: right .6s cubic-bezier(0.190, 1.000, 0.220, 1.000);
}
.drawer-open .drawer-nav {
    right: 0;
}	
.drawer-menu {
    margin: 0;
    padding: 0;
    list-style: none;
    text-align: left;
    padding-top: 80px;
    padding-bottom: 100px;
}
.drawer-menu a {
    display: block;
    padding: 15px 5% 15px 2em;
    border-bottom: solid 1px #ccc;
    position: relative;
    line-height: 1.4em;
}
.drawer-menu a::before {
    position: absolute;
    content: "";
    left: .7em;
    top: 0;
    bottom: 0;
    margin: auto;
    width: .3em;
    height: .3em;
    border-right: 1px solid #666;
    border-bottom: 1px solid #666;
    -webkit-transform: rotate(
-45deg
);
    transform: rotate(
-45deg
);
}
.drawer-menu .index_row {
    background: #2da4db;
    padding: .8em;
    color: #fff;
    font-size: 90%;
    font-weight: bold;
    letter-spacing: .2em;
    line-height: 1.2em;
}
.drawer-overlay {
    position: fixed;
    z-index: 500;
    top: 0;
    left: 0;
    display: none;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, .4);
}	
.drawer-open .drawer-overlay {
    display: block;
}	
nav.general {
    position: relative;
    margin-top: 0;
}	
nav.general ul {
	width: 100%;
	padding: 0 2px 0 0;
    text-align: center;
    background-color: transparent;
    letter-spacing: .05em;
}	
nav.general ul li {
    width: calc(50% - 1px);
    margin: 0 auto 2px;
    flex: auto;	
    padding: 0;
	border-left: 2px solid #FFF;
    background-color: rgba(45,164,219,.88);
	font-size: 3.8vw
}	
nav.general ul li:first-child {
	border-left: 2px solid #FFF;
}	
nav.general ul li a {
	height: 100%;
    padding: .8em 0;
    color: #fff;
}
nav.general ul li a p {
    padding-bottom: 0;
    line-height: 1.5;
}	
nav.general ul > li a span,
nav.general ul > li::before	{
    display: none
}	
.home .fv .slick li img.mn {
    height: 400px;
}	
.home .fv .slick li::before {
    height: 20%;
}
.home .fv .slick li figure img {
    width: 70%
}	
.home .fv .slick-dots {
    bottom: 3%;
}	
.time_info {
	width: calc(100% - 10%);
    padding: 6% 0;
    margin: 7% auto 0;
}	
.cvz {
    margin-right: 0;
}	
.cvz .telz span.cap {
	width: 30%;
    padding-right: 0;
	font-size: 13px
}	
.cvz .telz a {
	width: 70%;
}	
.cvz .telz a span {
    padding-left: 0;
    font-size: 6.5vw;
}
.attn_vx .cvz .telz a span {
    font-size: 5.5vw;
	width: calc(100% - 30px)
}
.cvz .telz span.cap {
	width: 30%;
    padding-right: 0;
}	
.cvz .mailz .vx a p span.nom, .cvz .mailz .free a p span, nav.general.fixed .cvz .mailz .vx a p span.nom {
    font-size: 3.5vw;
}	
.cvz .mailz .vx a p span.big, nav.general.fixed .cvz .mailz .vx a p span.big {
    font-size: 5.5vw;
}	
.tbl_time01.day8 {
    max-width: 100%;
	margin-top: 26px
}	
.home .news h2 {
    margin-bottom: 0;
	font-size: 160%;
}	
.home .news dl {
    padding: 10px;
    height: 250px;
}	
.taisetsu {
    background-size: 70% auto;
    padding-top: 14%;
}
.taisetsu .lead h2 {
    width: 100%;
}
.taisetsu .lead p {
    margin-top: 6%;
    font-size: 105%;
    padding-bottom: 12%;
}
.taisetsu .box01 {
    margin-bottom: 10%;
}
.taisetsu .box01 .img_list {
    margin-bottom: 0;
    display: block;
}
.taisetsu .box01 .img_list li:first-child {
    width: 95%;
    padding-top: 0;
}
.taisetsu .box01 .img_list li .caption {
    font-size: 100%;
}
.taisetsu .box01 .img_list li:last-child {
    width: 70%;
    margin-left: auto;
    margin-right: 0;
}
.taisetsu .box01 .img_list li:last-child .caption {
    text-align: right;
}
.taisetsu .box01 .txt_box {
    padding-top: 8%;
}	
.taisetsu .box01 .txt_box h3 {
    width: 32%;
    text-align: left;
    right: auto;
    left: 3%;
    top: -5%;
    -webkit-transform: none;
    transform: none;
}	
.taisetsu .box01 .txt_box .flex_box {
    display: block;
}
.taisetsu .box01 .txt_box .flex_box p {
    width: 44%;
    position: absolute;
    left: 2%;
    bottom: 100%;
}	
.taisetsu .box01 .txt_box .flex_box dl {
    width: 100%;
    max-width: 100%;
}	
.taisetsu .box01 dt, .taisetsu .box02 dt {
    font-size: 140%;
    letter-spacing: .0em;
    line-height: 1.6em;
    margin-bottom: .3em;
}	
.taisetsu .box01 .txt_box .flex_box dt {
    width: 65%;
    margin-left: auto;
    margin-right: 0;
}
.taisetsu .box01 .txt_box .flex_box dt {
    width: 65%;
    margin-left: auto;
    margin-right: 0;
}	
.taisetsu .box02 {
	background-image: none;
    padding: 0 0 10%;
}		
.taisetsu .box02 .guie_box {
    position: static;
    width: 100%;
    background: #f7b52c url(../img/concept_img2_1@2x.jpg) no-repeat left center;
    background-size: 120% auto;
    padding-top: 35%;
}
.taisetsu .box02 .guie_box p {
    padding-right: 15%;
}
.taisetsu .box02 .flex_box {
    width: 100%;
    max-width: 100%;
    display: block;
    padding-top: 8%;
    position: relative;
}
.taisetsu .box02 .flex_box h3 {
    width: 32%;
    position: absolute;
    left: 0;
    top: -6%;
}
.taisetsu .box02 .flex_box dl {
    width: 100%;
}
.taisetsu .box02 .flex_box dt {
    width: 65%;
    margin-left: auto;
    margin-right: 0;
}
.w1320, w1200 {
    padding: 0 0;
}	
.taisetsu .box0345 {
    padding: 10% 0 12%;
}	
.taisetsu .box0345 li h3 {
    position: absolute !important;
    width: 30% !important;
    padding: 0 !important;
    /* top: 15%; */
}
.taisetsu .box0345 li p {
    position: relative !important;
    width: 65% !important;
    padding: 0 !important;
}	
.taisetsu .box0345 ul {
    display: block;
    margin-left: 0;
}	
.taisetsu .box0345 li {
    width: 100%;
    margin-left: 0;
    position: relative;
    margin-bottom: 8%;
}
.taisetsu .box0345 li:nth-child(odd) h3 {
    left: 0;
    margin-bottom: 0;
}
.taisetsu .box0345 li:nth-child(odd) p {
    margin-left: auto;
    margin-right: 0;
}
.taisetsu .box0345 li dt {
    font-size: 130%;
    margin: .5em 0 .2em;
}
.taisetsu .box0345 li:nth-child(even) {
    display: block;
}
.taisetsu .box0345 li:nth-child(even) h3 {
    right: 0;
    margin-top: 0;
}
.taisetsu .box0345 li:nth-child(even) p {
    margin-left: 0;
    margin-right: auto;
}
.med_lead {
    padding: 8% 0 10%;
}	
.med_lead h2 {
    font-size: 100%;
    margin-bottom: 5%;
}
.med_lead h2 span {
    font-size: 280%;
    margin-bottom: .2em;
}
.med_lead p {
    text-align: left;
}
.med_lead .abs_box {
    margin: 3% 0 6%;
}
.med_lead .abs_box h3 {
    width: 75%;
    max-width: 100%;
    margin: 0 auto;
    position: static;
}
.med_lead .abs_box ul {
    width: 100%;
    max-width: 100%;
}
.med_lead .abs_box li {
    width: calc(50% - 1px);
    margin-left: 1px;
    margin-bottom: 1px;
}
.med_lead .abs_box li a {
    padding: 1.6em 0;
    font-size: 80%;
    letter-spacing: normal;
}
.first {
    padding-top: 10%;
    padding-bottom: 10%;
    text-align: left;
}
.first .in_box {
    width: 100%;
    margin-left: 0;
    margin-right: auto;
}
.first h3 {
    font-size: 140%;
    text-align: center;
    margin-bottom: .5em;
}
.first .in_box .sp_abs_box {
    position: relative;
    padding-right: 16%;
}
.first .abs {
    width: 15%;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}
.first .btn {
    width: 100%;
    margin-top: 1.0em;
    text-align: center;
}
.first .btn a {
    box-shadow: 0px 2px 8px 0px rgb(0 0 0 / 15%);
    padding: 1.0em 0;
    padding-right: 1.0em;
    font-size: 110%;
}
.yobo {
    background: url(../img/yobo_bg@2x_sp.jpg) no-repeat right top;
    padding-top: 6%;
    padding-bottom: 8%;
}
.yobo .l_img {
    width: 80%;
    position: static;
    -webkit-transform: none;
    transform: none;
    margin-left: 0;
    margin-right: auto;
    margin-bottom: 3%;
}
.yobo .r_box {
    width: 100%;
    max-width: 100%;
}
.yobo .r_box h3 {
    font-size: 190%;
    margin-bottom: .3em;
    text-align: center;
}
.med_pickup {
    display: block;
}
.med_pickup li {
    width: 100%;
    padding: 6% 3% 5%;
    padding-left: 20%;
    background-position: 0% center;
    background-size: auto 100%;
}
.med_pickup li::before {
    opacity: 0;
}
.med_pickup li h3 {
    font-size: 180%;
}
.med_pickup li h3 span {
    font-size: 60%;
    letter-spacing: .05em;
}
.med_pickup li h3 i {
    margin-left: .1em;
}
.med_other {
    padding-top: 10%;
    padding-bottom: 10%;
}	
.med_other ul {
    -webkit-justify-content: space-between;
    justify-content: space-between;
    margin-left: 0;
}
.med_other li {
    width: 49.5%;
    margin-left: 0;
    margin-bottom: 1%;
    height: 4.0em;
    position: relative;
}
.med_other li::before {
    font-size: 100%;
    right: .3em;
}
.med_other li a {
    padding: 0;
    font-size: 100%;
    letter-spacing: .05em;
    position: absolute;
    left: 0;
    right: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
	flex-wrap: wrap;
	align-content: center
}
.med_other li a span{
    display: block;
	width: 100%
}
footer .btnz .vx {
    width: 50%;
    padding: 3.6vw 1vw;
}	
footer .btnz .tel {
	width: 100%;
	display: block;
	padding: 4vw 0
}	
footer .btnz .vx p span {
    font-size: 4vw;
	padding: 0
}	
footer .btnz.stc .tel .num {
    font-size: 7.2vw;
	line-height: 1.5;
}	
footer .btnz.stc .tel a {
    width: auto;
    height: auto;
    position: relative;
    top: 0;
    left: 0;
}	
footer .btnz .rza p .big {
    font-size: 7vw;
    line-height: 1.5;
}	
footer .btnz .mail p .big {
    font-size: 5vw;
}	
footer .btnz .rza p, footer .btnz .mail p {
    margin-top: 3vw;
    display: block;
    width: 100%;
}	
footer .mn_stg article {
    padding: 0 0.8rem
}	
footer .mn_stg .vx {
    width: 100%;
    text-align: left;
}	
footer .mn_stg .info h2 {
    font-size: 24px;
    margin-bottom: 12px;
}	
footer .mn_stg .info p {
    line-height: 1.5;
    margin-bottom: 1.5em;
}	
.for_sp {
    width: 100%;
	position: fixed;
	bottom: 0;
	left: 0;
	z-index: 9999999
}	
.for_sp .btnz .vx {
    width: 33.3333333%;
    padding: 0;
	height: 60px;
}	
.for_sp .btnz .tel {
    display: block;
}	
.for_sp .btnz .tel img,
.for_sp .btnz .rza img,
.for_sp .btnz .mail img{
    width: 20px;
	display: block;
	margin-right: 4%
}	
.for_sp .btnz .rza, .for_sp .btnz .tel {
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	flex-wrap: wrap;
}	
.for_sp .btnz .rza p, .for_sp .btnz .mail p, .for_sp .btnz .tel p {
    margin-top: 0;
    display: block;
	text-align: left;
	width: auto
}	
.for_sp .btnz .vx p span {
	display: block;
	font-size: 3.2vw;
	line-height: 1.25
}	
.for_sp .btnz .rza p .big{
	display: block;
	width: 100%;
    font-size: 3.2vw;
	line-height: 1.25
}	
.for_sp .btnz .mail p .big{
    font-size: 4vw;
    line-height:1;
}	
.for_sp .btnz .vx.arrw a::after {
    display: none
}	
.for_sp p.info {
	height: 36px;
	display: flex;
	justify-content: center;
	align-items: center;
	align-content: center;
	flex-wrap: wrap;	
	font-size: 3.2vw;
	font-weight: bold;
	text-align: center;
	background-color: #eef6f3
}	
#page_top {
    bottom: 101px;
    width: 10%;
}
footer {
    padding-bottom: 90px
}	
.tbl_time01.day8 thead th:first-child, .tbl_time01.day8 tbody th {
    width: 30%;
}	
.tbl_time01 thead th {
    padding: 14px 0 18px;
}	
.tbl_time01 tbody td {
    padding: 0 .05em 14px;
}	
.tbl_caption {
    font-size: 3.3vw;
}	
footer .tbl_time01 {
    font-size: 13px;
}	
footer .mapz .circz {
    justify-content: center;
}	
footer .mapz .circz .vx {
    width: 46%;
    padding-top: 47%;
	margin: 0 2% 0
}
footer .mapz .circz .vx .inn img {
    width: 34vw;
	margin-bottom: 10px
}	
footer .mapz .circz .vx .inn .smo {
    padding: 3px 10px 3px;
    font-size: 12px;
	line-height: 1
}	
footer .mapz .circz .vx .inn .big {
    font-size: 14px;
}	
.under .fv figure img {
    height: 200px;
}	
.under .fv h2 {
    font-size: 150%;
    letter-spacing: .15em;
}	
.under nav.general {
    display: none
}	
.under .sec_1 {
    margin-top: 0px;
}	
.under .lead_box dl dt {
    font-size: 140%;
    margin-bottom: 5%;
}	
.under .lead_box dl dt h2 {
    font-size: 100%;
    margin-bottom: 5%;
}	
.under .lead_box dl dd {
    text-align: left
}	
.h_type_2 {
	border-radius: 30px 0 0 0;
    font-size: 130%;
    letter-spacing: .05em;
    margin-bottom: 7%;
}	
.medical .med_box {
    margin: 0 auto 40px;
}	
.medical .in_box1 {
    margin-bottom: 8%;
}
.med_flt .img_r {
    float: none;
    margin: 0 auto 5% auto;
    width: 70%;
}
.med_flt .txt_l {
    width: 100%;
    float: none;
}	
.med_style1 dt {
    font-size: 120%;
    letter-spacing: .05em;
    line-height: 1.5em;
    margin-bottom: .5em;
}	
.medical .sec_2 {
    margin: 0 auto 40px;
}	
.med_side3_box li,.med_side4_box li,.med_side4_box.six_pack li {
    width: 100%;
	padding: 5%;
}	
.med_side3_box li dt,.med_side4_box li dt {
    font-size: 130%;
    margin: 0 0 3%;
}	
.med_side3_box li:last-child,.med_side4_box li:last-child  {
    float: none;
    margin: 5% 0 0;
}	
.med_frame_box .med_frame_list > li {
    padding-bottom: 0;
}	
.medical .in_box1 {
    margin-bottom: 40px;
}	
.dtl_vx .graph {
    width: 100%;
	margin-bottom: 5%;
}
.dtl_vx .txt {
    width: 100%;
}
.dtl_vx .txt h3,.dtl_vx .txt h2 {
    font-size: 130%;
    margin-bottom: 3%;
}	
.sec_3 .detail .d_m .merit {
	margin-bottom: 5%;
}
.sec_3 .detail .d_m .vx {
    width:100%;
}	
.sec_3 .detail .d_m dd {
    padding: 1.2rem 0.8rem;
}	
.rmd_vxz .tit {
    font-size: 5.5vw;
    padding: 4% 0;
    line-height: 1.5em;
}	
.rmd_vxz article {
    padding: 5%;
}	
.rmd_vxz article .dtl_vx.one {
    padding-bottom: 36px;
    margin-bottom: 36px;
}	
.under .rec_box .bnr_recruit dt {
    font-size: 200%;
    letter-spacing: 0.1em;
    margin-bottom: 10px;
    line-height: 1em;
    font-weight: 400;
}	
	
nav.und{
    padding: 8% 0;
    margin-top: 14%;
}
nav.und h2 {
    font-size: 130%;
    margin-bottom: 5%;
}	
nav.und ul {
    justify-content: space-between
}	
nav.und ul li {
    width: 47%;
    margin: 3% 0 0 0;
	padding-bottom: 12px;
    border-bottom: 1px solid rgba(62,58,57,0.30);
}	
nav.und ul li a {
    font-size: 3.9vw;
    letter-spacing: .05em;
    line-height: 1.5em;
    position: relative;
}
.under .rec_box .inn {
    padding: 24px 0
}	
.under .rec_box .inn .vx {
    width: 100%;
}	
.under .rec_box .inn .nv_nws {
    margin-bottom: 30px
}	
.under .rec_box .inn .nv_nws a {
	padding: 20px 0;	
    font-size: 200%;
    letter-spacing: .05em;
    line-height: 1.2em;
	margin-bottom: 0
}	
.under .rec_box .inn .nv_nws.arrw a::after {
    top: calc(50% - 16px);
	bottom: 0;
	margin: auto
}	
.maternity .med_flt .img_r {
    margin: 0 auto 5% auto;
    width: 90%;
}	
.med_flt .img_l {
    float: none;
    margin: 0 auto 5% auto;
    width: 70%;
}	
.med_flt .txt_r {
    width: 100%;
    float: none;
}	
.maternity .medical .in_box1,.surgery .medical .in_box1 {
    margin-bottom: 40px;
}	
.med_side4_box li {
    margin-bottom: 5%
}	
.med_side4_box li:last-child {
    margin-bottom: 0
}	
.faq dl dt, .faq dl dd {
    padding-left: 2.5em;
    background-size: 1.5em auto;
	margin-left: 0;	
}	
.faq dl dt {
	margin-left: 4%;
    font-size: 120%;
    letter-spacing: 0.1em;
    padding-bottom: 15px;
}	
.faq dl dd {
    padding: 4%;
    position: relative;
}	
.faq dl dd p {
    background: url(../img/icon_a.svg) no-repeat left top .4em;
    background-size: 28px 34px;
    padding-left: 2.5em;
    line-height: 1.8;
}	
.faq dl {
    margin-bottom: 30px;
}	
p.msg {
    font-size: 110%;
    letter-spacing: 0.05em;
    margin-top: 2%;
}	
.vx_type_1 {
    padding: 7% 5%;
}	
.vx_type_1 .med_check_title {
    margin-bottom: 5%;
}	
.vx_type_1 .med_check_title dt {
    font-size: 3.7vw;
    margin-bottom: 0.3em;
}	
.vx_type_1 .med_check_title dd span {
    font-size: 5.5vw;
    letter-spacing: 0.05em;
    background: url(../img/check_icon.svg) no-repeat right center;
    padding: 5px 35px 5px 0;
    background-size: 30px 23px;
}	
.med_check_li li {
    padding-bottom: 3%;
    margin-bottom: 3%;
    width: 100%;
}	
.med_check_li li p, .med_check_li li dt {
    background: url(../img/check_box.svg) no-repeat left 7px;
    background-size: 1.2em 1.2em;
    padding: 3px 0 3px 2em;
    font-size: 100%;
}
.cvz.tp_under .telz {
    margin-bottom: 16px;
}	
.cvz.tp_under .telz span.cap {
    font-size: 3.4vw;
}
.cvz.tp_under .telz a img {
    max-width: 30px;
}	
.cvz.tp_under .telz a span {
    font-size: 6vw;
}	
.cvz.tp_under .mailz .vx a {
    padding: 20px 0;
}	
.cvz.tp_under .mailz .free a p span {
    font-size: 3.4vw;
}	
.cvz.tp_under .mailz .vx.arrw a::after {
    right: 3%;
    top:auto;
	bottom: 0;
    margin: auto;
    font-size: 14px;
    color: #FFF;
}	
.contact .lead_box {
	width: 94%;
    padding: 40px 3%;
    margin: 0 auto;
    text-align: left;
}	
.box1 {
    padding-bottom: 14%;
}	
.com_index3 {
    padding: 3.5em 0 0;
    margin-bottom: 6%;
    font-size: 130%;
    letter-spacing: .08em;
    line-height: 1.5em;
}	
.box1 .com_index3 {
    margin-bottom: 8%;
}
.box1 .w1000 {
    padding: 8% 3%;
}
.com_reserve_coution {
    font-size: 105%;
    text-align: left;
    margin-bottom: 1.5em;
}
.box1 .bdr_list {
    margin: 8% 0;
}
.form_area {
    margin-top: 30px;
}	
.form_area .th {
    width: 100%;
    padding: 16px 4%;
    background: #fae3c4;
    font-size: 110%;
}	
.form_area .td {
    width: 100%;
    padding: 16px 4%;
}	
.form_area .td.sepa .vx_s {
    width: 100%;
}	
.form_area .td .vx_s:first-of-type {
    margin-bottom: 24px
}	
.form_area .td.cal .vx_s .fc_ora_2 {
    margin-bottom: 16px
}	
.form_area .td.cal .vx_s span {
    padding: 0
}	
.form_area .td.cal .vx_s input[type="date"] {
    margin-bottom: 16px
}	
.form_area .sub_cov {
    margin: 40px auto 0;
    width: 100%;
}	
.form_area .privacy section::before {
    display: none
}	
.form_area .privacy section dl {
    width: 100%;
}	
.form_area .sub_cov::after {
    right: 1%;
}	
.ortho .medical .in_box1 {
    margin-bottom: 0;
}	
.vx_type_2 .tx {
    width: 100%;
}	
.flex_circ .vx {
    width: 100%;
    margin: 20px 0 0;
}	
.flex_circ .vx .tx h3 {
    margin: 10px auto 5px;
    font-size: 110%;
    letter-spacing: .04em;
}	
.vx_type_2 .px {
    width: 100%;
    margin: 4% 0 0 0;
}	
.vx_type_2 .px {
	max-width: 100%;
}	
.vx_type_2 .px img {
	max-width: 100%;
    margin: 0 auto;
	display: block
}	
.h_type_3 {
    padding-top: 80px;
    margin-bottom: 35px;
    font-size: 140%;
    letter-spacing: .08em;
    line-height: 1.5em;
}
.box2 .flow_box li {
    padding-left: 40px;
    margin-left: 10px;
    padding-bottom: 5%;
    margin-bottom: 5%;
}
.box2 .flow_box li::before {
    width: 18px;
    height: 90%;
}
.box2 .flow_box li::after {
    width: 18px;
    height: 10px;
}	
.box2 .flow_box .flex_box {
    display: block
}	
.box2 .flow_box .flex_box .box_l {
    width: 100%;
}	
.box2 .flow_box .flex_box .box_l > dt {
    font-size: 130%;
    margin-bottom: 3%;
}
.box2 .flow_box .flex_box .box_r {
    width: 70%;
    max-width: 100%;
    margin: 5% auto 0;
}	
.vx_type_3 .inn,.vx_type_3.ora .inn,.vx_type_3.blue .inn {
    width: 100%;
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    padding: 0.8rem;
}	
.h_type_4 {
    padding: 20px 10px;
    margin-bottom: 26px;
    text-align: center;
    font-size: 130%;
}	
.balloon p {
    padding: 4px;
    font-size: 1rem;
}	
.bg_col2, .bg_col2.s_pad {
    padding: 6% 5%;
}
.bg_col2.s_pad {
    padding: 5%;
}
.bg_col2 .flex_box {
    -webkit-flex-flow: column;
    flex-flow: column;
}	
.bg_col2 .flex_box li {
    width: 100%;
}
.bg_col2 .flex_box li:first-of-type::before {
    bottom: 0;
    top: inherit;
    width: 100%;
    height: 1px;
}	
.bg_col2 .flex_box li:nth-child(1) {
    padding-bottom: 6%;
    margin-bottom: 6%;
}
.bg_col2 .flex_box li:nth-child(1) dl {
    padding-right: 0;
}

.bg_col2 .flex_box li dl {
    max-width: 100%;
}	
.bg_col2 .flex_box li dt {
    font-size: 120%;
    letter-spacing: 0.1em;
    margin-bottom: .5em;
}	
.dtl_vx .txt h3.ico {
	padding-right: 0;
    padding-left: 1em;
    text-indent: -0.6em;
}	
.dtl_vx .txt h3.ico i {
    padding-right: 0.2em;
}	
img.alignright {
    padding: 0;
    margin: 0 auto 10px;
    display: block;
}

.alignright {
    float: none;
}	
.toc dl {
    padding-left: 0;
	padding-right: 0
}	
.beauty.under .fv figure img {
    object-position: right center;
}	
.beauty.under .lead_box dl dt {
    margin-bottom: 0;
}	
.beauty.under .medical .in_box1 {
    margin-bottom: 0;
}	
.toc dl dd ul li a {
    display: block;
    margin-bottom: 16px;
    padding-left: 1em;
    text-indent: -1em;
    font-size: 16px;
    font-weight: bold;
    letter-spacing: .06em;
    line-height: 1.5;
    transition-property: all;
    transition: 0.1s linear;
}	
.beauty .num span {
    width: 35px;
    height: 35px;
}	
.mt_60 {
    margin-top: 40px;
}	
.beauty.under .medical .in_box1 {
    margin-bottom: 8%;
}	
.box02 .med_point_box .med_flt .txt_l {
    width: 100%;
}	
.box02 .med_point_box {
    padding: 7% 5%;
}	
.box02 .med_point_box dt {
    width: 100%;
    font-size: 130%;
    margin-bottom: 5%;
}	
.box02 .med_point_box .med_flt .img_r {
    width: 75%;
    float: none;
}	
.med_point_box .img_r {
    float: none;
    position: static;
    width: 75%;
    margin: 5% auto 0;
}	
.box02 .med_frame_box h3 {
    font-size: 5.5vw;
    padding: 4% 0;
    line-height: 1.5em;
}	
.box02 .med_frame_box .med_frame_list {
    padding: 5%;
}	
.box02 .med_frame_box .med_frame_list > li {
    padding-bottom: 10%;
    margin-bottom: 10%;
}	
.box02 .med_frame_box .med_flt .img_r {
    width: 65%;
}	
.box02 .item_box .med_flt .img_r {
    margin: 0 auto 5%;
}	
.box02 .med_frame_box .med_frame_list > li dt, .box02 .med_frame_box .med_frame_list > li p.title {
    font-size: 130%;
    margin-bottom: 3%;
    padding-left: 1.3em;
}
.box02 .item_box .score {
    margin: 10px 0;
    padding: 8px 8px;
}	
.box02 .item_box .score ul {
    width: 100%;
}
.box02 .item_box .score li {
    margin: 0 .5em;
    letter-spacing: .05em;
    font-size: 90%;
}	
.box02 .item_box .score_txt {
    letter-spacing: 0.06em;
    line-height: 1.9em;
}
.med_flow_box {
    padding: 6% 4%;
}
.box03 .med_flow_box .flow_index {
    margin-bottom: 5%;
}
.box03 .med_flow_box li {
    width: 100%;
    max-width: 100%;
	float: none
}	
.med_flow_box li p {
    max-width: 100%;
    display: inline-block;
    vertical-align: middle;
}	
.med_flow_box li .illust {
    width: 28%;
}	
.med_flow_box li p {
    max-width: 100%;
    display: inline-block;
    vertical-align: middle;
}
.med_flow_box li .txt {
    margin-top: 0;
    width: 62%;
    margin-left: 2%;
    font-size: 90%;
    text-align: left;
}	
.box03 .med_flow_box li {
    width: 100%;
    max-width: 100%;
}	
.box03 .med_flow_box li.flow_arrow {
    padding-top: 0;
}
.box03 .med_flow_box li.flow_arrow i:before {
    content: "\f0dd";
	font-size: 30px
}
.med_flow_box .flow_index {
    margin-bottom: 3%;
    font-size: 115%;
}
.box03 .txt_box dt {
    margin-bottom: 3%;
    font-size: 115%;
}	
.box03 .txt_box dd li {
    background-size: 1.2em 1.2em;
    font-size: 110%;
    padding-left: 2em;
}	
.staff .box1 .bg_col .flex_box {
    -webkit-flex-flow: column;
    flex-flow: column;
	display: block;
}	
.staff .box1 .bg_col .flex_box .box_l {
    width: 100%;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 10%;
}	
.staff .box1 .bg_col .flex_box .box_l .img_box .abs_img {
    bottom: 4%;
    right: 4%;
    width: 34%;
}
.staff .box1 .bg_col .flex_box .box_l .img_box .abs_img {
    bottom: 4%;
    right: 4%;
    width: 34%;
}	
.name_box p:first-of-type {
    margin-right: 0;
    margin-bottom: 2%;
}	
.name_box p:last-of-type {
    width: 45%;
    margin: 0 auto;
}	
.staff .box1 .bg_col .flex_box .box_l .prof_box li {
    margin-bottom: 2%;
    text-align: left;
}	
.staff .box1 .bg_col .flex_box .box_r {
    width: 100%;
}	
.staff .box1 .bg_col {
    padding-top: 0;
    padding-bottom: 0;
}	
.staff .box1 .bg_col::before {
    width: 0;
    height: 0
}	
.name_box {
    -webkit-flex-flow: column;
    flex-flow: column;
    padding-top: 6%;
	text-align: center;
}
.name_box p {
    font-size: 180%;
    letter-spacing: .1em;
}
.name_box p {
    font-size: 180%;
    letter-spacing: .1em;
}
.name_box p:first-of-type {
    margin-right: 0;
    margin-bottom: 2%;
}	
.name_box p {
    font-size: 180%;
    letter-spacing: .1em;
}
.name_box p:last-of-type {
    width: 45%;
    margin: 0 auto;
}	
.staff .box1 .bg_col .flex_box .box_l .prof_box li {
    margin-bottom: 2%;
    text-align: left;
}	
.staff .box1 .bg_col .flex_box .box_l {
    width: 100%;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 6%;
}	
.staff .box1 .bg_col .flex_box .box_r {
    width: calc(100% + 1.6rem);
	background-color: antiquewhite;
	margin-left: -0.8rem;
	padding: 0.8rem
}	
.staff .box1 .bg_col .flex_box .box_r > dt {
    font-size: 130%;
    letter-spacing: .1em;
    margin-bottom: 6%;
}
.staff .box1 .bg_col2 {
    padding-top: 24%;
    background-size: 90% auto;
    position: relative;
    z-index: 1;
}	
.staff .box1 .bg_col2 .flex_box {
    -webkit-flex-flow: column;
    flex-flow: column;
    padding-bottom: 0;
}
.staff .box1 .bg_col2 .flex_box .box_l {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 5%;
    min-width: inherit;
}	
.staff .box1 .bg_col2 .item > dt {
    letter-spacing: .1em;
    margin-bottom: 5px;
}	
.staff .box1 .bg_col2 .item dd {
    font-size: 90%;
}	
.staff .box1 .bg_col2 .flex_box .box_r {
    width: 100%;
}	
#loopslider {
  height: 180px;
}
#loopslider ul li {
  width: 800px;
  height: 180px;
}
#loopslider ul li img{
  width: 100%
}
.staff .box1 {
    padding-bottom: 0
}	
.staff .box1 .bg_col2::after {
    display: none
}	
.staff .box2 .flex_box {
    -webkit-flex-flow: column;
    flex-flow: column;
}	
.staff .box2 .flex_box > li {
    width: 100%;
    margin-bottom: 10%;
}	
.staff .box2 .flex_box > li:last-child {
    margin-bottom: 0;
}	
.staff .box2 .flex_box .bg_col {
    border-radius: 20px 0 0 0;
    margin-top: 5%;
}	
.base_pg{
	padding-bottom: 14%
}
.staff .box1 .btn_type_1 {
    padding: 30px 0 0;


}	
.staff .box2 .flex_box .prof_box .dt,
.staff .box2 .flex_box .prof_box .dd{
    width: 100%;
	font-size: 90%
}	
.staff .box2 .flex_box .prof_box .vx {
    padding-bottom: 8px;
    margin-bottom: 14px;
    line-height: 1.5;
}		
.h_type_5 {
    font-size: 130%;
    margin-bottom: 3%;
}	
.h_type_5 i {
    padding-right: 0.2em;
}	
.leave_teeth .sec_1 {
    margin-top: 40px;
}	
.clinic .sec_1.sec_pad_1,
.clinic .sec_4.sec_pad_1	{
    padding: 0 0 40px;
}	
.vx_type_3 .inn .vxz {
    margin: 0 0 0;
    padding-bottom: 0;
	border: none
}	
.vx_type_3 .inn .vxz .vx {
    width: 100%;
    margin: 40px 0 0;
    padding-bottom: 0;	
}	
.vx_type_3 .inn .vxz:first-of-type .vx:first-of-type,
.vx_type_3 .inn .vxz .vx.tx	{
    margin: 0 0 0;
}	
	
.vx_type_3 .inn .vxz .vx img {
    margin-bottom: 10px
}	
.access .sec_1 .time_info {
    margin: 0;
	width: 100%;
    padding: 6% 0 0;
}	
.access .sec_1 .tbl_time01.day8 {
    font-size: 16px;
}	
.access .sec_1 .cvz .telz {
    display: block;
	margin-bottom: 10px	
}	
.access .sec_1 .cvz .telz span.cap {
    width: 100%;
	text-align: center;
	display: block;
}	
.access .sec_1 .cvz .telz a {
	padding-top: 14px;
    width: 100%;
	justify-content: center
}	
.access .sec_1 .cvz .telz a span {
    font-size: 8vw;
}	
.access .sec_2 .vxz .vx {
    margin: 0 0 30px;
}	
.access .sec_2 .vxz .vx:last-child {
    margin: 0 0 0;
}	
.access .sec_2 .vxz .vx:first-child img {
    margin: 0 auto 12px;
}	
.access .sec_2 .vxz .vx img {
    margin: 0 auto;
}	
.vx_type_3.ora .inn {
    width: 100%;
    border-right: 3px solid #f0b688;
    border-bottom: 3px solid #f0b688;
    padding: 0.8rem!important;
}	
.h_type_8 {
	font-size: 130%;
    padding: 0 6px 10px;
}	
.access .sec_3 .ggmap {
    padding-bottom: 66.25%;
}	
.access .sec_1 .tbl_caption {
    margin: 20px 0 30px;
}	
.kids .sec_4 ul li {
    margin: 0 0 10px;
    width: 100%;
    padding: 0.8rem;
}	
.kids .sec_4 ul li:last-child {
    margin: 0 0 0;
}	
.kids .sec_4 ul li dt {
    font-size: 120%;
    margin: 10px 0;
}	
.rec_job_lead h3 {
    font-size: 7vw;
    margin-bottom: 4%;
    letter-spacing: 0.1em;
}	
.fs_140p {
    font-size: 8vw;
}	
.rec_job_lead .lead_img {
    margin: 8% auto;
}	
.rec_job_lead {
    margin-top: 0%;
    margin-bottom: 13%;
}
.rec_merit {
    padding: 8% 0;
    margin-bottom: 13%;
}
.rec_merit dl {
    background-size: 80% auto;
    padding-bottom: 5%;
    margin-bottom: 3%;
}
.rec_merit dt {
    font-size: 4.8vw;
    margin-bottom: 5%;
}
.rec_merit li {
    margin-bottom: 0.7em;
    padding-bottom: 0.7em;
}
.rec_point h6 {
    width: 85%;
    margin: 0 auto 7% auto;
}
.rec_point li {
    margin-bottom: 8%;
    padding-bottom: 8%;
    border-bottom: rgba(204,204,204,0.80) 1px solid;
}	
.rec_point li dl {
    width: 92%;
    float: none;
    padding: 8% 0 0 8%;
    background-size: 25% auto;
}	
.rec_point li dt {
    font-size: 120%;
    margin-bottom: 3%;
}
.rec_point li div {
    width: 65%;
    float: none;
    margin: 5% auto 0 auto;
}	
.rec_tbl .vx {
    padding: 1.1rem 0.8rem;
}	
.rec_tbl .th {
    width: 100%;
    font-size: 105%;
}	
.rec_tbl .td {
    width: 100%;
}
.arc_vx {
    padding: 8% 0 8% 0%;
}	
.arc_vx .entry-date {
    margin-bottom: 2%;
    font-size: 90%;
}	
.arc_vx .entry-title {
    font-size: 130%;
    line-height: 1.5em;
}	
.arc_vx .entry-inf {
    margin-bottom: 10px;
}	
.single_page article {
    padding: 8% 0 8% 0%;
}	
.single_page article .entry-date {
    margin-bottom: 2%;
    font-size: 90%;
}	
.single_page article .entry-title {
    margin-bottom: 5%;
}	
.single_page article .entry-title {
    font-size: 130%;
    line-height: 1.5em;
}	
.h_type_6{
	display: inline-block;
	padding: 13px 5px;
	font-size: 120%;
	line-height: 1.5
}
	
	
}
	
/* ==========================================================================
   Helper classes
   ========================================================================== */

/*
 * Hide visually and from screen readers
 */

.hidden {
    display: none !important;
}

/*
 * Hide only visually, but have it available for screen readers:
 * https://snook.ca/archives/html_and_css/hiding-content-for-accessibility
 *
 * 1. For long content, line feeds are not interpreted as spaces and small width
 *    causes content to wrap 1 word per line:
 *    https://medium.com/@jessebeach/beware-smushed-off-screen-accessible-text-5952a4c2cbfe
 */

.visuallyhidden {
    border: 0;
    clip: rect(0 0 0 0);
    clip-path: inset(50%);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
    white-space: nowrap; /* 1 */
}

/*
 * Extends the .visuallyhidden class to allow the element
 * to be focusable when navigated to via the keyboard:
 * https://www.drupal.org/node/897638
 */

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
    clip: auto;
    clip-path: none;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    width: auto;
    white-space: inherit;
}

/*
 * Hide visually and from screen readers, but maintain layout
 */

.invisible {
    visibility: hidden;
}

/*
 * Clearfix: contain floats
 *
 * For modern browsers
 * 1. The space content is one way to avoid an Opera bug when the
 *    `contenteditable` attribute is included anywhere else in the document.
 *    Otherwise it causes space to appear at the top and bottom of elements
 *    that receive the `clearfix` class.
 * 2. The use of `table` rather than `block` is only necessary if using
 *    `:before` to contain the top-margins of child elements.
 */

.clearfix:before,
.clearfix:after {
    content: " "; /* 1 */
    display: table; /* 2 */
}

.clearfix:after {
    clear: both;
}

/* ==========================================================================
   EXAMPLE Media Queries for Responsive Design.
   These examples override the primary ('mobile first') styles.
   Modify as content requires.
   ========================================================================== */

@media only screen and (min-width: 35em) {
    /* Style adjustments for viewports that meet the condition */
}

@media print,
       (min-resolution: 1.25dppx),
       (min-resolution: 120dpi) {
    /* Style adjustments for high resolution devices */
}

/* ==========================================================================
   Print styles.
   Inlined to avoid the additional HTTP request:
   http://www.phpied.com/delay-loading-your-print-css/
   ========================================================================== */

@media print {
    *,
    *:before,
    *:after {
        background: transparent !important;
        color: #000 !important; /* Black prints faster:
                                   http://www.sanbeiji.com/archives/953 */
        box-shadow: none !important;
        text-shadow: none !important;
    }

    a,
    a:visited {
        text-decoration: underline;
    }

    a[href]:after {
        content: " (" attr(href) ")";
    }

    abbr[title]:after {
        content: " (" attr(title) ")";
    }

    /*
     * Don't show links that are fragment identifiers,
     * or use the `javascript:` pseudo protocol
     */

    a[href^="#"]:after,
    a[href^="javascript:"]:after {
        content: "";
    }

    pre {
        white-space: pre-wrap !important;
    }
    pre,
    blockquote {
        border: 1px solid #999;
        page-break-inside: avoid;
    }

    /*
     * Printing Tables:
     * http://css-discuss.incutio.com/wiki/Printing_Tables
     */

    thead {
        display: table-header-group;
    }

    tr,
    img {
        page-break-inside: avoid;
    }

    p,
    h2,
    h3 {
        orphans: 3;
        widows: 3;
    }

    h2,
    h3 {
        page-break-after: avoid;
    }
}



.fee_tbl {
}
.fee_tbl table,
.fee_tbl_1 table,
.fee_tbl_2 table {
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
}
.fee_tbl th,
.fee_tbl_1 th {
	font-weight: bold;
	font-size: 90%;
    text-align: center;
    vertical-align: middle;
    color: #3B3B3B;
    background-color: #f8f6ef;
	border: solid 1px #e2d6b3;
	padding: 15px;
	line-height: 1.4;
}
.fee_tbl th:nth-child(1) {
	width: 16%;
}
.fee_tbl th:nth-child(2),
.fee_tbl th:nth-child(3) {
	width: 8%;
}
.fee_tbl th:nth-child(4) {
	width: 6%;
}
.fee_tbl th:nth-child(5) {
	width: 18%;
}
.fee_tbl th:nth-child(6),
.fee_tbl th:nth-child(7) {
	width: 22%;
}
.fee_tbl td,
.fee_tbl_1 td {
	font-size: 90%;
	vertical-align: middle;
	border: solid 1px #e2d6b3;
	padding: 15px;
	line-height: 1.4;
}
.fee_tbl td:nth-child(1),
.fee_tbl td:nth-child(2),
.fee_tbl td:nth-child(3),
.fee_tbl td:nth-child(4),
.fee_tbl td:nth-child(5),
.fee_tbl_1 td:nth-child(1),
.fee_tbl_1 td:nth-child(2) {
	text-align: center;
}
.fee_tbl_1 th:nth-child(1) {
	width: 26%;
}
.fee_tbl_1 th:nth-child(2) {
	width: 14%;
}
.fee_tbl_1 th:nth-child(3),
.fee_tbl_1 th:nth-child(4) {
	width: 30%;
}
.fee_ul {
}
.fee_ul li {
	list-style: disc;
	margin-left: 1rem;
	line-height: 1.4;
}
.fee_tbl_2 th {
	font-weight: bold;
	font-size: 90%;
    text-align: left;
    vertical-align: middle;
    color: #3B3B3B;
    background-color: #f8f6ef;
	border: solid 1px #e2d6b3;
	padding: 15px 10px;
	line-height: 1.4;
}
.fee_tbl_2 td {
	font-size: 90%;
    text-align: left;
	vertical-align: middle;
	border: solid 1px #e2d6b3;
	padding: 15px 10px;
	line-height: 1.4;
}
.fee_tbl_2 th:nth-child(1) {
	width: 20%;
}

.num_tbl {
}
.num_tbl li {
	list-style: decimal;
	line-height: 1.4;
	margin-left: 2rem;
	margin-bottom: 0.5rem;
}

@media screen and (max-width:767px){
.fee_tbl,
.fee_tbl_1 {
	overflow-x: scroll;
}
.fee_tbl table,
.fee_tbl_1 table {
	width: 760px;
}
.fee_tbl th,
.fee_tbl td {
	font-size: 80%;
	padding: 10px 5px;
}
.fee_tbl_2 th:nth-child(1) {
	width: 30%;
}
}


@media screen and (max-width:767px){

.wpcf7-list-item {
	display: inline-table !important;
	margin-bottom: 8px !important;
}
}