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

   mixin

===========================================================================*/
/*--------------------------------------------------------------------------
   overwrite
---------------------------------------------------------------------------*/
.l-page__main {
	padding-bottom: 0;
}

/*--------------------------------------------------------------------------
   common
---------------------------------------------------------------------------*/
/* animation
-----------------------------------------------------------------*/
.is-animate .c-hdg::before {
	transform: scale(0, 1);
}

.is-animated .c-hdg::before {
	transition: transform .6s cubic-bezier(.175, .885, .32, 1.275);
	transition-delay: .8s;
	transform: scale(1, 1);
}

/*--------------------------------------------------------------------------
   sec-mv
---------------------------------------------------------------------------*/
.sec-mv {
	position: relative;
}

.sec-mv .m-slide__item {
	height: calc(100vh - 265px);
	min-height: 500px;
}

@media only screen and (max-width: 767px) {
	.sec-mv .m-slide__item {
		height: calc(100vh - 95px);
		min-height: 300px;
		max-height: 420px;
	}
}

/*--------------------------------------------------------------------------
   sec-concept
---------------------------------------------------------------------------*/
.sec-concept {
	position: relative;
	margin-top: 75px;
	text-align: center;
}

@media only screen and (max-width: 767px) {
	.sec-concept {
		margin-top: 25px;
		padding-right: 35px;
		padding-left: 35px;
	}
}

.sec-concept__hdg {
	position: relative;
	margin-bottom: 30px;
	padding-bottom: 50px;
	font-size: 18px;
}

@media only screen and (max-width: 767px) {
	.sec-concept__hdg {
		margin-bottom: 20px;
		padding-bottom: 40px;
		font-size: 14px;
		line-height: 2;
	}
}

.sec-concept__hdg::before {
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 39px;
	height: 31px;
	background: url('../../img/common/ico_apple.svg') no-repeat;
	background-size: 39px 31px;
	content: '';
	transform: translateX(-50%);
}

@media only screen and (max-width: 767px) {
	.sec-concept__hdg::before {
		width: 24px;
		height: 19px;
		background: url('../../img/common/ico_apple.svg') no-repeat;
		background-size: 24px 19px;
	}
}

.sec-concept__hdg .mi-pc {
	display: inline-block;
}

@media only screen and (max-width: 767px) {
	.sec-concept__hdg .mi-pc {
		display: none;
	}
}

.sec-concept__txt {
	margin-top: 30px;
	font-weight: 600;
	line-height: 2.6;
}

@media only screen and (max-width: 767px) {
	.sec-concept__txt {
		margin-top: 20px;
		font-size: 11px;
	}
}

.sec-concept__btn {
	margin-top: 40px;
}

@media only screen and (max-width: 767px) {
	.sec-concept__btn {
		margin-top: 20px;
	}
}

/*--------------------------------------------------------------------------
   sec-about
---------------------------------------------------------------------------*/
.sec-about {
	margin-top: 80px;
}

@media only screen and (max-width: 767px) {
	.sec-about {
		margin-top: 60px;
	}
}

.sec-about__btn {
	margin-top: 30px;
}

@media only screen and (max-width: 767px) {
	.sec-about__btn {
		margin-top: 20px;
	}
}

.sec-about .m-slide {
	margin-top: 20px;
}

.sec-about .m-slide__item {
	height: 660px;
}

@media only screen and (max-width: 767px) {
	.sec-about .m-slide__item {
		height: calc(100vh - 250px);
		min-height: 300px;
	}
}

/*--------------------------------------------------------------------------
   sec-orthodontics
---------------------------------------------------------------------------*/
.sec-orthodontics {
	margin-top: 100px;
}

@media only screen and (max-width: 767px) {
	.sec-orthodontics {
		margin-top: 70px;
	}
}

.sec-orthodontics .m-orthodontics {
	margin-top: 45px;
}

