/* ----------------------------------------------------------------------------------------------------
     全端末共通のCSS（1325px〜）
---------------------------------------------------------------------------------------------------- */

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

  0. Layout
  1. Text
  2. Header
  3. Navigation
  4. Common
  5. Prt Common
  6. Sidebar
  7. Footer
  8. Index
 
=================================================== 
*/

.pc {
	display:block;
}

.sp {
	display:none;
}

/* -------------------------------------------------------------------------------------
  0. LAYOUT
----------------------------------------------------------------------------------------- */

html{
}

body {
	color: #4a4a4a;
	text-align: center;
	margin: 0 auto;
	height: 100%;
	font-family: 'Noto Sans JP', sans-serif;
	letter-spacing: 0.15em;
	-webkit-text-size-adjust: 100%;
}

#wrap {
	width :100%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
}

#layout {
	width: 100%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	overflow: hidden;
}

.width {
	width: 1100px;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

.width70 {
    width: 70%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}


/* -------------------------------------------------------------------------------------
  1. Text
----------------------------------------------------------------------------------------- */

h1 {
	font-size: 200%;
	margin-bottom: 50px;
	font-weight: 700;
	color: #333333;
    text-align: center;
    line-height: 150%;
	font-family: 'Noto Sans JP', sans-serif;
}

h1 span {
	display: block;
	font-size: 45%;
	font-weight: 500;
	margin-bottom: 10px;
	font-style: normal;
	color: #58BEDD;
	text-transform: uppercase;
}

h2 {
	font-size: 200%;
	text-align: left;
	margin-bottom: 30px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	line-height: 150%;
	font-style: normal;
}

h2 span {
	display: block;
	color: #0062C7;
	font-size: 35%;
	font-family: 'Ramabhadra', sans-serif;
	font-style: normal;
	vertical-align: middle;
}

h3 {
	align-items: center;
	font-size: 135%;
	text-align: left;
	margin-bottom: 30px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	font-style: normal;
}

/*
h3::before {
	content: '';
	display: inline-block;
	margin-right: 10px;
	width: 25px;
	height: 2px;
	background-color: #58BEDD;
}
*/

h3 span {
	font-size: 60%;
}

p + h2,
p + h3,
ul.text + h3,
ol.text + h3 {
	margin-top: 40px;
}

p {
	font-size: 95%;
	line-height: 200%;
	margin-bottom: 20px;
	text-align: left;
}

p.text {
	line-height: 160%;
}

ul.text {
	text-align: left;
	font-size: 95%;
	margin-bottom: 20px;
}

ul.text li {
	line-height: 200%;
	padding: 0 0 10px 0;
	margin-left: 25px; 
	list-style: outside;
}

ul.list {
	text-align: left;
	font-size: 95%;
	margin-bottom: 20px;
}

ul.list li {
	line-height: 200%;
	padding: 0 0 5px 0;
	margin-left: 25px; 
	list-style: outside;
}

ol.text {
	text-align: left;
	font-size: 95%;
	margin-bottom: 20px;
}

ol.text li {
	line-height: 200%;
    margin-top: 20px;
	padding: 0 0 0 0;
	margin-left: 25px; 
	list-style: decimal;
}

ol.text li ol li {
	line-height: 200%;
    margin-top: 10px;
	padding: 0 0 0 0;
	margin-left: 25px; 
	list-style: decimal;
}


/* -------------------------------------------------------------------------------------
  2. Header
----------------------------------------------------------------------------------------- */


#header {
    margin-top: 40px;
}

#header_left {
	float: right;
	margin-right: 5%;
}

#header_right {
	float: left;
	margin-left: 5%;
}


/* -------------------------------------------------------------------------------------
  3. Navigation
----------------------------------------------------------------------------------------- */

nav {
}

#navi {
}

#navi ul {
    border-left: 3px solid #4a4a4a;
}

#navi ul li {
	box-sizing: border-box;
	list-style: none;
	line-height: 100%;
	font-size: 90%;
    font-weight: 400;
    text-align: left;
}

