@charset "utf-8";
body {
	font-family: "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, "sans-serif";
	color: #47444F;
	font-size: 17px;
}
a {
	text-decoration: none;
	color: #47444F;
}
ul {
	list-style: none;
}
img {
	vertical-align: bottom;
	width: 100%;
}
.container {
	max-width: 1200px;
	margin: 0 auto;
	padding-top: 90px;
}
h2 {
	font-size: 28px;
	color: #20DB3F;
	text-align: center;
	position: relative;
	padding-top: 3rem;
	z-index: 2;
}
h2::before {
	position: absolute;
	content: url("../img/character.svg");
	display: block;
	top: -90px;
	left: 50%;
    transform: translateX(-50%);
}
h2::after {
	content: url("../img/h2_bg.png");
	display: block;
	position: absolute;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
}
#header {
	position: fixed;
	z-index: 20;
    background-color: rgba(205,248,188,0.45);
    width: 100%;
	padding: 10px;
}
#header_inner {
	margin: 0 auto;
	display: flex;
    align-items: center;
	max-width: 1510px;
}
.header_logo a {
	display: block;
}
.header_logo img {
	width: 100%;
}
.header_reserve {
	margin-left: auto;
}
.header_reserve ul li + li {
	margin-left: 50px;
}
.header_reserve ul {
	display: flex;
	align-items: center;
}
.header_reserve li {
	display: block;
	background: #FFFFFF;
	padding: 0 20px;
	border-radius: 10px;
	height: 62px;
}
.header_reserve li:hover {
	background: #CDF8BC;
}
.header_reserve_btn {
	display: flex;
	align-items: center;
	height: 62px;
}
.header_icon {
	margin-right: 17px;
	width: 20%;
}
.header_reserve_step {
	font-size: 12px;
}
.header_reserve_text {
	font-size: 16px;
	font-weight: 700;
}
.sp_nav {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    position: fixed;
}
.nav_wrapper {
    position: fixed;
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    bottom: 0;
}
.nav_wrapper div:first-child {
    border-left: 1px solid #505050;
}
.nav_wrapper div {
    width: 25%;
    display: flex;
    background: #fff;
    align-items: center;
    justify-content: center;
    border-right: 1px solid #505050;
    border-top: 1px solid #505050;
}
.nav_wrapper a {
    padding: 10px;
}
/*ここからメイン*/
main {
	width: 100%;
}
#mv_img {
	width: 100%;
	position: relative;
}
#mv_message {
	position: absolute;
	width: 40%;
	top: 582px;
	left: 2%;
	padding: 60px 70px;
	background: rgba(255,255,255,0.50);
}
#mv_message::before {
	content: url("../img/mv_icon01.png");
	display: block;
	position: absolute;
	left: 0;
}
#mv_message::after {
	content: url("../img/mv_icon02.png");
	display: block;
	position: absolute;
	top: -76px;
	right: 0;
}
#mv_message p {
	font-size: 32px;
	font-weight: bold;
	position: relative;
	z-index: 10;
}
#concept {
	background-image: url("../img/concept_background.png");
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
}
#concept_inner {
	width: 80%;
	margin: 0 auto;
    padding: 7rem 0;
	position: relative;
}
.concept_ttl {
    width: 50%;
    margin: 1rem auto;
}
.concept_text {
	width: 60%;
	border: 3px solid #D4D4D4;
	border-radius: 20px;
	background: #FFFFFF;
	padding: 60px;
	position: relative;
	margin: 0 auto;
	z-index: 5;
}
.concept_text_description {
	text-align: center;
	margin-bottom: 40px;
}
.concept_text_description:last-child {
	margin-bottom: 0;
}
#concept_inner::before {
	content: "";
	display: block;
	position: absolute;
    width: 292px;
    height: 307px;
	background-image: url("../img/concept_top.jpg");
	left: 0;
    top: 361px;
	z-index: 1;
}
#concept_inner::after {
	content: "";
	display: block;
	position: absolute;
	width: 443px;
    height: 307px;
	background-image: url("../img/concept_bottom.jpg");
	bottom: 80px;
	right: 0;
	z-index: 1;
}
#worry {
	margin: 0 auto;
	padding-top: 90px;
}
.worry_content {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 100px;
}
.worry_adult {
	flex-direction: row-reverse;
}
.worry_img {
	width: 40%;
}
.worry_text {
	max-width: 672px;
    padding: 32px 41px;
	border: 1px solid #707070;
	border-radius: 58px;
	flex: 5;
}
.worry_title {
	text-align: center;
	font-size: 28px;
	font-weight: 700;
	border-bottom: 3px dotted;
    padding-bottom: 28.5px;
}
.worry_description {
	padding-top: 40px;
}
.worry_description li {
	line-height: 2.5;
}
.worry_description li::before {
	content: '✓';
	color: #20DB3F;
	font-size: 20px;
	padding-right: 5px;
	font-weight: bold;
}
#reserve_message_top {
	margin: 90px auto 0 auto;
	position: relative;
}
.reserve_message_top_img {
	text-align: center;
}
.reserve_message_top_img img {
	width: 82%;
	vertical-align: bottom;
}
#reserve_message_top p {
	font-size: 37px;
	text-align: center;
	font-weight: 700;
	position: absolute;
	width: 100%;
	top: 60%;
	left: 50%;
	transform: translate(-50%,-50%);	
}
.reserve {
	margin: 0 auto;
}
.reserve_wrapper {
	background: #FDFFC8;
	width: 100%;
	padding: 100px 0;
}
.reserve_inner {
	max-width: 1240px;
	margin: 0 auto;
	padding: 55px 0;
	background: #FFFFFF;
	border: 3px solid #707070;
	width: 100%;
}
.reserve_title {
	font-size: 32px;
	text-align: center;
	font-weight: 700;
}
.reserve_flex {
	display: flex;
	align-items: center;
	justify-content: center;
    margin: 45px auto 0 auto;
    max-width: 1410px;
}
.reserve_btn {
	display: flex;
	align-items: center;
	max-width: 436px;
	text-align: center;
	font-size: 32px;
	font-weight: 700;
	padding: 20px 30px;
	margin-right: 30px;
}
.reserve_btn:last-child {
	margin-right: 0;
}
.reserve_btn:hover {
	opacity: 0.7;
}
.reserve_btn_tel {
	background: #CDF8BC;
}
.reserve_btn_web {
	background: #94E9F7;
	border-radius: 80px;
}
.reserve_btn_web span {
	display: block;
	font-size: 20px;
	font-weight: normal;
	background: #FFFFFF;
	border-radius: 50px;
	max-width: 130px;
}
.reserve_icon {
	padding: 23px;
	background: #FFFFFF;
	border-radius: 50%;
	margin-right: 30px;
}
.reserve_text {
    text-align: center;
    margin-top: 20px;
}
#kodawari01 {
	background-image: url("../img/kodawari01_background.png");
	background-size: cover;
	background-repeat: no-repeat;
}
.kodawari01_description {
	margin: 0 auto;
	padding: 90px 0;
}
h3 {
	font-size: 32px;
	font-weight: 700;
	display: inline-block;
	height: 42px;
	border-bottom: 15px solid #CCCCFF;
}
.kodawari01_content {
	margin: 60px auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.kodawari01_text {
	width: 60%;
}
.kodawari01_img {
	width: 33%;
}
.kodawari01_title {
	display: flex;
	justify-content: flex-start;
}
.kodawari01_number {
	margin-right: 20px;
	width: 11%;
}
.kodawari01_title_txt {
	font-size: 28px;
	font-weight: 700;
}
.kodawari01_txt {
	margin-top: 30px;
}
.kodawari01_flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	margin-top: 80px;
}
.kodawari01_point {
	width: 30%;
	padding: 43px 25px;
	border-radius: 45px;
	margin: 30px auto;
}
.point_green {
	background: rgba(205,248,188,0.60);
}
.point_blue {
	background: rgba(148,233,247,0.60);
}
.kodawari01_point_title {
	font-weight: 700;
	margin-bottom: 1rem;
}
#kodawari02 {
	background-image: url("../img/kodawari02_background.png");
	background-size: cover;
	background-repeat: no-repeat;
	padding-bottom: 100px;
}
.kodawari02_content_img {
	width: 45%;
}
.kodawari02_content01 {
	background-image: url("../img/kodawari02_01_bg.png");
	background-size: cover;
	background-repeat: no-repeat;
}
.kodawari02_content02 {
	background-image: url("../img/kodawari02_02_bg.png");
	background-size: cover;
	background-repeat: no-repeat;
}
.kodawari02_content03 {
	background-image: url("../img/kodawari02_03_bg.png");
	background-size: cover;
	background-repeat: no-repeat;
}
.kodawari02_content04 {
	background-image: url("../img/kodawari02_04_bg.png");
	background-size: cover;
	background-repeat: no-repeat;
}
.even {
	flex-direction: row-reverse;
}
.rgba {
	height: 100%;
	background: rgba(255,255,255,0.70);
	margin: 50px auto 0 auto;
	padding: 40px 60px;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.kodawari02_content_text {
	width: 50%;
}
.kodawari02_content_text span {
	font-size: 46px;
	font-weight: 700;
	color: #CCCCFF;
}
.kodawari02_content_title {
	font-size: 28px;
	font-weight: 700;
}
.kodawari02_content_txt {
	margin-top: 40px;
}
.kodawari02_list {
	width: 90%;
	margin: 3rem auto;
	padding: 20px;
	background: rgba(253,255,200,0.60);
}
.kodawari02_list ul li {
	font-size: 20px;
	margin-bottom: 20px;
}
.kodawari02_list ul li::before {
	content: url("../img/kodawari02_point.svg");
	display: inline-block;
	margin-right: 5px;
}
#kodawari02_point {
	display: flex;
	justify-content: space-around;
	flex-wrap: wrap;
}
.kodawari02_point_inner {
	width: 32%;
	margin: 50px 0;
}
.kodawari02_point_img {
	text-align: center;
}
.kodawari02_point_description {
	padding: 70px 20px;
	background: #FFFFFF;
	border: 3px solid #BFB5B5;
}
.kodawari02_point_title {
	font-weight: 700;
	height: 65px;
	position: relative;
	border-bottom: 3px solid #BFB5B5;
}
.kodawari02_point_txt {
	margin-top: 20px;
}

