@charset "utf-8";
/* CSS Document */
/* =================================================================================================
 * Reset
 * =================================================================================================*/
html, body {
	margin: 0;
	padding: 0;
	font-size: 100%;
	line-height: 1.0em;
}
img {
	border: 0;
	transition: 0.1s;
	-webkit-backface-visibility:hidden;
	backface-visibility:hidden;
}
a:hover img {
	opacity: 0.7;
	filter: alpha(opacity=70);
	-ms-filter: "alpha(opacity=70)";
}
a {
	text-decoration: none;
	color: #fff;
}

.pure-drawer a {
	color: #333;
}
ol, ul {
	list-style: none;
}
p {
	line-height: 24px;
}
img, input {
	vertical-align: middle;
	width: 100%;
}
h1, h2, h3, h4, h5, h6, address {
	margin: 0;
	padding: 0;
	border: 0;
	font-style: normal;
	font-weight: normal;
	font-size: 100%;
}
div, blockquote, p, pre, ul, ol, li, dl, dt, dd {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
}
.main_box {
    overflow: hidden;
}
span.anchorlink {
	position: relative;
	top: -120px;
	display: block;
}
/* =================================================================================================
 * common
 * =================================================================================================*/
body {
    font-family: 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック',Helvetica,Arial,sans-serif;
    font-size: 14px;
    color: #000;
    letter-spacing: 1px;
}
.wrapper {
	overflow: hidden;
}
hr {
	border: solid 1px #000;
	margin: 0;
}
.button {
	display: inline-block;
	max-width: 184px;
	height: 44px;
	text-align: center;
	text-decoration: none;
	line-height: 44px;
	outline: none;
	width: 100%;
}
.button::before,
.button::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
.button,
.button::before,
.button::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
}
.button {
	background-color: rgba(255, 255, 255, 0.5);
	border: 1px solid #000;
	color: #000;
	line-height: 44px;
	font-family: 'Playfair Display', "sawarabi mincho", serif;
}
.button_b {
	background-color: rgba(0, 0, 0, 0.5);
	border: 1px solid #fff;
	color: #fff;
}
.button:hover {
	border-style: dashed;
}


.button01 {
	display: inline-block;
	width: 184px;
	height: 44px;
	text-align: center;
	text-decoration: none;
	outline: none;
	position: relative;
	/*z-index: 1;*/
	border: 2px solid #fff;
	color: #fff;
	line-height: 40px;
	-webkit-perspective: 300px;
	perspective: 300px;
	-webkit-transform-style: preserve-3d;
	transform-style: preserve-3d;
}
.button01:hover {
	color: #fff;/*#b44a66*/
	font-weight: bold;
	letter-spacing: 3px;
}
.button01::before,
.button01::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
.button01,
.button01::before,
.button01::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
}
.button01::after {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(255,255,255,0.8);
	-webkit-transform-origin: center top;
	transform-origin: center top;
	-webkit-transform: rotateX(90deg);
	transform: rotateX(90deg);
	opacity: 0;
}
.button01:hover::after {
	-webkit-transform: rotateX(0);
	transform: rotateX(0);
	opacity: 1;
}
.display_tb,
.display_pc{
	display: none;
}
.display_sp{
	display: block;
}
/* =================================================================================================
 * drawer
 * =================================================================================================*/
.drawer{
	position: fixed;
	z-index: 50;
}
.pure-drawer ul {
	margin-top:15px;
} 
.pure-drawer li {
	font-size: 16px;
    padding: 8px 0;
    text-align: center;
    z-index: 2;
	border-bottom: 1px dashed #555;
}
.drawer_icon {
	width: 180px;
	margin: 20px auto 0;
	overflow: hidden;
}
.drawer_icon ul {
	margin: 12px 0 0;
}
.drawer_icon li {
	float: left;
	padding: 0 14px; 
	border-bottom: none;
}
.sp_navlogo {
	margin: 30px 0 0 15px;
}
.pure-drawer li {
	font-family: 'Playfair Display', "sawarabi mincho", serif;
}
.pure-drawer li span {
	margin-top: 10px;
	font-size: 10px;
	font-family: "Hiragino Kaku Gothic ProN","メイリオ", sans-serif;
}
/* =================================================================================================
 *  top
 * =================================================================================================*/
