@charset "UTF-8";
/*
Theme Name: rebirth
*/

ul{margin-left:0;list-style: none;padding: 0;}.text50{ font-size: 50%;}.text60{ font-size: 60%;}.text70{ font-size: 70%;}.text80{ font-size: 80%;}.text90{font-size:90%;}.text100{font-size:100%;}.text110{font-size: 110%;}.text120{font-size: 120%; }.text130 {font-size:130%;}.text140 {font-size:140%;}.text150{font-size:150%;}.text160{font-size:160%;}.text170{font-size: 170%;}.text180 {font-size:180%;}.text190{font-size:190%;}.text200{font-size:200%; }.text250{font-size: 250%;}.text300{font-size: 300%;}.text350 {font-size: 350%;}.text400{font-size:400%;}.alpha7,.alpha8,.alpha9{transition:0.25s ease-in-out;}.alpha7:hover{filter:alpha(opacity=70);opacity:.7!important;}.alpha8:hover{filter:alpha(opacity=80);opacity:.8!important;}.alpha9:hover{filter:alpha(opacity=90);opacity:.9!important;}.scale img{transition:transform 0.2s ease-out;}.scale:hover img{transform:scale(1.02);}.scale-m img{transition:transform 0.25s ease-out;}.scale-m:hover img{transform:scale(1.07);}.scale-l img{transition:transform 0.3s ease-out;}.scale-l:hover img{transform:scale(1.12);}.cf:after{content:".";display: block;clear:both;height: 0;visibility:hidden;}.cf{min-height:1px;}* html .cf {height: 1px;/*��*//*/height:auto;overflow:hidden;/**/}.clear{clear:both;}.fw400{font-weight:400;}.fw500{font-weight:500;}.fw600{font-weight:500;}.fw700{font-weight:700;}.kome,.maru,.kaku,.hishi{display: block;position:relative;padding-left:1.3em;line-height:1.3;}.kome:before,.maru:before,.kaku:before,.hishi:before {position:absolute;left: 0;}.kome:before{content:"※";}.maru:before{content:"●";}.kaku:before{content:"■";}.hishi:before{content:"◆";}@media (-webkit-device-pixel-ratio: 2){.alpha7,.alpha8,.alpha9{transition:none !important;}.scale img,.scale-m img,.scale-l img{transition:none !important;}}
.w-space-s {letter-spacing:.15em;text-indent:.15em;}.w-space-m{letter-spacing:.3em;text-indent:.3em;}.w-space-l{letter-spacing:.5em;text-indent:.5em;}

body {
  font-size: 1.3vw;
  font-family: "Noto Sans JP", "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Roboto, MotoyaLCedar, sans-serif;
  line-height: 1.8;
  color: #473a60;
  background-color: #ffffff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.font-latin {
  font-family: 'Comfortaa', "Noto Sans JP", "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Roboto, MotoyaLCedar, sans-serif;
}
.tel-link {
  cursor: text;
  text-decoration: none;
  pointer-events: none;
}
a.no-line {
  text-decoration: none;
}
.lh-s {
  line-height: 1.3;
}
.bg-gray {
  background-color: #555;
}
.bg-purple {
  background-color: #b6b4c8;
}
.text-purple {
  color: #645E9A;
}
.text-purple2 {
  color: #5D41CF;
}
.text-info-kon{
  color: #214C93;
}
.ttl-h1 {
  padding: 1.2vw 2vw;
  border-radius: 3vw;
  width: 30%;
  border-style: double;
  border-color: #fff;
  border-width: 0 1.5vw;
}

