@charset "UTF-8";
/*  
Theme Name:Original Style - 1column
Version:1.2
*/


.page-name-invisalign #contents > .inner {/* トップページ幅 100% */
	width:100%;
	max-width:100%;
}
.topinner {/* コンテンツは1000pxに */
	width:1000px;
	margin:0 auto;
	max-width:96%;
}

/* tinyMCE用に見出しをリセット */
.page-name-invisalign h3,
.page-name-invisalign h4,
.page-name-invisalign h5 {
	background:none;
	border:none;
	color:inherit;
	font-size:inherit;
	line-height:inherit;
	margin:0;
	padding:0;
    border-radius: 0;
    font-family: "Hiragino Mincho ProN", "Hiragino Mincho Pro","游明朝", YuMincho,  "ＭＳ 明朝", serif;
}
.page-name-invisalign h3::before,
.page-name-invisalign h3::after ,
.page-name-invisalign h4::before,
.page-name-invisalign h4::after,
.page-name-invisalign h5::before,
.page-name-invisalign h5::after {
	display:none;
}
.page-title,.bread_wrap{
    display: none;
}

/*==========================
	　mainimage
==========================*/
    .main_address {
    position: absolute;
    bottom: 0;
    right: 0;
}
/*-- スライダーの時 ------------*/

.slider { }
.slick-slide img { margin:0 auto;}

button.slick-arrow {/* 矢印ボタン */
	background:none;
	border:none;
	position:absolute;
	top:50%;
	margin-top:-20px;
	height:40px;
	width:16px;
	text-indent:-9px;
	z-index:1;
}
button.slick-arrow:hover {
 	cursor:pointer;
	opacity:0.7;
}
button.slick-prev {/* 矢印（前へ）ボタン */
	background:url(img/btn_prev.png) no-repeat;
	left:18%;
	margin-left:-16px;
}
button.slick-next {/* 矢印（次へ）ボタン */
	background:url(img/btn_next.png) no-repeat;
	right:18%;
	margin-right:-16px;
}
@media screen and (max-width: 1650px) {
button.slick-prev {	left:13.7%;}
button.slick-next {	right:13.7%;}
}
@media screen and (max-width: 1400px) {
button.slick-prev {	left:8%;}
button.slick-next {	right:8%;}
}
@media screen and (min-width: 1200px) {
.slick-track {}
.mainimage .slick-slide:not(.slick-center) {/* 前と次の画像を半透明に */
	opacity: 0.4;
	-moz-opacity: 0.4;
	filter: alpha(opacity=40);
}
}


/*==========================
	汎用に使えるボタン
==========================*/
.btn-style { text-align:left; }
.btn-style a {
    background: #6ad9c1;
    width: 200px;
    max-width: 100%;
    padding: 0.6em 1.3em;
    text-align: center;
    color: #fff;
    display: inline-block;
    text-decoration: none;
    line-height: 1.2;
    box-sizing: border-box;
    font-size: 16px;
    border-radius: 30px;
    position: relative;
    letter-spacing: 0.1em;
}
.btn-style a span{
	display:block;
	font-size:12px;
}
.btn-style a::after {
    content: '';
    position: absolute;
    top: 50%;
    margin-top: -2px;
    right: 15px;
    width: 4px;
    height: 4px;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    -webkit-transition: .3s;
    transition: .3s;
}
.btn-style a:hover:after{
	right:13px;
}
.btn-style a:hover {
	opacity: 0.7;
	-moz-opacity: 0.7;
	filter: alpha(opacity=70);
 	cursor:pointer;
}


/*==========================
	　TOP コンテンツ
==========================*/

.page-name-invisalign .mainblock a {
	text-decoration:none;
}
.page-name-invisalign .mainblock a:hover {
}

/*見出し*/
.page-name-invisalign h2{
	font-size: 30px;
    color: #333;
    text-align: center;
    line-height: 1.4;
    letter-spacing: 0.2em;
    font-weight: bold;
        font-family: "Hiragino Mincho ProN", "Hiragino Mincho Pro","游明朝", YuMincho,  "ＭＳ 明朝", serif;
    margin-bottom: 4%;
}
span.h2_line{
    display: inline-block;
    border-bottom: 1px solid #6ad9c1;
    padding-bottom: 10px;
}
h2 .sub {
    text-align: center;
    display: block;
    font-size: 16px;
    color: #6ad9c1;
    margin-top: 12px;
    font-weight: bold;
    letter-spacing: 0.15em;
}

