@charset "UTF-8";
html {
font-size: 62.5%;
}

body {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  width:100%;
  font-size: 1.4rem;
  color: #000;
  background:#FFF;
  position:relative;
  min-width:1024px;
  line-height:1.4;
}

.to-top{
  position: fixed;
  bottom: 20px;
  right: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 50px;
  height: 50px;
  background: rgba(51,51,51,0.7);
}

.arrow{
  width: 10px;
  height: 10px;
  border-top: 3px solid #fff;
  border-right: 3px solid #fff;
  transform: rotate(-45deg);
  margin-top: 5px;
}

*{
  box-sizing:border-box;
}

img{
  width:100%;
  height:auto;
}

header{
  position:fixed;
  width:100%;
  z-index:3;
}

.headerScroll{
  background:rgba(255,255,255,0.9);
}

.headerInner{
  display: flex;
  align-items: baseline;
  padding: 25px 25px 5px;
}

header .logoArea{
  width: 100px;
}

header nav{
  width: 100%;
  font-family: "Raleway", sans-serif;
  letter-spacing: 2px;
  font-size: 1.8rem;
}

.webfont{
  font-family: "Raleway", sans-serif;
}

.fa-solid{
  display: none;
}

header nav a{
  color: #FFF;
}

.headerScroll nav a{
  color: #888;
  text-shadow:none;
}

header nav ul{
  display:flex;
  justify-content: flex-end;
  column-gap: 30px;
}

section.visual{
  width: 100VW;
  max-width: none;
  height: 100vh;
  position:relative;
  padding:0;
}

.catch{
  position:absolute;
  top: 50%;
  left: 10%;
  transform:translate(0,-50%);
  font-size: 8rem;
  font-weight: 700;
  letter-spacing: 6px;
  color:#FFF;
  z-index:2;
}

.mask{
  position: absolute;
  width:100%;
  height:100vh;
  background:rgba(0,0,0,0.3);
}

.visual video{
  width: 100%;
  height:100vh;
  object-fit: cover;
  object-position: center top;
}

section h2{
  font-size: 4.2rem;
  color:#000;
  letter-spacing: 3px;
  font-family: "Raleway", sans-serif;
  line-height: 1;
  padding-top: 50px;
}

#top h2{
  padding: 0;
}

.textGuide{
  font-size:1.6rem;
  font-weight: 700;
  padding:12px 0 0 12px;
}

section{
  padding: 50px 10%;
  max-width: 1920px;
  margin: 0 auto;
}

.intro{
  padding-bottom: 100px;
}

.contentsBox{
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-top: 50px;
  gap: 20px;
}

.contentsImg{
  width: calc(100%/2 - 20px);
  max-height: 410px;
  aspect-ratio: 1;
}