#navi ul li a {
	display: block;
	text-decoration: none;
	overflow: hidden;
	padding: 10px 20px;
	box-sizing: border-box;
}

#navi ul li a:hover {
	transition:0.5s;
    color: #007df3;
}

body#home #navi ul li a#cat-nav-1 { color: #007df3; }
body#menu #navi ul li a#cat-nav-2 { color: #007df3; }
body#salon #navi ul li a#cat-nav-3 { color: #007df3; }

#menu_btn {
	display: none;
}

/* -------------------------------------------------------------------------------------
  4. Common
----------------------------------------------------------------------------------------- */

#container {
    margin-top: 100px;
}

section {
	margin-bottom: 80px;
}

article {
	margin-bottom: 60px;
}

.column2 {
	width: 48%;
	float: left;
	margin-right: 4%;
	margin-bottom: 40px;
}

.column2:nth-child(2n) {
	margin-right: 0;
}

.column3 {
	width: 31.5%;
	float: left;
	margin-bottom: 20px;
	margin-right: 2.75%;
}

.column3:nth-child(3n) {
	margin-right: 0;
}

.column4 {
	width: 23.5%;
	float: left;
	margin-right: 2%;
}

.column4:nth-child(4n) {
	margin-right: 0;
}

.column3box {
	width: 33.3333%;
	float: left;
}

.left50 {
	float: left;
	width: 48%;
}

.right50 {
	float: right;
	width: 48%;
}

.left40 {
	float: left;
	width: 25%;
    margin-bottom: 20px;
}

.right60 {
	float: right;
	width: 60%;
    margin-bottom: 20px;
}

.left65 {
	float: left;
	width: 60%;
}

.right35 {
	float: right;
	width: 35%;
}

.left30 {
	float: left;
	width: 25%;
    margin-bottom: 20px;
}

.right70 {
	float: right;
	width: 70%;
    margin-bottom: 20px;
}


.flex {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.flex2 {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}

/* -------------------------------------------------------------------------------------
  5. Prt Common
----------------------------------------------------------------------------------------- */



 /* -------------------------------------------------------------------------------------
  6. Sidebar
----------------------------------------------------------------------------------------- */



/* -------------------------------------------------------------------------------------
  7. Footer
----------------------------------------------------------------------------------------- */

#footer_left {
    float: left;
    width: 50%;
}

#footer_left p {
    line-height: 160%;
    font-size: 90%;
}

#footer_right {
    float: right;
    width: 50%;
}

#footer_right dl {
    text-align: right;
    font-size: 90%;
}

#footer_right dl dt {
    display: inline-block;
    background: #007df3;
    padding: 5px 25px;
    text-align: center;
    color: #FFF;
    border-radius: 100px;
    margin-bottom: 5px;
}

#footer_right dl dd {
    margin-bottom: 20px;
}

#footer_right dl dd a {
    text-decoration: none;
}

#footer_address {
    padding: 40px 0;
}

address {
	font-style: normal;
	font-size: 80%;
}

/* Pagetop Button
-------------------------------------*/

#page-top {
	position: fixed;
    bottom: 0%;
    right: 0px;
	z-index: 500;
	box-sizing: border-box;
}

#page-top a {
    background: #1a1311;
    text-decoration: none;
    color: #fff;
	padding: 15px 20px 20px;
    text-align: center;
    display: block;
}

#page-top a:hover {
    text-decoration: none;
    background: #E75800;
}

/* -------------------------------------------------------------------------------------
  8. Index
----------------------------------------------------------------------------------------- */

#main {
    position: relative;
    top: 0;
    right: 5%;
    left: 15%;
    width: 80%;
    display: block;
    margin-top: 40px;
}

#main p {
    position: absolute;
    top: -100px;
    left: 5%;
    transform: translateX(0%);
    margin: auto;
    width: 30%;
    z-index: 10;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

/* トップページ
-------------------------------------*/