#header {
  height: 6vw;
  color: #333;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 123456;
  width: 100%;
  background: linear-gradient(to bottom, rgba(255,255,255,1) 0%, rgba(255,255,255,.9) 40%, rgba(255,255,255,0) 100%);
}
#mv {
	z-index: 12;
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
  height: 40vw;
  position: relative;
  top: 0;
  left: 0;
  overflow: hidden;
}
#page-title {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: rgba(147,113,183,.7);
  padding: 1vw 0;
}
.other #mv {
  background-position: bottom center;
}
#search {
  background-color: rgba(0,0,0,.65);
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 12345;
}
.logo-area {
  padding: .7vw;
  width: 16vw;
}
.logo-area a {
  font-size: 100%;
  z-index: 123;
  position: relative;
  line-height: 1.3;
  text-decoration: none;
}
.logo-area figcaption {
  padding: 0 0 0 1.8vw;
  font-size: 110%;
}

#header .main-nav {
  text-align: center;
}
#header .nav-link {
  text-decoration: none;
  font-size: 90%;
  text-align: center;
  padding: 1vw 0.7vw 0;
  transition: 0.2s ease-in-out;
  line-height: 1.7;
}
#header .main-nav li#nav-info {
  border-width: 0;
}
#header .nav-link:hover,
#header .nav-link.active {
  color: #FF9927;
}
#header .nav-link::after {
  position: absolute;
  top: 0;
  left: 0;
  content: '';
  width: 0;
  height: 3px;
  background-color: #FF9927;
  border-radius: 3px;
  transition: .2s ease-out;
  z-index: -1;
}
#header .nav-link:hover::after,
#header .nav-link.active::after {
  width: 100%;
}


.wp-pagenavi {
  margin: 3vw 0;
  text-align: center;
  font-family: 'Comfortaa', "Noto Sans Japanese", "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", Roboto, MotoyaLCedar, sans-serif;
}
.wp-pagenavi > span,
.wp-pagenavi > a {
  display: inline-block;
  line-height: 1.1;
  padding: 4px 9px 1px;
  border: solid 1px #123;
  border-radius: 3px;
  margin: 0 3px;
  color: #345;
  text-decoration: none;
  font-size: 105%;
  font-weight: 600;
}
.wp-pagenavi span.current,
.wp-pagenavi > a:hover {
  background-color: #567;
  color: #fff;
  border: solid 1px #123;
}
.nav-spacer {
	width: 1vw;
}

.table-title {
  background-color: coral;
}
table {
  border-collapse: collapse;
  font-size: 16px;
}
table th, table td {
  border: solid 1px white;
  background-color: #dae0e5;
  padding:0px 13px;
}
table tr {
 height:100px;
}



@media (min-width: 768px){
  #header .nav-link {
    color: #712c99;
    font-weight: 600;
  }
  #header .nav-link span {
    font-weight: 400;
  }
  #add-tel-area {
    margin-top: 1.7vw;
  }
  #btn-inquiry {
    margin-top: 1.5vw;
  }
  .tel-text,
  #btn-inquiry {
    display: block;
    text-decoration: none;
    color: #dc3545;
    font-size: 120%;
    line-height: .2;
  }
  a.btn-effect,
  .btn-effect {
    position: relative;
    box-sizing: border-box;
    display: inline-block;
    margin: 0px 3px 6px;
    text-align: center;
    text-decoration: none;
    color: #dc3545;
    white-space: nowrap;
    z-index: 0;
    transition: 0.5s ease-in-out;
    overflow: visible;
    border: none;
    padding: 0 1.5vw;
  }
  .btn-effect::after {
    box-sizing: border-box;
    position: absolute;
    width: 100%;
    height: 100%;
    content: "";
    border: 1px solid #dc3545;
    border-radius: 2px;
    z-index: 2;
    margin: 0px;
    left: 0px;
    bottom: 0px;
    border-top-width: 1px;
    transition: border-top-width 0.1s 0.2s, height 0.2s 0.1s, width 0.2s 0s, margin 0.2s 0s;
  } 
  .btn-effect:hover::after {
    width: 68%;
    height: 0px;
    border-width: 0px 1px 1px;
    margin: 0px 17%;
    transition: border-top-width 0.1s 0s, height 0.2s 0.1s, width 0.2s 0.2s, margin 0.2s 0.2s;
  }
  #nav-sns {
    position: absolute;
    top: 8vw;
    left: 2%;
    width: 26%;
    font-size: 200%;
    background-color: #ddd;
    padding: .7vw;
  }
  #nav-sns li {
    padding: .2vw 1vw !important;
    line-height: 1;
  }
  #link-athome {
    background-color: #dc3545;
    width: 8vw;
    padding: 0 .7vw .5vw;
    line-height: .6;
  }
  #link-rakumachi {
    width: 5.5vw;
  }
}