.top_bg_img {
  	content:"";
  	display:block;
  	position:fixed;
  	top:0;
  	left:0;
  	z-index:-1;
  	width:100%;
  	height:100%;
	background:url(../img/top/top_bg01.jpg) center/cover no-repeat;
}
.about_bg_img {
  	content:"";
  	display:block;
  	position:fixed;
  	top:0;
  	left:0;
  	z-index:-1;
  	width:100%;
  	height:100%;
	background:url(../img/bg/m_back.jpg);
}
.m_bridal .about_bg_img {
	background:url(../img/bg/m_back2.jpg);
}
.box1 {
    text-align: center;
}
.top_img{
	margin: 16px 0;
}
.top_img img{
	width: 100%;
}
#box1:after {
    background-attachment: fixed;
    background-repeat: no-repeat;
    background-size: 0% auto;
    content: "";
    display: block;
    height: 630px;
}
.top_box {
	width: 100%;
    height: 500px;	
	position: absolute;
	top: 95px;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	background: url(../img/top/logo_1.png)no-repeat;
	background-position: 50% 0%;
	background-size: 100%;
}
.top_logo {
	width: 60%;
	/*margin: 0 0 0 40%;*/
}
.top_logo img {
	width: 100%;
}
.top_btn{
    margin: 32px auto 0;
}
.top_contact{
	margin-top: 16px;
}
p.campaign_headline {
	position: absolute;
	top: 70%;
	text-align: center;
	display: block;
	width: 100%;
	font-weight: bold;
	line-height: 5rem;
}
p.campaign_headline span {
	border-top: 1px solid;
	padding: 1rem;
	border-bottom: 1px solid;
	color: #8a6326;
	font-family: "sawarabi mincho",serif;
	font-size: 13px;
}
/*------------------------
【Period2】　start
---------------------------*/
.top_box dl {
	position: absolute;
	right: 0;
}
.top_box dt {
	font-size: 3.5rem;
	padding: 17rem 1rem 2rem 0rem;
	font-family: Allura, cursive, "sawarabi mincho", serif;
	margin: 1rem auto 0;
	color: #162b6a;
	text-shadow: 1px 1px 15px #fff;
	text-align: left;
}
.top_box span {
	color: #ff3e88;
}
.top_box span:first-child {
    color: #DA8E00;
    background: -webkit-linear-gradient(-90deg, #fffde7, #fbd896, #fffdf8, #F7DE05, #ECB802, #fffbeb, #ffbe3e, #f7d595, #fff9e9, #F7DE05, #ffe37d, #ffffff);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    -webkit-text-stroke: 0.8px #9c7608;
}
.top_box ul {
	display: block;
	padding-top: 1rem;
}
.top_box li {
	font-family: "sawarabi mincho",serif;
	text-align: left;
	font-size: 1.8rem;
	padding: 0rem 0 1rem;
	color: #3a5dad;
	text-shadow: 1px 1px 15px #fff87f;
}
.top_box li:first-child {
}
.top_box li:last-child {
}
/*------------------------
【Period3】　end
---------------------------*/

.button1 {
	display: inline-block;
	width: 200px;
	height: 54px;
	text-align: center;
	text-decoration: none;
	line-height: 54px;
	outline: none;
	position: relative;
	z-index: 2;
	background-color: transparent;
	border: 2px solid #fff;
	color: #fff;
	line-height: 50px;
	overflow: hidden;
    font-weight: bold;
}
.button1:hover {
	color: #fff;
	letter-spacing: 3px;
}
.button1::before,
.button1::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
.button1,
.button1::before,
.button1::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
	-webkit-transition: all .3s;
	transition: all .3s;
}
.button1::after {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	-webkit-transform: scale(.5);
	transform: scale(.5);
}
.button1:hover::after {
	background: rgba(255,255,255,0.8);
	-webkit-transform: scale(1);
	transform: scale(1);
}

.scr_box {
	height: 255px;
    overflow: scroll;
	overflow-x: hidden;
}
/*スクロールバー表示させる*/
.scr_box::-webkit-scrollbar{ 
    width: 10px;
}
.scr_box::-webkit-scrollbar-thumb{ 
    background: rgba(39, 87, 129, 0.8);
    border-radius: 10px;
}
.scr_box::-webkit-scrollbar-track-piece:start{
    background: #ddd;
}
.scr_box::-webkit-scrollbar-track-piece:end{
    background: rgba(255, 255, 255, 0.6);
}
/* =================================================================================================
 * about
 * =================================================================================================*/
.about {
	background: rgba(255,255,255,0.8);
	overflow: hidden;
	margin-bottom: 200px;
	padding: 0;
}
#about {
	background: rgba(255,255,255,0.9); /* Old browsers */
	background: -moz-linear-gradient(-45deg, rgba(255,255,255,0.9) 1%, rgba(226,204,163,0.9) 14%, rgba(255,244,224,0.9) 31%, rgba(201,164,126,0.9) 52%, rgba(237,228,201,0.9) 75%, rgba(255,235,209,0.9) 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(-45deg, rgba(255,255,255,0.9) 1%,rgba(226,204,163,0.9) 14%,rgba(255,244,224,0.9) 31%,rgba(201,164,126,0.9) 52%,rgba237,228,201),0.9 75%,rgba(255,235,209,0.9) 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(135deg, rgba(255,255,255,0.9) 1%,rgba(226,204,163,0.9) 14%,rgba(255,244,224,0.9) 31%,rgba(201,164,126,0.9) 52%,rgba(237,228,201,0.9) 75%,rgba(255,235,209,0.9) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#ffebd1',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */
}
#about .menu_bg {
    background: url(../img/sp/top_about_sp.png)no-repeat top;
    background-size: 350px;
    padding-top: 205px;
}
.about_box {
	width: 310px;
	margin: 0 auto ;
}
.about_title {
	text-align: center;
	margin: 10px 0;
}
.about_title h2 {
	font-size: 30px;
	margin: 40px 0 10px;
	font-family: 'Playfair Display', "sawarabi mincho", serif;
}
.about_img {
	margin-bottom: 24px;
}
.about_img img {
	width: 100%;
}
.about_text {
	margin-bottom: 40px;
	overflow: hidden;
	font-family: "Hiragino Kaku Gothic ProN","メイリオ", sans-serif;
	font-size: 15px;
	letter-spacing: 2px;
	line-height: 30px;
}
.about_text h3 {
	font-size: 1.8rem;
	font-family: "sawarabi mincho", serif;
	text-align: center;
	padding-bottom: 0.25rem;
	border-bottom: 1px solid;
	margin-bottom: 1rem;
	margin: auto;
}
.about_text ul li {
	margin: auto;
}
.about_text ul li>i {
	color: #ca0052;
}
.about_text p {
	padding: 1rem;
}
.about_btn {
	margin: 24px 0;
	text-align: center;
}