#bg_reserve {
    background: #007df3;
    padding: 60px 0;
}

#bg_reserve h3,
#bg_reserve p {
    text-align: center;
    color: #FFF;
}

.tel {
    font-size: 230%;
    font-weight: bold;
    line-height: 100%;
}

.name {
    font-size: 140%;
    font-weight: 500;
    margin-bottom: 0px;
}

.name span {
    background: #007df3;
}

.name + p {
    font-size: 85%;
}

/* menu
-------------------------------------*/

#bg_point {
    background: #007df3;
    padding: 60px 0;
}

.box_white {
    background: #FFFFFF;
    border-radius: 20px;
    box-sizing: border-box;
    padding: 50px 50px 40px;
}

/* 
-------------------------------------*/



/* フェード
-------------------------------------*/

.fade {
    opacity : 0.1;
    transform : translate(0, 50px);
    transition : all 500ms;
}
 
.fade.scrollin {
    opacity : 1;
    transform : translate(0, 0);
}

.fade1 {
    opacity : 0.1;
    transform : translate(0, -80px);
    transition : all 500ms;
}
 
.fade1.scrollin {
    opacity : 1;
    transform : translate(0, 0);
}

.bound {
  animation: bound 3s infinite;
}

@keyframes bound {
  0% { transform:translateY(-20px) }
  5% { transform:translateY(-20px) }
  10% { transform:translateY(-20px) }
  20% { transform:translateY(-100px) }
  25% { transform:translateY(-20px) }
  30% { transform:translateY(-95px) }
  50% { transform:translateY(-20px) }
  100% { transform:translateY(-20px) }
}

.fadeUp{
   animation-name: fadeUpAnime;
    animation-delay: 1s;
    animation-duration: 1.5s;
    animation-fill-mode: forwards;
    transform: translateX(-50px);
    opacity: 0;
}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
	transform: translateY(100px);
  }

  to {
    opacity: 1;
	transform: translateY(0);
  }
}

.img-wrap {
  opacity: 0;
}

.img-animation {
  animation: img-opacity 2s cubic-bezier(.4, 0, .2, 1);
  overflow: hidden;
  position: relative;
}

.img-animation:before {
  animation: img-animation 2s cubic-bezier(.4, 0, .2, 1) forwards;
  background: #fff;
  bottom: 0;
  content: '';
  left: 0;
  pointer-events: none;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
}

@keyframes img-opacity {
  100% {
    opacity: 1;
  }
}

@keyframes img-animation {
  100% {
    transform: translateX(100%);
  }
}

/* 写真
-------------------------------------*/

.maru img {
	border-radius: 25px;
}

.anime_wrap {
    position: relative;
    overflow: hidden;
}
.anime_wrap p {
    position: absolute;
    top: 30px;
    left: 30px;
    font-size: 40px;
    font-weight: bold;
}

.pattern6::before {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background: #0062C7;
    z-index: 2;
    transition: .5s;
}
.pattern6.show::before {
    transform: translateX(100%);
}
.pattern6 img {
    opacity: 0;
    transition: .5s;
}
.pattern6.show img {
    opacity: 1;
}
.pattern6 p {
    color: #FFF;
    opacity: 0;
    transform: translateX(-40px);
    transition: .5s;
    transition-delay: .5s;
    z-index: 1;
    overflow: hidden;
	letter-spacing: 0.1em;
	font-weight: 400;
	font-family:Georgia, "Times New Roman", Times, "serif";
	font-style: italic;
}
.pattern6.show p {
    opacity: 1;
    transform: translateX(0);
}
.pattern6 p::before {
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
    background: #0062C7;
    transition: .5s;
    transition-delay: 1s;
}
.pattern6.show p::before {
    transform: translateX(100%);
}

/* ボタン
-------------------------------------*/

.btn {
}

.btn a {
    display: inline-block;
	background: #007df3;
	padding: 5px 30px;
	text-align: center;
	color: #FFF;
	text-decoration: none;
	border-radius: 100px;
	font-size: 95%;
    box-sizing: border-box;
}