/*--------------------------------------------------------------------------
   sec-fee
---------------------------------------------------------------------------*/
.sec-fee {
	margin-top: 115px;
}

@media only screen and (max-width: 767px) {
	.sec-fee {
		margin-top: 70px;
		padding-bottom: 80px;
	}
}

.sec-fee__lead {
	margin-top: 25px;
	text-align: center;
	font-size: 15px;
	font-weight: 600;
}

@media only screen and (max-width: 767px) {
	.sec-fee__lead {
		font-size: 11px;
		line-height: 2;
	}
}
.sec-fee__lead-small {
	text-align: center;
	font-size: 13px;
  font-weight: 600;
}

@media only screen and (max-width: 767px) {
	.sec-fee__lead-small {
    margin-top: 5px;
		font-size: 10px;
	}
}

.sec-fee .m-fee-list {
	margin-top: 25px;
}

@media only screen and (max-width: 767px) {
	.sec-fee .m-fee-list {
		margin-top: 20px;
	}
}
.m-fee-list__price-tax {
	font-size: 13px;
	}
@media only screen and (max-width: 767px) {
	.m-fee-list__price-tax {
    display: block;
	font-size: 10px;
	}
  .m-fee-list__price-wrap {
    text-align: right;
  }
}
.sec-fee__btn {
	margin-top: 25px;
}

@media only screen and (max-width: 767px) {
	.sec-fee__btn {
		margin-top: 20px;
	}
}

/*--------------------------------------------------------------------------
   sec-hours
---------------------------------------------------------------------------*/
.sec-hours {
	margin-top: 120px;
}

@media only screen and (max-width: 767px) {
	.sec-hours {
		margin-top: -40px;
		padding: 40px 0 45px;
	}
}

.sec-hours__lead {
	margin-top: 25px;
	text-align: center;
	font-weight: 600;
}

@media only screen and (max-width: 767px) {
	.sec-hours__lead {
		font-size: 11px;
		line-height: 2;
	}
}

.sec-hours__calendar {
	position: relative;
	max-width: 800px;
	margin: 30px auto 0;
}

@media only screen and (max-width: 767px) {
	.sec-hours__calendar {
		width: auto;
	}
}

.sec-hours__calendar .fc-view-container {
	background-color: #fff;
}

.sec-hours__calendar .fc-header-toolbar {
	margin-bottom: 10px;
}

@media only screen and (max-width: 767px) {
	.sec-hours__calendar .fc-header-toolbar {
		margin-bottom: 8px;
	}
}

.sec-hours__calendar .fc-header-toolbar .fc-center h2 {
	font-size: 14px;
	line-height: 1;
}

@media only screen and (max-width: 767px) {
	.sec-hours__calendar .fc-header-toolbar .fc-center h2 {
		font-size: 12px;
	}
}

.sec-hours__calendar .fc-header-toolbar .fc-button {
	width: 50px;
	height: 30px;
	margin: 0;
	padding: 0;
	box-shadow: none;
	background: #fff;
	color: #5d370c;
	transition: .2s;
}

.mode-pc .sec-hours__calendar .fc-header-toolbar .fc-button:hover {
	opacity: .8;
}

@media only screen and (max-width: 767px) {
	.sec-hours__calendar .fc-header-toolbar .fc-button {
		top: -4px;
	}
}

.sec-hours__calendar .fc-header-toolbar .fc-icon-left-single-arrow,
.sec-hours__calendar .fc-header-toolbar .fc-icon-right-single-arrow {
	position: absolute;
	top: 0;
	left: 0;
	width: 50px;
	height: 30px;
	margin: 0;
	padding: 0;
}

.sec-hours__calendar .fc-header-toolbar .fc-icon-left-single-arrow:after,
.sec-hours__calendar .fc-header-toolbar .fc-icon-right-single-arrow:after {
	position: absolute;
	top: calc(50% - 4px);
	left: calc(50% - 4px);
	width: 8px;
	height: 8px;
	border-top: 2px solid #7a0;
	border-right: 2px solid #7a0;
	content: '';
	transform: rotate(-135deg);
}