/* =================================================================================================
 * 特別優待期間
 * =================================================================================================*/
#campaign {
	background: rgba(255, 255, 255, 0.6);
	background-size: contain;
	margin-bottom: 205px;
	padding: 0 0 2rem;
	border-top: 4px solid #e8ca7a;
	border-bottom: 4px solid #e8ca7a;
}
#campaign .p {
	color: #dd168d;
	font-weight: bold;
}
#campaign .menu_bg {
	background: url(../img/top/top_campaign.png)no-repeat;
	background-size: 100%;
	background-position: top center;
}
#campaign .menu_title {
	text-align: center;
	color: #dc0685;
	font-size: 1.8rem;
	margin: 0;
	padding: 22rem 0 2rem;
}
#campaign .menu_title h2 {
	border-bottom: 1px solid;
	max-width: 390px;
	margin: 0.5rem 0 1rem auto;
	text-align: center;
	padding-bottom: 2rem;
}
#campaign .menu_title h2 span {
	font-size: 1.5rem;
	line-height: 4rem;
	color: #dc0685;
	font-weight: bold;
	display: block;
}
#campaign .serif {
	font-family: "sawarabi mincho",serif;
}
#campaign .b {
	font-weight: bold;
}
#campaign .menu_text {
    width: 100%;
}
#campaign .menu_text .button {
	font-size: 1.3rem;
}
#campaign .flex li {
	border: 4px double #ffbd53;
	margin: 1rem 0.5rem 3rem;
	padding: 2rem 1rem;
	background: rgba(255, 255, 255, 0.3);
}
#campaign dt {
	font-family: "sawarabi mincho",serif;
	text-align: center;
	font-size: 1.8rem;
	line-height: 2.5rem;
	font-weight: bold;
	color: #8a6326;
}
#campaign .flex dt {
	border-bottom: 1px solid #000;
	padding-top: 1rem;
	padding-bottom: 2rem;
	min-height: 6rem;
	margin-bottom: 2rem;
	padding: 1rem 0.5rem;
}
#campaign .flex dd p {
	text-align: center;
}
#campaign .flex dd:last-child {
	text-align: center;
	font-family: "sawarabi mincho",serif;
	padding: 0.5rem 0;
	color: #dc0685;
}
#campaign .flex dd:last-child span {
	display: block;
	font-weight: bold;
	text-align: center;
}
#campaign .button {
	margin: 1rem auto;
	display: block;
}
#campaign .flex_tab2 li:first-child dt {
	padding: 0;
}
#campaign .te_center{
	text-align: center;
}
/* =================================================================================================
 * 水素メニュー
 * =================================================================================================*/
#hydrogen {
	background: url(../img/sp/top_hydrogen_sp.png)no-repeat top rgba(39, 87, 129, 0.6);
	background-size: 350px;
	padding-top: 205px;
}
#hydrogen {
	color: #fff;
}
#hydrogen .about_title h2 {
	font-size: 22px;
}
#hydrogen .about_text dt h3 {
	font-size: 2.2rem;
	color: #ff91d2;
}
#hydrogen .about_btn {
    margin: 2rem 0 5rem;
}

/* =================================================================================================
 * 整骨メニュー
 * =================================================================================================*/
#ostracy{
	text-align: center;
	padding: 0;
	background: rgba(255,255,255,0.9);
	background: -moz-linear-gradient(-45deg, rgba(255,255,255,0.9) 1%, rgba(226,204,163,0.9) 14%, rgba(255,244,224,0.9) 31%, rgba(201,164,126,0.9) 52%, rgba(237,228,201,0.9) 75%, rgba(255,235,209,0.9) 100%);
	background: -webkit-linear-gradient(-45deg, rgba(255,255,255,0.9) 1%,rgba(226,204,163,0.9) 14%,rgba(255,244,224,0.9) 31%,rgba(201,164,126,0.9) 52%,rgba237,228,201),0.9 75%,rgba(255,235,209,0.9) 100%);
	background: linear-gradient(135deg, rgba(255,255,255,0.9) 1%,rgba(226,204,163,0.9) 14%,rgba(255,244,224,0.9) 31%,rgba(201,164,126,0.9) 52%,rgba(237,228,201,0.9) 75%,rgba(255,235,209,0.9) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#ffebd1',GradientType=1 );
}
#ostracy div>div.about_box {
	max-width: 750px;
	background: rgba(248, 238, 219, 0.7);
	padding: 1px 0;
}
#ostracy .menu_bg {
	background: url(../img/top/ostracy_bg.png)no-repeat;
	background-size: cover;
	background-position: center;
	padding: 40px 0;
}
#ostracy dd>p:first-child{
	font-size: 2rem;
	color: #7d0b0b;
	font-family: "sawarabi mincho",serif;
}
#ostracy dd>p.about_btn {
    margin-top: 10px;
}