.btn a:hover {
	background: #DC6372;
}

.btn2 {
    position: relative;
	text-align: center;
}

.btn2 a {
    display: inline-block;
	background: #C40C23 url("../img/common/arrow.svg") center right 20px no-repeat;
	padding: 25px 0px;
	text-align: center;
	color: #FFF;
	text-decoration: none;
	border-radius: 100px;
	width: 400px;
	font-size: 120%;
    box-sizing: border-box;
}

.btn2 a:hover {
	background: #DC6372 url("../img/common/arrow.svg") center right 20px no-repeat;
}


/* ローディング
-------------------------------------*/

.loading {
	width: 100%;
	height: 100%;
	background: rgba(250,248,243,1.0);
	position: fixed;
	top: 0;
	left: 0;
	z-index: 20000;
}

.loading i {
	position: absolute;
	top: 50%;
	left: 50%;
	margin-top: -30px;
	margin-left: -30px;
}

#instagram {
    position: fixed;
    top: 40%;
    right: 2%;
}

/* Wordpress
--------------------------------------------------------------------------*/

.entry-footer {
	display: none;
	margin: 50px auto;
	padding: 15px 0;
	border: 1px solid rgba(235,235,235, 1);
	font-size: 85%;
	background: #FFF;
}

.navigation {
	display: none;
}

.pagination {
	clear: both;
	padding: 20px 0;
	position: relative;
	font-size: 14px;
	line-height: 14px;
	text-align: center;
	border-top: 4px solid #3d6946 !important;
}
.pagination-box {
	display: inline-block;
}
.pagination span, .pagination a {
	display: block;
	float: left;
	margin: 2px 2px 2px 0;
	padding: 10px 15px 10px 15px;
	text-decoration: none;
	width: auto;
	color: #fff; /* 通常の文字色 */
	background: #3d6946; /* 通常の背景色 */
}
.pagination a:hover{
	color: #fff; /* マウスホバー時の文字色 */
	background: #A81925; /* マウスホバー時の背景色 */
}
.pagination .current{
	padding: 10px 15px 10px 15px;
	color: #FFF500; /* 現在のページの文字色 */
        background: #003925; /* 現在のページの背景色 */
}

@media only screen and (max-width: 413px) {
.pagination {
	font-size: 12px;
	line-height: 12px;
}
.pagination span, .pagination a {
	padding: 8px 10px 8px 10px;
}
.pagination .current{
	padding: 8px 10px 8px 10px;
}
}


/* ----------------------------------------------------------------------------------------------------
     タブレット端末（640〜900px）
---------------------------------------------------------------------------------------------------- */ 
@media only screen and (max-width: 1100px) {

.pc {
	display:block;
}

.sp {
	display:none;
}

.width {
	width: 90%;
}
	
} /* /@media */



/* ----------------------------------------------------------------------------------------------------
     スマホ端末（320px〜640px）
---------------------------------------------------------------------------------------------------- */
@media only screen and (max-width: 950px) {



} /* /@media */