#f-contact {
  background-position: center bottom -15vw;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  color: #fff;
}
#f-contact > div {
  position: relative;
  z-index: 123;
}
#f-contact .ttl-index,
#f-contact a {
  color: #fff;
}
#f-btn a {
  border: solid 1px #fff;
  background-color: rgba(220, 53, 69,.7);
  border-radius: 8vw;
  text-decoration: none;
  line-height: 1;
  padding: 1vw 0;
}
.nav-sns .icon-sns img {
  width: 4vw;
}
.nav-sns .athome a, .nav-sns .rakumachi a {
  border-radius: .7vw;
}
.nav-sns .athome a {
  padding: .9vw 1.1vw .7vw;
}
#header .nav-sns .athome a {
  border: solid 1px #fff;
}
.nav-sns .athome img {
  width: 8.7vw;
  vertical-align: baseline;
}
.nav-sns .rakumachi a {
  padding: .8vw 1.3vw;
}
.nav-sns .rakumachi img {
  width: 5.2vw;
}

#footer-nav .nav-link,
.copy {
  color: #ffffff;
}
#footer-nav a.nav-link {
  font-weight: 400 !important;
  padding: .4vw .5vw;
  font-size: 80%;
  text-align: center;
}


@media (min-width: 768px){
  /*page-top*/
  #Pagetop {
    position:fixed;
    bottom: 5vw;
    right: 3vw;  
    cursor:pointer;
    z-index: 1234567;
    opacity: .9;
  }

  #Pagetop p {
    font-size: 150%;
    text-align: center;
    line-height: 4vw;
    height: 4vw;
    width: 4vw;
    padding: 0;
    margin: 0;
    color: #ffffff;
  }
  #footer .nav-link i {
    line-height: 2vw !important;
  }
}