/* =================================================================================================
 * トータルメニュー
 * =================================================================================================*/
.menu {
	background: rgba(255, 255, 255, 0.8);
	overflow: hidden;
	margin-bottom: 150px;   
}
.menu_box {
	width: 310px;
	margin: 0 auto;
	color: #000;
}
.menu_title {
	text-align: center;
	margin: 24px 0;
	font-family: 'Playfair Display', "sawarabi mincho", serif;
}
.menu_title h2 {
	font-size: 30px;
	margin: 40px 0 24px;
	color: #000;
}
.menu_img {
	margin-bottom: 24px; 
}
.menu_img img {
	width: 100%;
}
.menu_text {
	margin-bottom: 40px;
	overflow: hidden;
	color: #000;
}
.menu_text p, .about_text p {
	font-size: 15px;
	font-family: "Hiragino Kaku Gothic ProN","メイリオ", sans-serif;
	letter-spacing: 2px;
}
.menu_btn {
	margin: 24px 0;
	text-align: center;
}
#menu li {
	width: 300px;
	height: 300px;
	float: left;
	margin: 0 0 7% 3%;
	overflow: hidden;
	position: relative;
}
#menu li img {
	width: 100%;
}
.mask_caption {
	font-size:	160%;
	text-align: center;
	padding-top: 140px;
	color: #333;
	font-family: 'Playfair Display';
}
.menu_hover .mask {
	width: 300px;
	height: 300px;
	-webkit-border-radius: 150px;/* width,heightの半分 */
	-moz-border-radius: 150px;
	border-radius: 150px;
	position: absolute;
	top: 0;
	left: 0;
	opacity: 0;
	background-color: rgba(255,255,255,0.6);
	-webkit-transition: all 0.2s ease;
	transition:	all 0.2s ease;
}
.menu_hover:hover .mask {
	opacity: 1;
}

/* =================================================================================================
 * total
 * =================================================================================================*/
#total {
	background: url(../img/sp/top_menu_sp.png)no-repeat top rgba(255, 255, 255, 0.6);
	background: url(../img/sp/top_menu_sp.png)no-repeat top rgba(255, 255, 255, 0.6);
	background-size: contain;
	padding-top: 205px;
}
#total .about_box {
	padding: 3rem 0;
}
#total .about_text, #total .about_title {
	width: 95%;
	margin: auto;
	text-align: center;
}
#total ul {
    /*display: flex;*/
}
#total .about_text ul li{
	width: 40%;
	margin: 1rem auto 0 5rem;
}
#total .about_btn {
	margin-top: 25px;
	width: 184px;
}

/* =================================================================================================
 * foot
 * =================================================================================================*/
#foot {
	background: rgba(255,255,255,0.9);
	background: -moz-linear-gradient(-45deg, rgba(255,255,255,0.9) 1%, rgba(226,204,163,0.9) 14%, rgba(255,244,224,0.9) 31%, rgba(201,164,126,0.9) 52%, rgba(237,228,201,0.9) 75%, rgba(255,235,209,0.9) 100%);
	background: -webkit-linear-gradient(-45deg, rgba(255,255,255,0.9) 1%,rgba(226,204,163,0.9) 14%,rgba(255,244,224,0.9) 31%,rgba(201,164,126,0.9) 52%,rgba237,228,201),0.9 75%,rgba(255,235,209,0.9) 100%);
	background: linear-gradient(135deg, rgba(255,255,255,0.9) 1%,rgba(226,204,163,0.9) 14%,rgba(255,244,224,0.9) 31%,rgba(201,164,126,0.9) 52%,rgba(237,228,201,0.9) 75%,rgba(255,235,209,0.9) 100%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ffffff', endColorstr='#ffebd1',GradientType=1 );
}
#foot .menu_bg {
	background: url(../img/top/foot_bg1.png) no-repeat;
	background-position: center bottom;
	background-size: 350px;
	padding-bottom: 24rem;
}
#foot .about_text, #foot .about_title {
	width: 100%;
	margin: auto;
}
#foot .about_title h2 {
    text-align: left;
}
#foot .about_text h3{
	width: 100%;
	text-align: left;
}
#foot p {
	text-align: left;
}
#foot .about_text dd p:first-child,
#foot .about_text dd p:nth-child(3) span {
	font-size: 2rem;
	color: #11368e;
	padding-bottom: 0.5rem;
	font-family: 'sawarabi mincho';
}
#foot p:first-child span {
	font-size: 2.3rem;
	color: #dc0685;
}
#foot p:last-child span {
	color: #11368e;
	display: block;
}
#foot p:last-child span:nth-child(2){
	font-size: 1.8rem;
	padding: 0.5rem 0;
	font-family: "sawarabi mincho", serif;
	font-weight: bold;
}
#foot .about_btn {
	margin-top: 10px;
}
#foot ul{
	display: flex;
}
#foot li:last-child .about_btn .button {
	background: #6e7484;
	color: #fff;
}

/* =================================================================================================
 * MTG
 * =================================================================================================*/