/* ----------------------------------------------------------------------------------------------------
     タブレット端末（640〜900px）
---------------------------------------------------------------------------------------------------- */ 
@media only screen and (max-width: 750px) {

.pc {
	display:none;
}

.sp {
	display:block;
}

.width {
	width: 80%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}

.width70 {
    width: 100%;
	text-align: center;
	margin-left: auto;
	margin-right: auto;
	box-sizing: border-box;
}


/* -------------------------------------------------------------------------------------
  1. Text
----------------------------------------------------------------------------------------- */

h1 {
	font-size: 200%;
	margin-bottom: 30px;
	font-weight: 700;
	color: #333333;
    text-align: center;
    line-height: 150%;
	font-family: 'Noto Sans JP', sans-serif;
}

h1 span {
	display: block;
	font-size: 45%;
	font-weight: 500;
	margin-bottom: 10px;
	font-style: normal;
	color: #58BEDD;
	text-transform: uppercase;
}

h2 {
	font-size: 200%;
	text-align: left;
	margin-bottom: 30px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	line-height: 150%;
	font-style: normal;
}

h2 span {
	display: block;
	color: #0062C7;
	font-size: 35%;
	font-family: 'Ramabhadra', sans-serif;
	font-style: normal;
	vertical-align: middle;
}

h3 {
	align-items: center;
	font-size: 135%;
	text-align: left;
	margin-bottom: 30px;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	font-style: normal;
}

/*
h3::before {
	content: '';
	display: inline-block;
	margin-right: 10px;
	width: 25px;
	height: 2px;
	background-color: #58BEDD;
}
*/

h3 span {
	font-size: 60%;
}

p + h2,
p + h3,
ul.text + h3,
ol.text + h3 {
	margin-top: 40px;
}

p {
	font-size: 95%;
	line-height: 200%;
	margin-bottom: 20px;
	text-align: left;
}

p.text {
	line-height: 160%;
}

ul.text {
	text-align: left;
	font-size: 95%;
	margin-bottom: 20px;
}

ul.text li {
	line-height: 200%;
	padding: 0 0 10px 0;
	margin-left: 25px; 
	list-style: outside;
}

ul.list {
	text-align: left;
	font-size: 95%;
	margin-bottom: 20px;
}

ul.list li {
	line-height: 200%;
	padding: 0 0 5px 0;
	margin-left: 25px; 
	list-style: outside;
}

ol.text {
	text-align: left;
	font-size: 95%;
	margin-bottom: 20px;
}

ol.text li {
	line-height: 200%;
    margin-top: 20px;
	padding: 0 0 0 0;
	margin-left: 25px; 
	list-style: decimal;
}

ol.text li ol li {
	line-height: 200%;
    margin-top: 10px;
	padding: 0 0 0 0;
	margin-left: 25px; 
	list-style: decimal;
}


/* -------------------------------------------------------------------------------------
  2. Header
----------------------------------------------------------------------------------------- */


#header {
    margin-top: 40px;
}

#header_left {
	float: right;
	margin-right: 10%;
}

#header_right {
	float: left;
	margin-left: 10%;
}


/* -------------------------------------------------------------------------------------
  3. Navigation
----------------------------------------------------------------------------------------- */

nav {
}

#navi {
}

#navi ul {
    border-left: 3px solid #4a4a4a;
}

#navi ul li {
	box-sizing: border-box;
	list-style: none;
	line-height: 100%;
	font-size: 90%;
    font-weight: 400;
    text-align: left;
}

#navi ul li a {
	display: block;
	text-decoration: none;
	overflow: hidden;
	padding: 10px 15px;
	box-sizing: border-box;
}

#navi ul li a:hover {
	transition:0.5s;
    color: #007df3;
}

body#home #navi ul li a#cat-nav-1 { color: #007df3; }

#menu_btn {
	display: none;
}

/* -------------------------------------------------------------------------------------
  4. Common
----------------------------------------------------------------------------------------- */

#container {
    margin-top: 60px;
}

section {
	margin-bottom: 60px;
}

article {
	margin-bottom: 40px;
}

.column2 {
	width: 100%;
	float: none;
	margin-right: 0%;
	margin-bottom: 40px;
}

.column2:nth-child(2n) {
	margin-right: 0;
}

.column3 {
	width: 100%;
	float: none;
	margin-bottom: 20px;
	margin-right: 0%;
}

.column3:nth-child(3n) {
	margin-right: 0;
}

.column4 {
	width: 23.5%;
	float: left;
	margin-right: 2%;
}

.column4:nth-child(4n) {
	margin-right: 0;
}

.column3box {
	width: 33.3333%;
	float: left;
}

.left50 {
	float: left;
	width: 48%;
}

.right50 {
	float: right;
	width: 48%;
}

.left40 {
	float: none;
	width: 70%;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 20px;
}