.sec-hours__calendar .fc-header-toolbar .fc-icon-right-single-arrow:after {
	left: calc(50% - 6px);
	transform: rotate(45deg);
}

.sec-hours__calendar .fc-scroller {
	height: auto !important;
}

.sec-hours__calendar .fc-event {
	margin: 0 5px;
	padding: 5px 0;
	border: none;
	background-color: #abcd03;
	text-align: center;
	font-size: 10px;
	font-weight: 600;
	line-height: 1;
}

@media only screen and (max-width: 767px) {
	.sec-hours__calendar .fc-event {
		padding: 2px 0;
		font-size: 9px;
	}
}

.sec-hours__body {
	width: 800px;
	margin: 45px auto 0;
}

@media only screen and (max-width: 767px) {
	.sec-hours__body {
		display: block;
		width: auto;
	}
}

.sec-hours__table {
	width: 100%;
	border: 4px solid #abcd03;
	text-align: center;
	table-layout: fixed;
	border-collapse: collapse;
}

@media only screen and (max-width: 767px) {
	.sec-hours__table {
		border: 3px solid #abcd03;
	}
}

.sec-hours__table th {
	width: calc(100% / 7);
	padding: 3px 0;
	border: 2px solid #abcd03;
	font-size: 16px;
}

@media only screen and (max-width: 767px) {
	.sec-hours__table th {
		width: 50px;
		border: 1px solid #abcd03;
		font-size: 11px;
	}
}

.sec-hours__table td {
	padding: 9px 0;
	border: 2px solid #abcd03;
	font-size: 13px;
	font-weight: 600;
}

@media only screen and (max-width: 767px) {
	.sec-hours__table td {
		width: auto;
		border: 1px solid #abcd03;
		font-size: 12px;
	}
}

.sec-hours__table .close {
	font-size: 16px;
}

.sec-hours__table .note {
	display: block;
	margin-top: -2px;
	font-size: 8px;
	line-height: 1;
}

@media only screen and (max-width: 767px) {
	.sec-hours__table .note {
		margin-top: 2px;
	}
}

.sec-hours__note {
	margin-top: 12px;
	font-size: 13px;
	font-weight: 600;
}

@media only screen and (max-width: 767px) {
	.sec-hours__note {
		font-size: 11px;
	}
}

/*
.sec-hours__twitter {
	display: none;
}

@media only screen and (max-width: 767px) {
	.sec-hours__twitter {
		display: block;
		margin-top: 20px;
	}
	.sec-hours__twitter iframe {
		width: 100% !important;
	}
}
*/

.facebook-wrapper {
    max-width: 500px;
    margin: 0 auto;
    margin-top: 20px;
}
.facebook-wrapper > .fb-page {
    width: 100%;
}
.facebook-wrapper > .fb-page > span,
.facebook-wrapper iframe {
    width: 100% !important;
}

/*--------------------------------------------------------------------------
   sec-access
---------------------------------------------------------------------------*/
.sec-access {
	margin-top: 80px;
}

@media only screen and (max-width: 767px) {
	.sec-access {
		margin-top: -40px;
		padding-top: 40px;
	}
}

.sec-access__txt {
	margin-top: 30px;
	text-align: center;
	font-size: 14px;
	font-weight: 600;
	line-height: 2;
}

.sec-access__txt span {
	vertical-align: 5%;
}

.sec-access__map {
	position: relative;
	margin: 40px auto 0;
}

@media only screen and (max-width: 767px) {
	.sec-access__map {
		margin: 30px 0 0;
	}
}

.sec-access__map .js-gmap {
	height: 500px;
}

@media only screen and (max-width: 767px) {
	.sec-access__map .js-gmap {
		height: 300px;
	}
}