.about#mtg {
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#e5d2c0+9,e5d2c0+9,fcf9ea+33,ffffff+46,fcf9ea+53,e2d6b7+78,f5f6f6+100 */
	background: #e5d2c0; /* Old browsers */
	background: -moz-linear-gradient(-45deg, #e5d2c0 9%, #e5d2c0 9%, #fcf9ea 33%, #ffffff 46%, #fcf9ea 53%, #e2d6b7 78%, #f5f6f6 100%); /* FF3.6-15 */
	background: -webkit-linear-gradient(-45deg, #e5d2c0 9%,#e5d2c0 9%,#fcf9ea 33%,#ffffff 46%,#fcf9ea 53%,#e2d6b7 78%,#f5f6f6 100%); /* Chrome10-25,Safari5.1-6 */
	background: linear-gradient(135deg, #e5d2c0 9%,#e5d2c0 9%,#fcf9ea 33%,#ffffff 46%,#fcf9ea 53%,#e2d6b7 78%,#f5f6f6 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#e5d2c0', endColorstr='#f5f6f6',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */
	padding: 0;
}
#mtg .menu_bg {
	background: url(../img/sp/top_mtg_sp.png)no-repeat top;
	background-size: 350px;
	padding-top: 205px;
}
#mtg .about_text dt h3 {
	text-shadow: white 1px 1px 2px, white -1px 1px 1px, white 1px -1px 2px, white -1px -1px 2px;
}
#mtg .about_text ul {
    display: block;
	background: #fff;
	padding: 0.5rem;
}
#mtg .about_text ul li {
    width: 95%;
	margin: auto;
}
#mtg .about_text p {
	text-align: center;
	text-shadow: white 1px 1px 2px, white -1px 1px 1px, white 1px -1px 2px, white -1px -1px 2px;
}
#mtg dd p:nth-child(4) {
	font-size: 1.8rem;
	font-weight: bold;
	font-family: "sawarabi mincho";
	color: #d1015f;
	padding-top: 3rem;
}
#mtg .about_btn {
    margin-top: 10px;
}

/* =================================================================================================
 * news
 * =================================================================================================*/
.news01 {
	background: rgba(255, 255, 255, 0.5);
	overflow: hidden;
	margin-bottom: 200px;
}
.news01 h2{
	color: #000 !important;
}
.news {
  background:url(../img/bg/company.jpg) ; /*fixedをトル！*/	
	  filter: 				alpha(opacity=90);
    -moz-opacity:			0.9;
    opacity:				0.9;
    width: 100%;

	/*background: rgba(255,255,255,0.8);*/
	overflow: hidden;
	margin-bottom: 200px;
}
.news_box {
	width: 320px;
	margin: 0 auto 40px;
}
.news_title {
	text-align: center;
	margin: 24px 0;
	font-family: 'Playfair Display', "sawarabi mincho", serif;
}
#news_box .news_title h2 {
	font-size: 30px;
	margin: 40px 0 24px;
	color: #fff;
}
#menu .news_title {
	color: #333;
	font-size: 30px;
}
.news_main{
	margin: 0 auto; 
	height: 180px;
	margin-bottom: 50px;
	overflow: hidden;
}
.news_main a {
	color: #fff;
}
.news_main li{
	line-height: 24px;
	font-size: 12px;
	border-top: dotted 1px #fff;
}
/* =================================================================================================
 * Company
 * =================================================================================================*/
.company_text p {
	font-size: 14px;
	line-height: 30px;
	text-align: center;
	color: #fff;
}
/* =================================================================================================
 * contact
 * =================================================================================================*/
.contact {
	background: rgba(255,255,255,0.8);
	overflow: hidden;
	margin-bottom: 200px; 
}
.contact_box {
	width: 100%;
	margin: 0 auto;
}
.contact_box .menu_title h2 {
	text-align: center;
	color: #000;
}
.contact_form{
	overflow: hidden;
}
.contact_btn {
	margin: 24px 0 40px;
	text-align: center;
}
.contact_btn input {
	font-family: 'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro W3','メイリオ',Meiryo,'ＭＳ Ｐゴシック',Helvetica,Arial,sans-serif;
	font-size: 14px;
  letter-spacing: 1px;
	background: transparent;
	border: none;
	z-index: 4;
	width: 180px;
	height: 40px;
	text-align: center;
}
/* =================================================================================================
 * access
 * =================================================================================================*/
div#access_box .menu_box {
    color: #000;
}
#access_box table {
	display: block;
	width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
}
#access_box table caption {
	font-family: 'Playfair Display','Noto Serif JP', serif;
	font-size: 15px;
	text-align: left;
	display: block;
	width: 100%;
	padding: 1.8rem 1rem 0.5rem;
	font-weight: bold;
	line-height: 2rem;
}
#access_box table caption span {
	font-size: 23px;
}
#access_box table::after,
#access_box table caption::after {
	position: relative;
	content: "";
	display: block;
	height: 3px;
	width: 100%;
	top: 3px;
	background: -webkit-gradient(linear, left center, right center, from(#093d82), to(#ffffff));
	background: -moz-linear-gradient(left, #093d82, #ffffff);
	background: linear-gradient(left, #093d82, #ffffff);
}
#access_box table::after {
	top: 0;
}
#access_box table tr {
	border-bottom: 1px solid #dcdcdc;
}
#access_box table tr:last-child,
#access_box table td:last-child {
	/*border: none;*/
}
#access_box table th,
#access_box table td {
	padding: 15px;
}
#access_box table th {
	vertical-align: top;
	min-width: 100px;
	text-align: left;
	font-weight: normal;
}
#access_box table td {
	width: 100%;
	border-left: 1px dotted #dcdcdc;
	padding-left: 1rem;
	line-height: 2rem;
}
#access_box table td a {
	color: #134588;
	transition: 0.2s;
}
#access_box table td a:hover {
	color: #aaa;
}
/* =================================================================================================
 * インスタ
 * =================================================================================================*/