/*ワンランク上の歯のクリーニング*/
#teethcleaning{
	background-image: url(../img/kodawari01_background.png);
	background-size: cover;
	background-repeat: no-repeat;
	padding-bottom: 100px;
}
#teethcleaning h2{
	margin-bottom: 100px;
}
#teethcleaning .teethcleaning_description{
	padding: 30px 0;
}
#teethcleaning .teethcleaning_img{
	width: 60%;
	margin: 0 auto;
	margin-bottom: 45px;
}
#teethcleaning table{
	width: 100%;
	border-collapse:  collapse;
	margin-top: 45px;
}
#teethcleaning th{
	border: 1px solid #333;
	width: 50%;
	text-align: left;
	padding: 10px;
	background: rgba(205, 248, 188, 0.60);
}
#teethcleaning td{
	border: 1px solid #333;
	width: 50%;
	padding: 10px;
}

/*子どもの予防歯科について*/
.forkids_container {
	position: relative;
	padding: 95px 0;
	background-image: url("../img/forkids_foradults_back.png");
	background-size: cover;
	background-repeat: no-repeat;
}
.forkids_content {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
    padding: 10rem 0 3rem;
}
.forkids_content::before {
	content: url("../img/forkids.jpg");
	display: inline-block;
	position: absolute;
	left: 0;
	top: 104px;
	z-index: 1;
}
.forkids_content_txt {
	width: 60%;
	margin-left: auto;
	background: rgba(255,255,255,0.6);
	border: 3px solid #BFB5B5;
	position: relative;
	z-index: 4;
}
.forkids_content_txt_title {
	margin-top: 50px;
	font-size: 32px;
	font-weight: 700;
	color: #CCCCFF;
	text-align: center;
	-webkit-text-stroke: 1px #707070;
}
.forkids_content_txt_description {
	margin: 50px auto;
	padding: 0 95px;
}
#forkids_feature {
	padding-top: 4rem;
	position: relative;
	background: rgba(205,248,188,0.50);
}
.forkids_fea_container {
	width: 100%;
	padding-bottom: 90px;
}
.forkids_fea_title {
	margin: 0 auto;
	text-align: center;
	max-width: 665px;
	padding: 60px;
}
.forkids_fea_title::before {
	content: url("../img/forkids_fea_title.png");
	position: absolute;
	display: inline-block;
	top: 55px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 1;
}
.forkids_fea_title span {
	font-size: 35px;
	color: #47444F;
	font-weight: 700;
	position: relative;
	z-index: 4;
}
.forkids_fea_content {
	margin-top: 90px;
	background: #FFFFFF;
	border-radius: 30px;
}
.forkids_fea_content_flex {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 44px 32px;
}
.forkids_fea_content_flex_img {
	width: 36%;
}
.forkids_fea_content_flex_img img+img {
	margin-top: 15px;
	width: 74%;
}
.forkids_fea_content_flex_txt {
	width: 70%;
    margin-left: 15px;
}
.forkids_fea_content_flex_txt_title span {
	display: block;
	font-size: 24px;
	color: #A19DAC;
}
.forkids_fea_content_flex_txt_title {
	font-size: 28px;
	color: #CCCCFF;
	font-weight: 700;
	font-family: "HG丸ｺﾞｼｯｸM-PRO";
}
.forkids_fea_content_flex_txt_des {
	margin-top: 20px;
}
.forkids_fea_02 {
	flex-direction: row-reverse;
}
.forkids_fea_02_img {
	text-align: end;
}
.foradults_content_img {
	position: absolute;
	top: 0;
	right: 0;
}
.foradult_content {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
    padding: 10rem 0 3rem;
}
.foradult_content::before {
	content: url("../img/foradults.jpg");
	display: inline-block;
    position: absolute;
    right: 0;
    top: 104px;
    z-index: 1;
}
.foradults_content_txt {
	margin: 0;
}
.foradults_fea_title {
	margin: 0 auto;
	text-align: center;
	font-size: 35px;
	font-weight: 700;
	color: #47444F;
    margin-bottom: 165px;
	position: relative;
}
.foradults_fea_title::before {
	content: url("../img/forkids_fea_title.png");
	position: absolute;
    display: inline-block;
    top: -54px;
    left: 50%;
    transform: translateX(-50%);
    z-index: -1;
}
.foradults_fea_content {
	border: 1px solid #707070;
	border-radius: 60px;
	margin-bottom: 50px;
}
.foradults_fea_content_title {
	padding: 32px 50px;
	background: #CDF8BC;
	font-size: 28px;
	font-weight: 700;
	border-radius: 60px 60px 0 0;
}
.title_blue {
	background: #94E9F7;
}
.foradults_fea_flex {
	display: flex;
	justify-content: space-between;
	margin: 37px 50px;
}
.foradults_fea_txt {
	width: 50%;
}
#reserve_message_bottom {
	margin-top: 150px;
	width: 100%;
	background: #CDF8BC;
	border-radius: 50% 50% 0 0;
	padding: 20px 0;
}
.reserve_message_bottom_txt {
	width: 1222px;
	height: 350px;
	border-radius: 50%;
	background: rgba(255,255,255,0.55);
	margin: 0 auto;
	position: relative;
}
.center {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%,-50%);
	width: 80%;
}
.reserve_message_bottom_txt span {
	text-align: center;
	display: block;
	font-size: 32px;
	font-weight: 700;
}
.reserve_bottom {
	position: relative;
	top: 0;
}
#footer {
	background: rgba(205,248,188,0.20);
	padding-top: 80px;
}
#footer_flex {
	display: flex;
	justify-content: space-between;
	margin: 0 60px;
}
.footer_logo {
	width: 46%;
	margin: 0 auto;
}
.footer_reserve {
	display: block;
    margin: 0 auto 25px auto;
    max-width: 450px;
    background: #CDF8BC;
    border-radius: 56px;
    font-size: 28px;
    font-weight: 700;
    padding: 15px;
    text-align: center;
}
.footer_reserve:hover {
	opacity: 0.7;
}
.footer_web {
	display: flex;
	align-items: center;
	justify-content: space-around;
}
.footer_web_reserve {
	display: block;
	max-width: 275px;
	padding: 18px;
	border-radius: 20px;
	background: #94E9F7;
	font-size: 28px;
	font-weight: 700;
	position: relative;
}
.footer_web_reserve:hover {
	opacity: 0.7;
}
.reserve01::before {
	content: url("../img/icon_web_footer.svg");
	margin-right: 5px;
	vertical-align: bottom;
}
.reserve02::before {
	content: url("../img/icon_sheet_footer.svg");
	margin-right: 5px;
	vertical-align: bottom;
}
.reserve01::after {
	content: "STEP01";
	position: absolute;
	top: 10px;
	left: 75px;
	font-size: 24px;
	font-weight: normal;
}
.reserve02::after {
	content: "STEP02";
	position: absolute;
	top: 10px;
	left: 75px;
	font-size: 24px;
	font-weight: normal;
}
.footer_web_txt {
	text-align: center;
	margin-top: 15px;
	font-size: 18px;
}
.tbl_info {
	width: 100%;
	margin: 30px 0 15px;
}
.tbl_info th {
    text-align: left;
    font-weight: 700;
}
.tbl_info th, .tbl_info td {
    padding: 5px;
    font-size: 20px;
    vertical-align: middle;
    border-bottom: 1px solid #707070;
}
#footer_right {
	width: 50%;
}
.footer_right_title {
	font-size: 25px;
	margin-top: 50px;
	margin-bottom: 30px;
	font-weight: 700;
}
.footer_right_flex {
	display: flex;
	align-items: center;
}
.footer_right_flex li {
	margin-right: 10px;
}
.footer_right_flex li a {
	display: block;
}
.footer_right_txt {
	margin-bottom: 25px;
}
.parking {
	display: block;
    padding: 15px 0;
    max-width: 475px;
    border-radius: 56px;
    font-size: 28px;
    font-weight: 700;
    text-align: center;
    background: #CDF8BC;
    margin: 0 auto;
}
.parking:hover {
	opacity: 0.7;
}
#copy {
	padding: 10px 0;
	background: #CDF8BC;
}
#copy p {
	text-align: center;
	font-size: 10px;
}
.site-link {
	display: block;
	width: 90%;
	margin: 1rem auto;
}
.site-link:hover {
	opacity: 0.7;
}
.youtube {
	width: 100%;
	position: relative;
	z-index: 0;
	padding: 60px 0;
}
.youtube::before {
	content: "";
	width: 90%;
	height: 60%;
	background: rgba(253,255,200,0.50);
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}
.youtube::after {
	content: "";
	width: 90%;
	height: 60%;
	background: rgba(253,255,200,0.50);
	position: absolute;
	bottom: 100px;
	right: 0;
	z-index: -1;
}
.youtube-wrap {
	width: 90%;
	margin: 0 auto;
	padding: 30px 0;
}
.youtube-ttl {
	width: 40%;
	margin: 0 auto;
}
.youtube-movie {
	width: 60%;
	margin: 30px auto;
}
.youtube-movie:hover {
	opacity: 0.7;
}