@media (min-width: 1200px){
  #main section {
    font-size: 1rem;
  }
}
@media (max-width: 1200px){
  .container {
    max-width: none;
  }
}
@media (max-width: 767px){
  body {
    font-size: 3vw;
  }
  #header {
    height: 18vw;
  }
  .tel-link {
    pointer-events: auto;
    text-decoration: underline;
  }
  .form-control {
    padding: .2vw;
  }
  #mv {
    height: 70vw;
    width: 100%;
    min-height: 0;
    margin-left: 0;
  }
  
  #page-title {
    padding: 2vw 0;
  }
  .logo-area {
    width: 70vw;
    padding: 1.8vw 0 0 0;
  }
  .logo-area figure {
    margin: 0;
  }
  .logo-area figcaption {
    padding: 0 0 0 3.6vw;
  }
  #nav-area {
    width: 0;
  }
  #inquiry-area {
    position: fixed;
    width: 100%;
    bottom: 0;
    left: 0;
    font-size: 160%;
    color: #ffffff;
    background-color: rgba(255,255,255,.9);
    z-index: 123456;
    height: 14vw;
  }
  #inquiry-area > div {
    height: 100%;
  }
  #inquiry-area a,
  .navbar-toggle {
    color: #712c99;
    text-decoration: none;
    position: relative;
    display: block;
    height: 100%;
    line-height: 1;
  }
  .bm-text {
    font-size: 40%;
    position: absolute;
    top: 8.5vw;
    left: 0;
    width: 100%;
  }
  .tel-text {
    font-size: 100%;
  }
  .navbar-toggle {
    border: none;
    margin-top: 0;
    outline: none !important;
    color: #712c99;
    background-color: transparent;
    text-align: center;
    display: inline-block;
    width: 100%;
    padding-top: .7vw;
  }
  .navbar-toggle .icon-bar {
    background-color: #712c99;
    width: 7vw;
    height: .7vw;
    display: block;
    border-radius: 1px;
    margin-left: auto;
    margin-right: auto;
  }
  .navbar-toggle span {
    transition: all 0.5s;
    transform: rotate(0deg);
  }
  .navbar-toggle .top {
    transform: translateY(0px);
  }
  .navbar-toggle .bottom {
    transform: translateY(0px);
  }

  .navbar-toggle .icon-bar+.icon-bar {
      margin-top: 1.2vw;
  }
  .navbar-toggle.is-open .middle {
    background: rgba(0, 0, 0, 0);
  }
  .navbar-toggle.is-open .top {
    transform: rotate(-45deg) translateY(1.4vw) translateX(-1.3vw);
  }
  .navbar-toggle.is-open .bottom {
    transform: rotate(45deg) translateY(-1.4vw) translateX(-1.3vw);
  }
  
  #header .main-nav {
    display: none;
    width: 100%;
    position: fixed !important;
    left: 0;
    bottom: -14vw;
    white-space: nowrap;
    max-height: 100%;
    height: auto;
    z-index: 123456;
    padding: 3vw;
    opacity: 0;
    overflow: auto;
    background-color: rgba(255,255,255,1);
  }
  #header .main-nav li {
    margin: 1.5vw 0;
    padding: 0 2vw;
    border-right: 0;
  }
  #header .nav-link {
    padding: 3vw 0;
    text-align: center;
    width: 100%;
    font-size: 105%;
    border: solid 1px rgba(113, 44, 153,.5);
    border-width: 0 0 1px;
    height: auto;
    color: #712c99;
  }
  #header li:last-child .nav-link {
    border-width: 0 0 1px;
  }
  #header .nav-link::after {
    content: none;
  }
  #nav-sns {
    padding-top: 3vw;
  }
  #nav-sns li {
    padding: 0 5vw !important;
  }
  #nav-sns a {
    color: #fff !important;
    font-size: 150%;
  }
  #link-athome {
    width: 23vw;
  }
  #link-rakumachi {
    width: 15vw;
  }
  .wp-pagenavi {
    margin: 6vw 0;
  }
  .nav-sns li {
    padding: 0 2vw !important;
  }
  .nav-sns .icon-sns img {
    width: 10vw;
  }
  .nav-sns .athome a, .nav-sns .rakumachi a {
    border-radius: 1.5vw;
  }
  .nav-sns .athome a {
    padding: 2.2vw 2.5vw 1.2vw;
  }
  .nav-sns .athome img {
    width: 22vw;
    vertical-align: baseline;
  }
  .nav-sns .rakumachi a {
    padding: 1.1vw 1.3vw 1.6vw;
  }
  .nav-sns .rakumachi img {
    width: 14vw;
  }
  #f-contact {
    background-position: center center;
  }
  #f-btn a {
    padding: 2vw 0;
  }
  #footer {
    padding-bottom: 16vw;
  }
  #footer-nav a.nav-link {
    padding: .8rem 2.5vw;
  }
  #Pagetop {
    background-color: rgba(255,255,255,.2);
  }
  #Pagetop p {
    color: #ffffff;
    padding: 2vw 0;
    background-color: transparent;
  }
}

@media (max-width: 575px){
  body {
    font-size: 3.7vw;
  }
  #permit {
    width: 67vw;
    top: 15vw;
    left: 1.7vw;
  }
  .logo-area {
    width: 80vw;
  }
}