#insta {
	margin-top: -100px;
	padding-top: 75px;
}
#insta h2 {
	margin-bottom: 50px;
}

/* =================================================================================================
 *  iv
 * =================================================================================================*/
.iv{
	height:300px;
}
@media screen and (min-width:360px){
/* =================================================================================================
 *  top
 * =================================================================================================*/
	.top_bg_img {
	  content:"";
	  display:block;
	  position:fixed;
	  top:0;
	  left:0;
	  z-index:-1;
	  width:100%;
	  height:100vh;
	  background:url(../img/top/top_bg01.jpg) center/cover no-repeat;
	}
/* =================================================================================================
 *  menu
 * =================================================================================================*/
	#menu li {
		width: 200px;
		height: 200px;
		margin: 0 auto 6%;
		float: none;
	}
	.mask_caption {
		font-size:	130%;
		padding-top: 90px;
	}
	.menu_hover .mask {
		width: 200px;
		height: 200px;
		-webkit-border-radius: 45px;/* width,heightの半分 */
		-moz-border-radius: 75px;
		border-radius: 75px;
	}
}

@media screen and (min-width:450px){
	#campaign .menu_title {
		padding-top: 29rem;
	}
}
@media screen and (min-width:600px){
	.menu_bg{
		display: inline-block;
		width: 100%;
		height: 100%;
	}
	
/* =================================================================================================
 * campaign_headline
 * =================================================================================================*/
	p.campaign_headline {
		top: 600px;
	}
	p.campaign_headline span {
		font-size: 1.5rem;
	}
	@media screen and (orientation: portrait) {
		p.campaign_headline {
			top: 80vh;
		}
	}
/* =================================================================================================
 *  top
 * =================================================================================================*/
	#box1:after {
	    height: 1000px;
	}
	.top_box {
		width: 600px;
		top: 5%;
		background-size: auto;
	}
	.top_tel {
		display: inline-block;
	}
	.top_contact {
		display: inline-block;
		margin: 0 0 0 60px;	
	}
	.top_img{
		width: 465px;
		margin: 24px auto;
	}
	.top_box .top_logo {
		width: 100%;
		display: inline-block;
	}
	.top_logo h1 {
		width: 750px;
		float: right;
	}
	.top_box dt {
		font-size: 5.5rem;
		padding: 34rem 1rem 2rem 0rem;
	}
	.top_box li {
		font-size: 2.5rem;
		padding: 1rem 0 2rem;
	}
/* =================================================================================================
 * about
 * =================================================================================================*/
	
	.about_text h3 {
		font-size: 2rem;
		width: 60%;
	}
	#about .menu_bg {
		background: url(../img/top/sec1_about.png) no-repeat;
		background-size: auto;
		padding-top: 0;
		background-position: 50% 100%;
	}
	.about_box {
		width: 580px;
	}
	
	#about .menu_box {
		width: 50%;
		margin: 0 auto 0 10px;
	}

/* =================================================================================================
 * campaign
 * =================================================================================================*/
	#campaign .menu_bg {
		background: unset;
		background-size: unset;
		background-position: unset;
	}
	#campaign .menu_title {
		background: url(../img/top/top_campaign.png)no-repeat;
		background-size: 490px;
		background-position: top left;
		padding: 26rem 9rem 4rem;
		text-align: right;
	}
/* =================================================================================================
 * 水素メニュー
 * =================================================================================================*/
	#hydrogen {
		background: url(../img/top/sec3_h.png) no-repeat rgba(39, 87, 129, 0.6);
		padding-top: 10px;
		background-position: 56% 100%;
	}
	#hydrogen .about_title, #hydrogen .about_text {
		width: 50%;
		margin: auto 0 auto auto;
	}
/* =================================================================================================
 * menu
 * =================================================================================================*/
	.menu_box {
		width: 580px;
	}
	#menu li {
		width: 90px;
		height: 90px;
		margin: 0 0 6% 13%;
		float: left;
	}
	.mask_caption {
		font-size:	100%;
		padding-top: 35px;
	}
	.menu_hover .mask {
		width: 90px;
		height: 90px;
		-webkit-border-radius: 45px;/* width,heightの半分 */
		-moz-border-radius: 75px;
		border-radius: 75px;
	}
	
/* =================================================================================================
 * 整骨
 * =================================================================================================*/
	#ostracy .menu_bg {
		background: url(../img/top/ostracy_bg.png)no-repeat;
		background-size: contain;
		background-position: -12% 20%;
	}	
/* =================================================================================================
 * トータル
 * =================================================================================================*/
	#total .about_text, #total .about_title {
		width: 50%;
		margin: auto auto auto 0;
		text-align: left;
	}
	#total .about_text ul li {
		margin: auto auto auto 0;
	}