.contentsImg img{
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sectionTextBox{
  width: calc(100%/2 - 20px);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.serviceIntro{
  padding:25px 0 50px;
  font-size: 1.8rem;
  line-height: 2;
}

.serviceIntro p{
  padding-bottom: 32px;
}

.serviceIntro span{
  display: block;
}

.sectionText{
  font-size:1.5rem;
  line-height: 2;
  margin-bottom: 50px;
}

.sectionText h3{
  font-size: 2.4rem;
  padding: 50px 0 25px;
}

.serviceArea{
  background: #b2b2b2;
}

.serviceTop{
  margin-top:50px;
  padding-bottom: 100px;
}

.serviceTop h2{
  color: #FFF;
}

.serviceTop h4{
  font-size: 1.8rem;
}

.listColumn{
  display: flex;
  justify-content: flex-start;
  align-items: stretch;
  flex-wrap: wrap;
  gap: 15px;
  margin: 50px auto 100px;
}

.worksList{
  display: flex;
  flex-direction: column;
  align-items: center;
  width: calc(100%/3 - 10px);
  border: 1px solid #FFF;
  background: #FFF;
}

.worksList .iconImg{
  width: 100%;
}

.worksList .iconImg img{
  object-fit: cover;
  height: 100%;
}

.listDesc{
  padding: 15px 20px;
  font-size: 1.2rem;
}

.listDesc h3{
  text-align: center;
  padding-bottom: 10px;
  font-size:1.6rem;
}

.sectionText div{
  padding-left: 16px;
  padding-bottom:25px;
}

.serviceText h3{
  text-align: center;
  font-size: 2.4rem;
  color:#000;
}

.moreBtn{
  display:flex;
  width: 100%;
}

.serviceArea .moreBtn{
  justify-content: center;
}

.moreBtn a{
  width: 250px;
  font-size:1.8rem;
  color:#FFF;
  background:#333;
  text-align: center;
  line-height: 1;
  padding: 20px 0;
}

.moreBtn a:hover{
  opacity:0.8;
}

.service .serviceBox{
  padding-left: 20%;
  margin-bottom:50px;
  display:flex;
  justify-content: space-between;
  flex-wrap:wrap;
  gap: 5px;
}

.description{
  width: calc(100%/2 - 5px);
  margin-bottom: 10px;
  border:1px solid #ccc;
}

.description h3{
  font-size: 2.4rem;
  padding:20px 25px;
}

.description p{
  padding:0 25px 25px 25px;
  line-height: 1.8;
}

.description p span{
  display: block;
}

.introBox{
  margin-top: 50px;
  margin-left: 25%;
  font-size: 1.8rem;
  line-height: 2;
}

.introBox span{
  display: block;
}

.company ul{
  margin-left: 25%;
}

.company ul li{
  display:flex;
  padding:30px 25px;
  border-bottom: 1px solid #eee;
}

.company ul li:first-child{
  padding-top: 0;
}

.company ul li div:first-child{
  width: 150px;
  margin-right:5%;
}

.googlemap{
  margin-left: 25%;
}

.googlemap iframe {
  width:100%;
  -webkit-filter: grayscale(100%);
  -moz-filter: grayscale(100%);
  -ms-filter: grayscale(100%);
  -o-filter: grayscale(100%);
  filter: grayscale(100%);
}

.contact iframe{
  display: block;
  margin: 50px auto;
  padding-top: 50px;
  height: 900px;
}

.privacy{
  margin: 50px 15% 50px 25%;
  font-size: 1.6rem;
  line-height: 2;
}

.privacy h3{
  padding-top: 25px;
}

.privacy p{
  padding-left: 15px;
}

.privacy a{
  text-decoration: underline;
}

.alignRight{
  padding-top: 100px;
  text-align: right;
}

.footerUper{
  margin-top:250px;
  height: 300px;
  background: url(../images/town.png)no-repeat center top/cover;
}

footer{
  background: #000;
  margin-top:0;
  padding: 30px 0 50px;
}

.footerContents{
  max-width: 1920px;
  margin: 0 auto;
}

.footerInner{
  color:#FFF;
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin: 0 10%;
  font-size: 1.2rem;
}

footer .logoArea{
  width: 150px;
  margin-bottom:15px;
  margin-left: -5px;
}

footer .copy{
  padding-bottom:10px;
}


.pc{display:block!important;}
.sp{display:none!important;}
@media screen and (max-width:768px){
  body {
    font-size: 1.4rem;
    min-width:320px;
    line-height:1.4;
    color: #000;
  }
  h1{
    text-align:center;
  }
  .logo{
    width:auto;
    height: 30px;
    margin:0 auto;
  }
  .to-top{
    bottom:80px;
    right:5px;
  }
  header{
    position: static;
    height: 0;
  }
  header .logoArea{
    width: 100%;
    margin: 0 auto;
    padding:10px 0;
    position: fixed;
    top: 0;
    z-index: 9;
  }
  .headerScroll .logoArea{
    background:rgba(255,255,255,0.9);
  }
  .headerInner{
    display: block;
    padding: 0;
  }


  header nav{
    position: fixed;
    left: 0;
    bottom: 0;
    letter-spacing: 1px;
    font-size: 1.2rem;
    background:#f5f5f5;
    z-index:9;
  }

  header nav a{
    color: #888;
  }

  .headerScroll nav a{
    color: #888;
    text-shadow:none;
  }

  header nav ul{
    justify-content: space-around;
    align-items: flex-end;
    column-gap: 5px;
    height: 55px;
    text-align: center;
  }
  .fa-solid{
    display: block;
    padding-bottom: 2px;
  }

  .catch{
    font-size: 6rem;
    letter-spacing: 6px;
  }

  section{
    padding: 50px 25px;
    margin: 0 auto;
  }

  .intro{
    padding-bottom: 25px;
  }

  section h2{
    font-size: 4rem;
    letter-spacing: 2px;
    padding-top: 0;
  }

  .contentsBox{
    display: block;
    margin-top:10px;
  }

  .contentsImg{
    width: 100%;
    max-height: 250px;
    aspect-ratio: 1;
  }

  .sectionTextBox{
    width: 100%;
    display: block;
  }

  .sectionText{
    margin: 0 auto 50px;
    padding: 0;
  }

  .sectionText h3{
    font-size: 1.8rem;
    padding: 30px 0;
  }

  .serviceTop{
    padding-bottom: 50px;
  }


  .serviceArea{
    margin-bottom: 100px;
  }

  .moreBtn{
    justify-content: center;
    margin-bottom: 50px;
  }

  .listColumn{
    display: block;
    margin: 50px auto;
  }

  .worksList .iconImg{
    height: 200px;
  }

  .worksList{
    display: block;
    width: 100%;
    margin-bottom: 25px;
  }

  .listDesc{
    padding: 15px 10px;
    font-size: 1.2rem;
  }

  .listDesc span{
    display: block;
  }

  .serviceArea .moreBtn{
    margin-bottom: 0;
  }

  .service .serviceBox{
    padding: 0;
    margin: 50px auto 0;
  }

  .serviceIntro{
    padding:0 0 50px;
    font-size: 1.6rem;
    line-height: 2;
  }

  .serviceIntro span{
    display: inline;
  }

  .description{
    width: 100%;
    margin-bottom: 20px;
    border: none;
  }

  .description h3{
    padding:20px 0;
  }

  .description p{
    padding:0 0 25px 0;
    line-height: 1.8;
  }

  .description p span{
    display: inline;
  }

  .introBox{
    margin: 50px auto;
    font-size: 1.6rem;
    line-height: 2;
    padding: 0 10px;
  }

  .introBox span{
    display: inline;
  }

  .company ul{
    margin: 50px auto;
  }

  .company ul li{
    display:flex;
    padding:30px 10px;
    border-bottom: 1px solid #eee;
  }

  .company ul li div:first-child{
    width: 80px;
    margin-right:5%;
  }

  .company ul li span{
    display: block;
  }

  .access{
    padding:25px;
  }

  .googlemap{
    margin: 50px auto;
  }

  .googlemap iframe{
    height: 250px;
  }

  .contact iframe{
    width: 100%;
    height: 1100px;
  }

  .privacy{
    margin: 50px auto 0;
    font-size: 1.6rem;
    line-height: 2;
  }

  .alignRight{
    padding-top: 30px;
  }

  .footerUper{
    margin-top:50px;
    height: 100px;
  }

  footer{
    margin: 0 auto 48px;
    padding: 10px 0 50px;
  }

  .footerInner{
    gap: 5px;
    margin: 10px 10% 0;
    font-size: 1.2rem;
  }

  footer .logoArea{
    width: 100px;
  }

  footer .logo{
    width: 100%;
    height: auto;
  }

  .pc{display:none!important;}
  .sp{display:block!important;}

}
