@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@300;400;500&display=swap');
@import url('https://fonts.googleapis.com/css2?family=League+Spartan:wght@100;200&display=swap');
html {
  font-size: 62.5%;
  scroll-behavior: smooth;
}
@media(min-width: 768px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
a:link {
  color: #191919;
  text-decoration: underline;
  transition: 0.3s;
}
a:visited {
  color: #191919;
  text-decoration: underline;
}
a:hover {
  color: #666;
  text-decoration: none;
}
.center {
  text-align: center;
}
.right {
  text-align: right;
}
a img {
  transition: 0.3s;
}
a img:hover {
  opacity: 0.6;
}
picture {
  display: block;
}
.pc_none {
  display: none !important;
}
.br {
  display: block !important;
}
/* レイアウト
------------------------------------------------- */

body {
  font-size: 1.7rem;
  color: #3a3b3c;
  line-height: 1.8;
  font-family: 'Zen Kaku Gothic New', sans-serif;
  font-weight: 400;
  background-image: url("../images/bg.jpg");
  background-attachment: fixed;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: none;
  position: relative;
}
header {
  padding: 30px 3%;
}

.kurashi{
  font-size: 1.6rem;
  color: #000000;
}


.nklogo {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 999;
}
h1.logo {
  height: 75vh;
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 3;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #000;
}

svg{
  width: 300px;
  height: auto;
}
path{
  fill: url(#gradient);
}

#stop1{
  animation: step1 5s ease-in-out infinite alternate;
}
#stop2{
  animation: step2 5s ease-in-out infinite alternate;
}

@keyframes step1{
  0% {
    stop-color: #6ba3bc;
  }
  100% {
    stop-color: #5a6366;
  }
}
@keyframes step2{
  0% {
    stop-color: #5a6366;
  }
  100% {
    stop-color: #dba63f;
  }
}



article.topics {
  display: flex;
  margin-left: 3%;
  margin-bottom: 150px;
}
article.topics h2 {
  font-family: 'League Spartan', sans-serif;
  font-weight: 200;
  writing-mode: vertical-rl;
  margin-right: 50px;
  letter-spacing: 0.1em;
  position: relative;
  line-height: 1;
  font-size: 16px;
}


article.topics dl {
  margin-right: 3%;
}

article.topics dl dt {
  font-family: 'League Spartan', sans-serif;
  font-weight: 100;
  letter-spacing: 0.1em;
  font-size: 4rem;
  line-height: 1.2;
}
article.topics dl dd {
  margin-bottom: 30px;
}
.concept {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 200px;
}
.concept ul.slider {
  width: 50%;
  list-style: none;
}
.concept ul.slider li img {
  width: 100%;
  height: auto;
  border-radius: 0 30px 30px 0;
  border: solid 1px #eae9e9;
}
.concept div {
  width: 40%;
  margin-right: 5%;
}
h1.h1_ttl {
  margin-bottom: 30px;
  font-size: 4rem;
  font-weight: 300;
  line-height: 1.3;
}
h1.h1_ttl span {
  font-family: 'League Spartan', sans-serif;
  font-weight: 100;
  letter-spacing: 0.1em;
  font-size: 1.6rem;
  display: block;
}
.concept div p{
  line-height: 3;
  letter-spacing: 0.2em;
}










section.column {
  margin: 0 3%;
  display: flex;
}
h1.vertical {
  font-family: 'League Spartan', sans-serif;
  font-weight: 100;
  writing-mode: vertical-rl;
  width: 10%;
  letter-spacing: 0.1em;
  position: relative;
  line-height: 1;
  font-size: 40px;
  display: flex;
  align-items: flex-end;
}
h1.vertical:after {
  content: '';
  position: absolute;
  top: 200px;
  display: inline-block;
  width: 1px;
  height: calc(100% - 200px);
  height: 50%;
  border-left: solid 1px #b8bec0;
  left: 25px;
}
ul.column_list {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  width: 90%;
  align-items: flex-start;
}
ul.column_list li {
  line-height: 3;
  letter-spacing: 0.2em;
  width: 46%;
  position: relative;

}
ul.column_list li:after {
    position: absolute;
    bottom: -50px;
    left: 0;
  background-image: url("../images/line.png");
  height: 2px;
  content: "";
  width: 75%;
  background-position: center;
}



  
  
  
ul.column_list li:nth-child(even) {
  margin: 200px 0 200px 4%;
}
ul.column_list li:last-child{
  margin: 0 0 200px 0;
}
ul.column_list li i {
  font-size: 4rem;
}
ul.column_list li span {
  color: #a47f0d;
  line-height: 1;
  font-weight: 500;
}
ul.column_list li.photo {
width: 350px;
  height: 500px;
  border-radius: 30px;
  position: relative;
  overflow: hidden;
  z-index: 1;
  border: none;
}
ul.column_list li:nth-child(5):after{
  content: none;
}
ul.column_list li:nth-child(7).photo{
margin-right: calc(46% - 350px);
margin-top: -350px;
}
.photo_in {
position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 70vh;
    z-index: 1;
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    border-radius: 30px;
}

.photo1{
background-image: url("../images/column1.jpg");
}
.photo2{
background-image: url("../images/column2.jpg");
}
.photo3{
background-image: url("../images/column3.jpg");
}
  
  
address {
  font-family: 'League Spartan', sans-serif;
  font-weight: 100;
  letter-spacing: 0.1em;
  font-size: 1.6rem;
  font-style: normal;
  margin: 20px 3%;
  line-height: 1;
}
/*スクロールダウン全体の場所*/
.scrolldown1 {
  /*描画位置※位置は適宜調整してください*/
  position: relative;
}
/*Scrollテキストの描写*/
.scrolldown1 span {
  /*描画位置*/
  position: relative;
}
/* 線の描写 */
.scrolldown1::after {
  content: "";
  /*描画位置*/
  position: absolute;
  top: 60px;
  left: 65%;
  /*線の形状*/
  width: 1px;
  height: 150px;
  background: #b8bec0;
  /*線の動き1.4秒かけて動く。永遠にループ*/
  animation: pathmove 1.7s ease-in-out infinite;
  opacity: 0;
}
/*高さ・位置・透過が変化して線が上から下に動く*/
@keyframes pathmove {
  0% {
    height: 0;
    top: 60px;
    opacity: 0;
  }
  30% {
    height: 120px;
    opacity: 1;
  }
  100% {
    height: 0;
    top: 200px;
    opacity: 0;
  }
}