/* =================================================================================================
 * foot
 * =================================================================================================*/
	#foot .about_text, #foot .about_title {
		margin: 0 0 0 auto;
	}
/* =================================================================================================
 * mtg
 * =================================================================================================*/
	#mtg .menu_bg {
		background: url(../img/top/sec2_mtg.png) no-repeat 68% 0/cover,
					url(../img/top/sec2_mtg2.png) no-repeat 75% 0/cover;
		padding-top: 0;
	}
/* =================================================================================================
 * news
 * =================================================================================================*/
	.news_box{
		width: 580px; 
		margin-bottom: 40px; 
	}
	.news_main{
		margin: 0 auto; 
		color: #fff;
	}
	.news_main dt{
		width: 90px;
		float: left;
		margin-right: 40px;
		font-size: 14px;
		line-height: 40px;
	}
	.news_main dd{
		border-top: none;
		font-size: 14px;
		line-height: 40px;
	}
/* =================================================================================================
 * gallery
 * =================================================================================================*/
	.gallery_box {
		width: 580px;
	}
/* =================================================================================================
 * access
 * =================================================================================================*/
	#map {
		width: 49.9%;
		height: 300px;
		float: left;
		margin: 0 0 24px;
	}
	#iv {
		width: 49.9%;
		height: 300px;
		float: right;
		margin: 0 0 24px;
	}
	.access_info {
		width: 580px;
	}
	.access_address {
		float: left;
		width: 50%;
		margin-bottom: 0;   
	}
	.access_tel {
		float: right;
		width: 50%; 
	}
}
@media screen and (min-width:768px){
	.display_sp,
	.display_pc{
		display: none;
	}
	.display_tb{
		display: block;
	}
	.scr_box {
		height: 168px;
	}
	.nav_box .float_l{
		float: left;
	}

	/* =================================================================================================
	 * width
	 * =================================================================================================*/
	.w1 {
		width: 8.3333%
	}
	.w2 {
		width: 16.6666%
	}
	.w3 {
		width: 25%
	}
	.w4 {
		width: 33.3333%
	}
	.w5 {
		width: 41.6666%
	}
	.w6 {
		width: 50%
	}
	.w7 {
		width: 58.3333%
	}
	.w8 {
		width: 66.6666%
	}
	.w9 {
		width: 75%
	}
	.w10 {
		width: 83.333%
	}
	.w11 {
		width: 91.6666%
	}
	.w12 {
		width: 100%
	}
/* =================================================================================================
 * about
 * =================================================================================================*/
	.about_box{
		width: 748px;
	}
	.about_img {
		float: left;
		width: 45%;
	}
	.about_text {
		/*float: right;
		width: 45%;
		*/
	}
	.about_title {
		text-align: center;
	}
	#about .menu_box {
    	width: 748px;
    	margin: auto;
	}
/* =================================================================================================
 * campaign
 * =================================================================================================*/
	
	#campaign .flex {
		display: flex;
		width: 100%;
	}
	#campaign .menu_title {
		padding: 9rem 0;
	}
	#campaign .flex li {
		margin: 0.5rem;
	}
	#campaign .flex_tab,
	#campaign .flex_tab2 {
		display: flex;
	}
	#campaign .flex_tab li ,
	#campaign .flex_tab2 li {
		width: 50%;
	}
	#campaign .flex_tab2 li:first-child dd,
	#campaign .flex_tab2 li:last-child dd {
		padding-top: 3.5rem;
	}
	#campaign .flex dd:nth-child(2) {
		min-height: 5rem;
	}
/* =================================================================================================
 * menu
 * =================================================================================================*/
	.menu_box {
		width: 748px;
	} 
	.menu_title {
		text-align: left; 
	}
	.menu_img {
		float: right;
		width: 50%;
	}
	.menu_img iframe {
		min-height: 340px;
	}
	.menu_text {
		float: left;
		width: 47%;
	}
	#menu li {
		width: 150px;
		height: 150px;
		margin: 0 0 3% 10%;
	}
	.mask_caption {
		font-size:	120%;
		padding-top: 70px;
	}
	.menu_hover .mask {
		width: 150px;
		height: 150px;
		-webkit-border-radius: 75px;/* width,heightの半分 */
		-moz-border-radius: 75px;
		border-radius: 75px;
	}
	/* =================================================================================================
 * foot
 * =================================================================================================*/
	#foot .menu_bg {
		background-position: 0 100%;
		background-size: 350px;
		padding-bottom: 0;
	}
	#foot .about_text, #foot .about_title {
		width: 70%;
		margin: 0 0 0 auto;
	}
	#foot .scr_box {
		height: 157px;
	}
/* =================================================================================================
 * MTG
 * =================================================================================================*/
	#mtg .menu_bg {
		background: url(../img/top/sec2_mtg.png) no-repeat 200% 0/cover,
					url(../img/top/sec2_mtg2.png) no-repeat 75% 0/cover;
		padding-top: 0;
	}
	#mtg .about_text {
		width: 70%;
		margin: auto;
	}
	#mtg .about_text ul {
    	display: flex;
	}
	#mtg .about_text ul li {
    	width: 40%;
		margin: 0 auto;
	}
/* =================================================================================================
 * news
 * =================================================================================================*/
 	.news_box{ 
		width: 748px;
	}
