@charset "UTF-8";
/* ----------------------------------------------- CSS Information
 Style Info:     トップページ
 Notes:          
--------------------------------------------------------------- */
section.main {
  padding: 5.5em 0 0;
  position: relative;
  line-height: 0;
}
.main .txt-box {
  width: 10%;
  max-height: 90%;
  position: absolute;
  top: 20%;
  right: 17%;
  color: #FFF;
  /*
  writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
  */
}
section.works {
  padding: 12em 0 5%;
  position: relative;
  background: #EFEFEF;
}
h1.section-title {
  position: absolute;
  top: 0;
  left: 0;
  font-size: 10em;
  line-height: 0.7;
}
h2.section-title {
  width: 70%;
  margin: 0 0 5% auto;
  padding: 0 0 0 3%;
  font-size: 1.8em;
  font-weight: bold;
  line-height: 1;
  border-bottom: 1px solid #000;
}
h2.section-title .color01 {
  color: #FF8000;
}
.slick-list {
  height: 50vw;
}
/* =============================== */
.slick-slide {
  transition: .3s ease;
  transform: scale(.60);
  transform-origin: 120% 15%;
}
.slick-current {
  transform: scale(.65);
  transform-origin: 50% 0%;
}
.slick-current + .slick-slide {
  transform-origin: -20% 15%;
}
.slick-cloned {
  width: 90%;
}
.slider{
  opacity: 0;
  transition: 3s;
}
.slick-initialized{
  opacity: 1
}
.slick-prev {
  padding: 0 2em 0 1.5em;
  position: absolute;
  top: 60%;
  left: 17%;
  z-index: 2;
	text-shadow: 0 0 0.5em #FFF;
}
.slick-prev::before {
  content: '';
  width: 1em;
  height: 3px;
  position: absolute;
  bottom: 20%;
  left: 0;
  background: #000;
  transform: skewY(-40deg);
  z-index: 2;
}
.slick-prev::after {
  content: '';
  width: 100%;
  height: 3px;
  position: absolute;
  bottom: 0;
  left: 0;
  background: #000;
  z-index: 2;
}
.slick-next {
  padding: 0 1.5em 0 2em;
  position: absolute;
  top: 60%;
  right: 17%;
  z-index: 2;
  text-shadow: 0 0 0.5em #FFF;
}
.slick-next::before {
  content: '';
  width: 1em;
  height: 3px;
  position: absolute;
  bottom: 20%;
  right: 0;
  background: #000;
  transform: skewY(40deg);
  z-index: 2;
}
.slick-next::after {
  content: '';
  width: 100%;
  height: 3px;
  position: absolute;
  bottom: 0;
  right: 0;
  background: #000;
  z-index: 2;
}
.slick-arrow:hover {
  color: #FF8000;
}
.slick-arrow:hover::before {
  content: '';
  background: #FF8000;
}
.slick-arrow:hover::after {
  content: '';
  background: #FF8000;
}
/* =============================== */
/* ================ */
#slick {
  margin: 0 auto;
}
#slick .slide {
  /* padding: 0 5%; */
}
.main-image {
  height: 55vw;
  margin: 0 auto 5%;
  box-shadow: 1.7em 1.7em 0 0 #FFDABB, -1.7em 1.7em 0 0 #FFDABB;
}
.main-image img {
  width: 100%;
}
.works .title {
  font-size: 2.3em;
}
.works .txt {
  font-size: 1.5em;
}
/* ================ */
.works .button {
  width: 15em;
  margin: 0 auto;
  position: relative;
  text-align: center;
  clear: both;
}
.works .button a::after {
  content: '\00203a';
  width: 0.5em;
  height: 1em;
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 0.5em;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
  font-size: 2em;
  line-height: 1;
}
.works .button a {
  padding: 1em 0;
  display: block;
  border: 1px solid #000;
}
section.service {
  padding: 12em 0 5%;
  position: relative;
}
.service .wrap {
  margin: 0 auto 3%;
  display: flex;
  justify-content: space-between;
}
.service .box01 {
  width: 55%;
}
.service .box02 {
  width: 30%;
  margin: 0 10% 0 0;
}
.service div.title {
  font-size: 1.5em;
  margin: 5% 0;
}
.service .txt {
  margin: 0 auto 5%;
}
.service .more {
  width: 6em;
  position: relative;
}
.service .more a {
  padding: 0 0 0 2em;
}
.service .more a::before {
  content: '';
  width: 1em;
  height: 3px;
  position: absolute;
  bottom: 20%;
  right: 0;
  background: #000;
  transform: skewY(40deg);
  z-index: 2;
}
.service .more a::after {
  content: '';
  width: 100%;
  height: 3px;
  position: absolute;
  bottom: 0;
  right: 0;
  background: #000;
  z-index: 2;
}
.service .more a:hover {
  color: #FF8000;
}
.service .more a:hover::before {
  content: '';
  background: #FF8000;
}
.service .more a:hover::after {
  content: '';
  background: #FF8000;
}
section.wood {
  position: relative;
}
.wood .wrap {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(0);
  -webkit- transform: translateY(-50%) translateX(0);
  color: #FFF;
}
.wood .title {
  margin: 0 auto 5%;
  font-size: 4.7em;
  line-height: 1.2;
}
.wood .txt {
  margin: 0 auto 15%;
  font-size: 1.3em;
}
.wood .button {
  width: 15em;
  margin: 0 auto;
  position: relative;
  text-align: center;
}
.wood .button a::after {
  content: '\00203a';
  width: 0.5em;
  height: 1em;
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 0.5em;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
  font-size: 2em;
  line-height: 1;
}
.wood .button a {
  padding: 1em 0;
  display: block;
  color: #FFF;
  border: 1px solid #FFF;
}
section.company {
  padding: 5% 0;
}
.company .wrap {
  width: 70%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
.company .box01 {
  width: 47%;
  position: relative;
  order: 2;
}
.company .box02 {
  width: 47%;
  margin: 10% 0 0;
  position: relative;
  order: 1;
}
.company a {
  display: block;
}
.company .box01 .txt01 {
  position: absolute;
  top: -1.7em;
  left: 0;
  font-size: 1.5em;
}
.company .box01 .txt02 {
  position: absolute;
  top: -1.1em;
  right: 0;
  font-size: 2.5em;
}
.company .box02 .txt01 {
  position: absolute;
  top: -1.7em;
  right: 0;
  font-size: 1.5em;
}
.company .box02 .txt02 {
  position: absolute;
  top: -1.1em;
  left: 0;
  font-size: 2.5em;
}
.company img {
  border: 0.3em solid #FF8000;
}
.company .box01 img {
  box-shadow: 15.5em -3em 0 #FFDABB, 25.5em -3em 0 #FFDABB;
}
.company .box02 img {
  box-shadow: -15.5em 2em 0 #FFDABB, -25.5em 2em 0 #FFDABB;
}
section.blog {
  position: relative;
}
.blog .wrap {
  width: 55%;
  margin: 0 auto;
  padding: 3%;
  box-sizing: border-box;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit- transform: translateY(-50%) translateX(-50%);
  background: rgba(255,255,255,.2);
  border: 0.3em solid #FF8000;
}
.blog .txt01 {
  position: absolute;
  top: -2em;
  right: 0;
  font-size: 1.5em;
}
.blog .txt02 {
  position: absolute;
  top: -1.2em;
  left: 0.3em;
  font-size: 4em;
}
.blog .article {
  border-bottom: 1px solid #000;
}
.blog .article:last-child {
  border-bottom: none;
}
.blog .article a {
  padding: 0.5em;
  display: flex;
  flex-wrap: wrap;
  white-space: nowrap;
  overflow: hidden;
  -o-text-overflow: ellipsis;
  text-overflow: ellipsis;
}
.blog .article a:hover {
  background: rgba(255,255,255,.8);
}
.blog .day {
  width: 15%;
  text-align: center;
}
.blog .cat {
  width: 25%;
  text-align: center;
}
.blog .headline {
  width: 60%;
}
section.link {
  padding: 3% 0;
}
.link h2.title {
  margin: 0 auto 1%;
  text-align: center;
  font-size: 3em;
}
.link .wrap {
  width: 55%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.link .banner {
  width: 49%;
  margin: 0 0 2%;
  line-height: 0;
}
.link .banner img{
width: 100%;
}

/* ================= smartphone ================= */
@media only screen and (max-width:699px) {
section.main {
  padding: 0;
}
.main .txt-box {
  width: 50%;
  top: 0.9em;
	right: 20%;
  filter: drop-shadow(0 0 5px #000);
}
h1.section-title {
  font-size: 5em;
}
section.works {
  padding: 20% 0 10%;
}
.slick-list {
  height: auto;
  margin: 0 auto 5%;
}
/* =============================== */
.slick-slide {
  transition: .3s ease;
  transform: scale(1);
  transform-origin: 100% 0%;
}
.slick-current {
  transform: scale(1);
  transform-origin: 100% 0;
}
.slick-current + .slick-slide {
  transform-origin: 0% 100%;
}
.slick-center {
  width: 100%;
}
.slider{
  opacity: 0;
  transition: 3s;
}
.slick-initialized{
  opacity: 1
}
.slick-prev {
  padding: 0 2em 0 1.5em;
  position: absolute;
  top: 40%;
  left: 5%;
  z-index: 2;
}
.slick-prev::before {
  content: '';
  width: 1em;
  height: 3px;
  position: absolute;
  bottom: 20%;
  left: 0;
  background: #000;
  transform: skewY(-40deg);
  z-index: 2;
}
.slick-prev::after {
  content: '';
  width: 100%;
  height: 3px;
  position: absolute;
  bottom: 0;
  left: 0;
  background: #000;
  z-index: 2;
	text-shadow: 0 0 0.5em #FFF;
}
.slick-next {
  padding: 0 1.5em 0 2em;
  position: absolute;
  top: 40%;
  right: 5%;
  z-index: 2;
  text-shadow: 0 0 0.5em #FFF;
}
.slick-next::before {
  content: '';
  width: 1em;
  height: 3px;
  position: absolute;
  bottom: 20%;
  right: 0;
  background: #000;
  transform: skewY(40deg);
  z-index: 2;
}
.slick-next::after {
  content: '';
  width: 100%;
  height: 3px;
  position: absolute;
  bottom: 0;
  right: 0;
  background: #000;
  z-index: 2;
}
/* =============================== */
/* ================ */
#slick {
  margin: 0 auto;
}
#slick .slide {
  padding: 0 5%;
}
.main-image {
  height: 55vw;
  margin: 0 auto 5%;
  box-shadow: 10px 10px 0 0 #FFDABB, -10px 10px 0 0 #FFDABB;
}
.main-image img {
  width: 100%;
}
.works .title {
  font-size: 18px;
}
.works .txt {
  font-size: 14px;
}
/* ================ */
h2.section-title {
  font-size: 18px;
}
section.service {
  padding: 20% 0 10%;
}
.service .wrap {
  margin: 0 auto 3%;
  display: block;
}
.service .box01 {
  width: 90%;
  margin: 0 auto;
}
.service .box02 {
  width: 90%;
  margin: 0 auto;
}
.service .more {
  margin: 0 0 10% auto;
}
.wood .wrap {
  top: 5%;
  left: 5%;
  transform: none;
}
.service div.title {
  margin: 0;
  font-size: 18px;
}
.wood .title {
  font-size: 30px;
}
.wood .txt {
  margin: 0 auto 1%;
  font-size: 12px;
  line-height: 1.5;
}
section.company {
  padding: 10% 0;
}
.company .wrap {
  width: 90%;
  display: block;
}
.company .box01 {
  width: 100%;
  order: unset;
}
.company .box01 img {
  box-shadow: 1em 1em 0 #FFDABB;
}
.company .box01 .txt01 {
  right: 0;
  left: auto;
  font-size: 16px;
}
.company .box01 .txt02 {
  left: 0;
  font-size: 27px;
}
.company .box02 {
  width: 100%;
  order: unset;
}
.company .box02 img {
  box-shadow: -1em 1em 0 #FFDABB;
}
.company .box02 .txt01 {
  font-size: 16px;
}
.company .box02 .txt02 {
  font-size: 27px;
}
section.blog {
  overflow: hidden;
}
.blog .bg {
  width: 250%;
  margin: 0 0 0 -50%;
}
.blog .wrap {
  width: 90%;
  border: 0.3em solid #FF8000;
}
.blog .day {
  width: 30%;
  text-align: left;
}
.blog .cat {
  width: 65%;
  text-align: left;
}
.blog .headline {
  width: 100%;
}
.blog .txt01 {
  font-size: 15px;
}
.blog .txt02 {
  font-size: 30px;
}
.blog .article a {
  padding: 0;
  font-size: 13px;
}
.link .wrap {
  width: 90%;
}
.link h2.title {
  font-size: 30px;
}

.wood .button a {
    padding: 0.3em 0;

}
}