/*-- ボックスその他 --------------*/
.i01 {
    background: url(img/i01_bg02.jpg) no-repeat center /cover;
        padding-bottom: 3%;
}
.i01 .bg {
    background: url(img/i01_bg01.png) no-repeat center bottom;
    padding: 5% 0;
}
.i01 h2 {
    margin-bottom: 6%;
}
.i01 .h3_wrap {
    display: table;
    margin: 8% auto 0;
}
.i01 h3 {
    font-size: 55px;
        font-weight: bold;
        line-height: 1.3;
}
.i01 h4 {
    font-size: 18px;
    background: #8dd6f2;
    border-radius: 30px;
    padding: 0 1em;
    width: 410px;
    max-width: 90%;
    margin-left: 10px;
    color: #fff;
    text-align: center;
    box-sizing: border-box;
}
.i01 p.p01 {
    font-size: 20px;
    line-height: 1.8;
    text-align: center;
}

.i02{
    background: #fcfaf5;
    padding:4% 0;
}
.i02 .col_img{
    position: relative;
    z-index: 1;
}
.i02 .col_text {
    box-sizing: border-box;
    position: relative;
    z-index: 0;
    margin-bottom: 8%;
    margin-top: 10%;
}
.i02 .col_text:after{
    content: "";
    width: 1230px;
    height: 100%;
    padding: 10% 0 8%;
    background: #c2f3e7;
    position: absolute;
    left: -26%;
    top: -24%;
    z-index: -1;
}

.i02 .bg02 .col_text:after{
 left:auto;
    right: -24%;
}
.i02 h3{
    font-size:36px;
    line-height: 1.3;
    background: url(img/i02_01.png) no-repeat left center;
        padding: 7% 0;
    text-align: left;
    margin-bottom: 3%;
    letter-spacing: 0;
}
.i02 .bg02 h3{
    background-image: url(img/i02_02.png) ;
}
.i02 .bg03 h3{
    background-image: url(img/i02_03.png) ;
}

.i03{
    padding:4% 0 3%;
}

.i03 .column{
    box-sizing: border-box;
    background: #e1faf4;
        margin-bottom: 5%;
}
.i03 .column:nth-of-type(even){
    background: #f2fcfa;
}
.i03 h3{
font-size: 22px;
    color: #13876d;
    padding: 0 2%;
    box-sizing: border-box;
    line-height: 1.3;
    letter-spacing: 0.1em;
    margin: 9% auto 7%;
}
.i03 p{
    padding: 0 7%;
    box-sizing: border-box;
}

.i04{
    padding:4% 0;
    background: url(img/i04_bg.png);
}
.i04 p.ttl {
    font-size: 38px;
    color: #fff;
    font-weight: bold;
    font-family: "Hiragino Mincho ProN", "Hiragino Mincho Pro","游明朝", YuMincho, "ＭＳ 明朝", serif;
    background: #6ad9c1;
    border-radius: 50px;
    display: table;
    margin: 0 auto 5%;
    line-height: 1.3;
    padding: 14px 20px;
    letter-spacing: 0.2em;
    max-width: 700px;
    width: 100%;
    text-align: center;
}
.i04 p.ttl .big {
    font-size: 48px;
    color: #feff9a;
}
.i04 .border-table {
    margin-top: 4%;
        margin-bottom: 7%;
}
.border-table th, .border-table td {
    font-weight: normal;
    padding: 16px 5px;
    border: 1px solid #d2e0dd;
    vertical-align: middle;
    font-size:18px;
}
.border-table thead th {
    background: #6ad9c1;
    color: #fff;
    text-align: center;
    font-size: 24px;
    font-weight: bold;
    font-family: "Hiragino Mincho ProN", "Hiragino Mincho Pro","游明朝", YuMincho, "ＭＳ 明朝", serif;
}
.border-table tbody th {
    vertical-align: middle;
    background: #e1faf4;
    text-align: center;
}
.border-table tbody td{
    background: #fff;
    text-align: center;
        padding: 27px 5px 16px;
}
.border-table tbody td .big {
    font-size: 36px;
}
.i04 p.p01{
    font-size:20px;
    margin-bottom: 6px;
}
.color02 {
    color: #eb354e;
}
.i04 h3 {
    font-size: 36px;
    text-align: left;
    line-height: 1.3;
    margin-bottom: 1.5%;
        margin-top: 2%;
}
.i04 .text_no {
    flex: 0 0 120px;
}
.i04 .text-box {
    flex: auto;
}
.i04 .text-wrap {
    margin-top: 4%;
}