/* =================================================================================================
 * gallery
 * =================================================================================================*/
	.gallery_box {
		width: 748px;
	}
/* =================================================================================================
 * access
 * =================================================================================================*/
	#map {
		height: 400px;
	}
	#iv {
		height: 400px;
	}	
	.access_info {
		width: 748px;
	}
	.access_address p{
		font-size: 16px;
	} 
}

@media screen and (min-width:1024px){
	.display_sp,
	.display_tb{
		display: none;
	}
	.display_pc{
		display: block;
	}
	
/* =================================================================================================
 * campaign_headline
 * =================================================================================================*/
	p.campaign_headline {
		top: 525px;
	}
/* =================================================================================================
 * drawer
 * =================================================================================================*/	
 	.drawer {
		display: none;		
	}

/* =================================================================================================
 *  top
 * =================================================================================================*/
	.top_box {
		width: 1000px;
		top: 5%;
	}
/* =================================================================================================
 * about
 * =================================================================================================*/
	.about {
		padding-top: 20px;
	}
	.about#about {
		padding-top: 0px;
	}
	#about .menu_bg {
		background-size: 85%;
		background-position: right bottom;
	}
	.about_box {
		width: 1000px;
	}
	#about .menu_box {
    	width: 1000px;
	}
	.about_img {
	    margin-bottom: 60px;
	}
	.about_btn {
	    margin-top: 48px;
	}
	#menu li {
		width: 300px;
		height: 300px;
		margin: 0 0 7% 3%;
	}
	.mask_caption {
		font-size:	160%;
		padding-top: 140px;
	}
	.menu_hover .mask {
		width: 300px;
		height: 300px;
		-webkit-border-radius: 150px;/* width,heightの半分 */
		-moz-border-radius: 150px;
		border-radius: 150px;
	}
/* =================================================================================================
 * campaign
 * =================================================================================================*/
	.campaign .serif {
		text-align: center;
	}
	#campaign .flex_tab,
	#campaign .flex_tab2 {
		width: 50%;
	}
	#campaign .flex dd p {
	}
	#campaign .flex dd:last-child p {
		text-align: center;
	}
	#campaign .menu_title {
		padding: 6rem 9rem 2rem;
		min-height: 250px;
		display: inline-block;
		width: 100%;
		text-align: center;
	}
	#campaign .menu_title .menu_text {
		width: 50%;
		display: block;
		margin: -1rem 0 0 auto;
		float: right;
		padding-top: 1rem;
	}
/* =================================================================================================
 * 水素メニュー
 * =================================================================================================*/
	#hydrogen {
		background-position:  bottom left;
	}
/* =================================================================================================
 * 整骨メニュー
 * =================================================================================================*/
	#ostracy div>div.about_box {
		background: transparent;
	}
/* =================================================================================================
 * total
 * =================================================================================================*/
	#total {
		background: url(../img/top/total_bg1.png) no-repeat rgba(255, 255, 255, 0.6);
		background-size: 70%;
		background-position: 100% 17%;
		padding-top: 0;
	}
/* =================================================================================================
 * menu
 * =================================================================================================*/
	.menu {
		padding: 20px 0 45px;
	}
	.menu_box {
		width: 1000px;
	}
	.menu_img {
	    margin: 10px 0;
		min-height: 340px;
	}
	.menu_btn {
		margin-top: 48px;
	}
/* =================================================================================================
 * MTG
 * =================================================================================================*/
	#mtg .menu_bg {
		background:  url(../img/top/sec2_mtg.png) no-repeat bottom left/contain,
		url(../img/top/sec2_mtg2.png) no-repeat right/contain;
	}
/* =================================================================================================
 * foot
 * =================================================================================================*/
	#foot .menu_bg {
		background-position: 10% 100%;
	}
	#foot .about_text, #foot .about_title {
		width: 70%;
		margin: 0 0 0 auto;
	}
/* =================================================================================================
 * news
 * =================================================================================================*/
	.news{
		padding-top: 20px; 
	}
	.news_box{ 
		width: 700px;
		margin-bottom: 60px; 
	}
/* =================================================================================================
 * contact
 * =================================================================================================*/
	.contact {
		padding-top: 20px;
	}
	.contact_btn {
		margin: 24px 0 60px;
	}
/* =================================================================================================
 * access
 * =================================================================================================*/
	.access {
		padding-top: 20px;
	}
	.access_info {
		width: 1000px;
	}
	.access_tel p {
	    font-size: 30px;
	}

/* =================================================================================================
 *  iv
 * =================================================================================================*/
	.iv{
		height:350px;
	}
}
@media screen and (min-width:1366px){

	/* =================================================================================================
	 * ostracy
	 * =================================================================================================*/
	#ostracy .menu_bg {
		background-position: 0% 20%;
	}
	#foot .menu_bg {
		background-position: 17% 100%;
	}
}
@media screen and (max-width:1023px){
	.nav {
		display: none;
	}
}
@media screen and (min-width:1500px){
/* =================================================================================================
 * ostracy
 * =================================================================================================*/
#ostracy .menu_bg {
	background-position: 22% 20%;
}	
/* =================================================================================================
 * foot
 * =================================================================================================*/
	#foot .about_text,
	#foot .about_title {
		width: 80%;
		margin: 0 0 0 auto;
	}
} 