.right60 {
	float: none;
	width: auto;
    margin-bottom: 20px;
}

.left65 {
	float: none;
	width: auto;
}

.right35 {
	float: none;
	width: auto;
}

.left30 {
	float: none;
	width: auto;
    margin-bottom: 20px;
}

.right70 {
	float: none;
	width: auto;
    margin-bottom: 20px;
}

.flex {
	display: block;
	justify-content: space-between;
	align-items: center;
}

.flex2 {
	display: block;
	justify-content: space-between;
	align-items: flex-end;
}

/* -------------------------------------------------------------------------------------
  5. Prt Common
----------------------------------------------------------------------------------------- */



 /* -------------------------------------------------------------------------------------
  6. Sidebar
----------------------------------------------------------------------------------------- */



/* -------------------------------------------------------------------------------------
  7. Footer
----------------------------------------------------------------------------------------- */

#footer_left {
    float: none;
    width: 100%;
}

#footer_left p {
    line-height: 160%;
    font-size: 90%;
    text-align: center;
}

#footer_right {
    float: none;
    width: 100%;
}

#footer_right dl {
    text-align: center;
    font-size: 90%;
}

#footer_right dl dt {
    display: inline-block;
    background: #007df3;
    padding: 5px 25px;
    text-align: center;
    color: #FFF;
    border-radius: 100px;
    margin-bottom: 5px;
}

#footer_right dl dd {
    margin-bottom: 20px;
}

#footer_right dl dd a {
    text-decoration: none;
}

#footer_address {
    padding: 40px 0;
}

address {
	font-style: normal;
	font-size: 80%;
}

/* Pagetop Button
-------------------------------------*/

#page-top {
	position: fixed;
    bottom: 0%;
    right: 0px;
	z-index: 500;
	box-sizing: border-box;
}

#page-top a {
    background: #1a1311;
    text-decoration: none;
    color: #fff;
	padding: 15px 20px 20px;
    text-align: center;
    display: block;
}

#page-top a:hover {
    text-decoration: none;
    background: #E75800;
}

/* -------------------------------------------------------------------------------------
  8. Index
----------------------------------------------------------------------------------------- */

#main {
    position: relative;
    top: 0;
    right: 10%;
    left: 10%;
    width: 80%;
    display: block;
    margin-top: 40px;
}

#main p {
    position: absolute;
    top: -60px;
    left: 5%;
    transform: translateX(0%);
    margin: auto;
    width: 30%;
    z-index: 10;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

/* トップページ
-------------------------------------*/

#bg_reserve {
    background: #007df3;
    padding: 60px 0;
}

#bg_reserve h3,
#bg_reserve p {
    text-align: center;
    color: #FFF;
}

.tel {
    font-size: 160%;
    font-weight: bold;
    line-height: 100%;
}

.name {
    font-size: 140%;
    font-weight: 500;
    margin-bottom: 0px;
    text-align: center;
}

.name span {
    background: #007df3;
}

.name + p {
    font-size: 85%;
    text-align: center;
}

/* menu
-------------------------------------*/

#bg_point {
    background: #007df3;
    padding: 60px 0;
}

.box_white {
    background: #FFFFFF;
    border-radius: 20px;
    box-sizing: border-box;
    padding: 50px 30px 40px;
}

#instagram {
    position: fixed;
    top: 40%;
    right: 3%;
}
    
.bg_menu .alignC {
    text-align: left;
}

ul.picture li {
    float: left;
    width: 33.3333%;
}
    
.normalTbl {
    overflow-x: scroll;
}
    
.normalTbl table {
    width: 100%;
    border-collapse: collapse;
    white-space: nowrap;
}
    
.normalTbl table th,
.normalTbl table td {
    border: 2px solid #eee;
}
    
}


/* ----------------------------------------------------------------------------------------------------
     iPhone5端末（〜320px）
---------------------------------------------------------------------------------------------------- */ 
@media only screen and (max-width: 640px) {


	
} /* /@media */