.i05{
    padding:4% 0;
}
.i05 .qa-block h4{
    background: url(img/i05_bg.png);
    color:#fff;
    font-size:24px;
    font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro","メイリオ", Meiryo,  "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
        padding: 1em 60px 1em 80px!important;
}
.i05 .qa-block h4:before{
    content: "";
    width:60px;
    height: 60px;
    background: url(img/i05_q.png) no-repeat center /contain;
    position: absolute;
        left: 10px;
    top: 13px;
    border-radius: 0;
    display: block;
}
.qa-block {
    margin-bottom: 4%;
    padding-top: 0;
    border-bottom: 1px solid #adadad;
    position: relative;
    border: none;
}
.qa-block .answer {
    padding:40px 20px 1.5em 80px!important;
    position: relative;
    margin-top: 0;
    background: #f2fcfa;
}
.qa-block .answer:before{
    content: "";
    width:60px;
    height: 60px;
    background: url(img/i05_a.png) no-repeat center /contain;
    position: absolute;
        left: 10px;
    top: 19px;
    border-radius: 0;
}
.qa-block .answer:after{
    display: none;
}
.i05 p.p01 {
    font-size: 24px;
    color: #3da48d;
    padding-bottom: 16px;
}
.qa-block:before, .qa-block:after {
    position: absolute;
    content: '';
    top: 37px;
    right: 29px;
    background: #3da48d;
    border-radius: 0;
    width: 12px;
    height: 2px;
        z-index: 1;
}
.qa-block::after {
  transform: rotate(90deg);
  transition: .3s;
}
.qa-block.open::after {
  transform: rotate(0);
}
.i05 .qa-block h4:after {
content: "";
    width: 30px;
    height: 30px;
    background: #fff;
    border-radius: 50%;
    position: absolute;
    right: 20px;
    top: 23px;
    display: block;
    left: auto;
}
.i05 .qa-block h4:hover {
    opacity: 0.8;
}
/********************************
	Responsive
*********************************/

@media screen and (min-width: 768px) {/* タブレットまで */

/*================================
	mainimage　が一枚画像の場合
================================*/
.mainimage{
        background: url(img/i_mainimage.jpg) no-repeat center / cover;
    height: 760px;
    margin-top: 10px;
}

/*==========================
	　TOP コンテンツ
==========================*/
/*-- FLEX設定 --------------*/
.columns {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    justify-content: space-between;
}
.col_wrap{ /*改行して組む場合*/
	flex-wrap: wrap;
	-ms-flex-wrap: wrap; /*IE10*/
	-webkit-flex-wrap: wrap; /* Safari6.1以降 */
}
.columns.reverse{ /*左右反転*/
-webkit-box-direction:reverse;
    -moz-box-direction:reverse;
    -webkit-box-orient:horizontal;
    -moz-box-orient:horizontal;
    -webkit-flex-direction:row-reverse;
    -moz-flex-direction:row-reverse;
    flex-direction:row-reverse;
}
.columns > .column {
    box-sizing: border-box;
    max-width: 47%;
    -webkit-box-flex-basis: 47%;
    -webkit-flex-basis: 47%;
    flex-basis:  47%;
}
.columns.col3{
    -webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}
.columns.col3 > .column {
    max-width: 30%;
    -webkit-box-flex-basis: 30%;
    -webkit-flex-basis: 30%;
    flex-basis: 30%;
    margin-right: 5%;
}
.columns.col3 > .column:nth-of-type(3n){
        margin-right:0;
}
    .columns.col4{
    -webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}
.columns.col4 > .column {
    max-width: 23.5%;
    -webkit-box-flex-basis: 23.5%;
    -webkit-flex-basis:23.5%;
    flex-basis:23.5%;
    margin-right: 2%;
}
.columns.col4 > .column:nth-of-type(4n){
        margin-right:0;
}
        .columns.col5{
    -webkit-box-pack: start;
	-ms-flex-pack: start;
	justify-content: flex-start;
}
.columns.col5 > .column {
    max-width: 17.6%;
    -webkit-box-flex-basis: 17.6%;
    -webkit-flex-basis:17.6%;
    flex-basis:17.6%;
    margin-right: 3%;
}
.columns.col5 > .column:nth-of-type(5n){
        margin-right:0;
}
.col_align{
    -webkit-align-items: center;
 	-ms-align-items    : center;
	align-items        : center;
    }
/*-- ボックスその他 --------------*/
.i02 .col_img {
    flex: 0 1 40.1%;
}
    .i02 .col_text {
    flex: 0 1 58%;
}
}

@media screen and (min-width: 768px)  and (max-width: 1280px) {/* 程よいブラウザサイズでメインイメージを縮小 */
.mainimage {
    height: 480px;
}
}
@media screen and (min-width: 768px)  and (max-width: 1041px) {
.i03 h3 {
    font-size: 20px;
    padding: 0;
    letter-spacing: -1px;
    }
}

@media screen and (max-width: 1041px) {/*コンテンツが横幅いっぱいになったら*/
    .i01 h3 {
    font-size: 47px;
    }
    .i02 h3 {
    font-size: 26px;
    background-size: contain;
    }
}

@media screen and (max-width: 767px) {/* スマホ */

.topinner {
	width:420px;
	margin:0 auto;
	box-sizing:border-box;
}
.page-name-invisalign #contents,
.page-name-invisalign #aside{
	margin-bottom:0;
}
/*==========================
	　mainimage
==========================*/
.mainimage, .slider {
    margin-bottom: 0;
}
.mainimage img {
    height: auto;
    max-width: none;
    max-height: none;
    width: 100%;
        vertical-align: bottom;
}
/*==========================
	ボタン
==========================*/


/*==========================
	　TOP コンテンツ
==========================*/
.sp-columns {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    justify-content: space-between;
	flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	-webkit-flex-wrap: wrap;
}
.sp-columns .column {
    box-sizing: border-box;
    max-width: 49%;
    -webkit-box-flex-basis: 49%;
    -webkit-flex-basis: 49%;
    flex-basis: 49%;
        margin-bottom: 2%;
}    
/*-- 余白・背景 --------------*/

/*-- 見出し --------------*/
    .page-name-invisalign h2 {
    font-size: 26px;
    }
/*-- ボックスその他 --------------*/
    .i01 .bg {
    padding: 8% 0;
}
    .i01 .h3_wrap {
    display: block;
    }
    .i01 h3 {
    font-size: 32px;
    }
    .i02 .col_text {
    margin-top: 5px;
}
    .i02 .col_text:after {
    padding: 24% 0 1%;
    }
    .i03 .column {
    padding-bottom: 1px;
}
    .i04 p.ttl {
    font-size: 21px;
    padding: 14px 5px;
    letter-spacing: 0;
    box-sizing: border-box;
}
    .i04 p.ttl .big {
    font-size: 27px;
}
    .border-table th, .border-table td {
    padding: 16px 2px;
    font-size: 16px;
}
    .border-table thead th {
    font-size: 16px;
    }
    .border-table tbody td .big {
    font-size: 28px;
}
    .i04 .text-wrap {
        display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: -moz-flex;
    display: flex;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    justify-content: space-between;
    }
    .i04 .text_no {
    flex: 0 0 24%;
    margin-right: 10px;
}
    .i04 h3 {
    font-size: 27px;
    letter-spacing: 0;
    }
    .i05 .qa-block h4:before {
    width: 40px;
    height: 40px;
}
    .i05 .qa-block h4 {
    font-size: 20px;
    padding: 0.8em 43px 0.8em 58px!important;
}
    .qa-block .answer {
    padding: 25px 15px 10px 60px!important;
    margin: 0;
}
    .qa-block .answer:before {
    width: 40px;
        height: 40px;
    }
    .i05 p.p01 {
    font-size: 20px;
    }
    .i05 .qa-block h4:after {
    right: 9px;
    top: 14px;
    }
    .qa-block:before, .qa-block:after {
    top: 28px;
    right: 18px;
    }
}

@media screen and (max-width: 480px) {/* スマホ480px */
}

@media screen and (max-width: 320px) {/* スマホ320px */
}

