@charset "utf-8";
/*------------------------------------------------------------
     common
------------------------------------------------------------ */
.webfont {
  font-family: 'Open Sans', sans-serif;
}
.h2_wrap {
  text-align: center;
}
.h2_wrap h2 {
  display: inline-block;
  padding-left: 1em;
  position: relative;
  font-size: 26px;
  font-size: 2.6rem;
  letter-spacing: .1em;
}
.h2_wrap h2::before {
  content: "";
  display: block;
  width: 10px;
  height: 28px;
  background-color: #990000;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
/* page top */
#pageTop {
  position: fixed;
  bottom: 64px;
  right: 48px;
  z-index: 500
}
/* header
------------------------------------------------------------ */
#header {
  padding: 25px 0;
  background-color: #990000;
}
#header .logo {
  float: left;
  padding: 5px 0;
}
#header .to_contact {
  float: right;
  margin-right: -130px;
}
#header .to_contact a {
  display: block;
  padding: 10px 35px 10px 17px;
  background-color: #FFCF18;
  box-shadow: 0 3px #473002;
}
#header .to_contact a img + img {
  margin-left: 25px;
}
#header .to_contact a:hover {
  box-shadow: 0 0 #FFCF18;
  -webkit-transform: translateY(3px);
  transform: translateY(3px);
  opacity: 1.0;
}
/* container
------------------------------------------------------------ */
.container {
  width: 94%;
  max-width: 1080px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: auto;
}
/* side
------------------------------------------------------------ */

/* footer
------------------------------------------------------------ */


/*------------------------------------------------------------
     index
------------------------------------------------------------ */
/* main image */
.main_image {
  background: rgb(153,0,0);
  background: -moz-linear-gradient(top, rgba(153,0,0,1) 83%, rgba(255,255,255,1) 83%);
  background: -webkit-linear-gradient(top, rgba(153,0,0,1) 83%, rgba(255,255,255,1) 83%);
  background: linear-gradient(to bottom, rgba(153,0,0,1) 83%, rgba(255,255,255,1) 83%);
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#990000', endColorstr='#ffffff', GradientType=0 );
}
.main_image .container {
  max-width: 1440px;
}
/* about */
.about {
  padding-bottom: 35px;
  margin-top: -45px;
}
.about h1.logo {
  text-align: center;
  margin-bottom: 50px;
}
.about h1.logo img {
  max-width: 50%;
}
.about h1.logo span {
  display: block;
  font-size: 32px;
  font-size: 3.2rem;
  letter-spacing: .4em;
  margin-top: 25px;
}
.about h2 {
  margin-bottom: 10px;
  text-align: center;
  font-size: 20px;
  font-size: 2.0rem;
  font-weight: bold;
  letter-spacing: .1em;
}
.about .ment {
  font-size: 18px;
  font-size: 1.8rem;
  line-height: 1.777;
  letter-spacing: .1em;
  margin-bottom: 20px;
}
.contact_box .btn::after {
  content: "";
  display: block;
  clear: both;
}
.contact_box .btn li {
  float: left;
  width: 47.222%;
  margin-right: 5.556%;
  margin-bottom: 20px;
}
.contact_box .btn li:nth-child(2n) {
  margin-right: auto;
}
.contact_box .btn li a {
  display: block;
  box-shadow: 0 6px #473002;
}
.contact_box .btn li a:hover {
  -webkit-transform: translateY(6px);
  transform: translateY(6px);
  box-shadow: 0 0 #473002;
  opacity: 1.0;
}
.contact_box .tel {
  text-align: center;
  font-size: 30px;
  font-size: 3.0rem;
  font-weight: bold;
  letter-spacing: .1em;
}
.contact_box .tel a {
  display: inline-block;
  font-size: 48px;
  font-size: 4.8rem;
  transform: translateY(0.1em);
}
/* 施工事例 */
.works .h2_wrap {
  margin-bottom: 25px;
}
.works .slick-slide {
  margin: auto 2.5px 5px;
}
/* イベント情報 */
.event {
  padding: 45px 0;
  background-color: #F5F5F5;
}
.event .h2_wrap {
  margin-bottom: 45px;
}
.event .eyecatch, .event .box {
  float: left;
  width: 47.222%;
  margin-bottom: 25px;
}
.event .eyecatch {
  margin-right: 5.556%;
}
.event .data_wrap {
  padding: 3% 4% 1%;
  background-color: #FFF;
  margin-bottom: 40px;
}
.event .data_wrap h3 {
  padding: 2.5% 5% 2.5% 6%;
  background-color: #FFCF18;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: .1em;
  margin-bottom: 5px;
}
.event .data_wrap dl {
  padding: 12px 0;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: .1em;
}
.event .data_wrap dl::after {
  content: "";
  display: block;
  clear: both;
}
.event .data_wrap dl + dl {
  border-top: 1px dotted #AAA;
}
.event .data_wrap dl dt {
  float: left;
  width: 3.3em;
}
.event .data_wrap dl dt::after {
  content: "：";
}
.event .data_wrap dl dd {
  margin-left: 3.3em;
}
.event .to_conseling a {
  display: block;
  padding: 17px 24% 17px 45px;
  background-color: #9D020E;
  box-shadow: 0 6px #473002;
  position: relative;
  color: #FFF;
  font-size: 40px;
  font-size: 4.0rem;
  line-height: 1;
  letter-spacing: .1em;
}
.event .to_conseling a i {
  margin-right: 17px;
}
.event .to_conseling a .ment_img {
  line-height: 40px;
  vertical-align: middle;
}
.event .to_conseling a .hito {
  max-width: 24%;
  position: absolute;
  bottom: 0;
  right: 0;
}
.event .to_conseling a:hover {
  -webkit-transform: translateY(6px);
  transform: translateY(6px);
  box-shadow: 0 0 #473002;
  opacity: 1.0;
}
.event .to_event {
  text-align: right;
  font-size: 14px;
  font-size: 1.4rem;
  letter-spacing: .05em;
}
.event .to_event a i {
  margin-left: 9px;
}
/* 選ばれる５つの理由 */
.cause {
  padding: 75px 0 60px;
  background: url("img/flatstyle/img_cause.png"), #FFCF18;
  background-position: center right;
  background-repeat: no-repeat;
  background-size: contain;
}
.cause h2 {
  display: inline-block;
  padding-bottom: 5px;
  border-bottom: 3px solid #000;
  margin-bottom: 25px;
  font-size: 28px;
  font-size: 2.8rem;
  font-weight: bold;
  letter-spacing: .1em;
}
.cause ul {
  counter-reset: num;
  margin-bottom: 40px;
}
.cause ul li {
  padding-left: 60px;
  position: relative;
  font-size: 20px;
  font-size: 2.0rem;
  font-weight: bold;
  line-height: 40px;
  letter-spacing: .05em;
}
.cause ul li + li {
  margin-top: 20px;
}
.cause ul li::before {
  display: block;
  counter-increment: num;
  content: counter(num);
  position: absolute;
  top: 0;
  left: 0;
  width: 40px;
  background-color: #990000;
  text-align: center;
  color: #FFF;
  font-family: 'Open Sans', sans-serif;
  font-size: 24px;
  font-size: 2.4rem;
  font-weight: bold;
  line-height: 40px;
}
.cause ul li::after {
  content: "";
  display: block;
  clear: both;
}
.cause .to_contact a {
  display: inline-block;
  padding: 20px 30px 20px 24px;
  background-color: #990000;
  color: #FFF;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: bold;
  line-height: 1;
  letter-spacing: .1em;
}
.cause .to_contact a img {
  margin-right: 20px;
}
/* 厳選プラン */
.plan {
  padding: 140px 0 110px;
}
.plan h2 {
  text-align: center;
  margin-bottom: 15px;
}
.plan .considerations {
  text-align: center;
  font-size: 14px;
  font-size: 1.4rem;
  letter-spacing: .05em;
}
.plan ol {
  margin-bottom: 30px;
}
.plan ol > li + li {
  margin-top: 65px;
}
.plan .popularity {
  font-size: 36px;
  font-size: 3.6rem;
  font-weight: bold;
  letter-spacing: .05em;
  margin-bottom: 15px;
}
.plan .popularity span {
  color: #FFCF18;
}
.plan .data {
  padding: 15px 200px 10px 30px;
  background-color: #990000;
  position: relative;
}
.plan .data::after {
  content: "";
  display: block;
  clear: both;
}
.plan h3 {
  display: block;
  width: 180px;
  height: 180px;
  padding-top: 30px;
  background-color: #FFF;
  border: 3px solid #990000;
  border-radius: 50%;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 14px;
  margin: auto;
  color: #990000;
  text-align: center;
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 1.25;
  letter-spacing: .05em;
}
.plan h3 span {
  display: block;
  font-family: 'Open Sans', sans-serif;
  font-size: 30px;
  font-size: 3.0rem;
  font-weight: bold;
  margin-bottom: 5px;
}
.plan .data dl {
  float: left;
  color: #FFF;
  font-weight: bold;
  letter-spacing: .05em;
}
.plan .data dl:nth-child(2) {
  margin-right: 30px;
}
.plan .data dl:nth-child(3) {
  margin-right: 50px;
}
.plan .data dl:nth-child(4) {
  margin-right: 65px;
}
.plan .data dl dt {
  font-size: 14px;
  font-size: 1.4rem;
}
.plan .data dl dd {
  font-size: 20px;
  font-size: 2.0rem;
}
.plan .data dl:nth-child(2) dd {
  font-size: 24px;
  font-size: 2.4rem;
}
.plan .image {
  float: left;
  width: 53.703%;
}
.plan .detail {
  float: left;
  width: 46.297%;
  padding: 50px 0 0 15px;
}
.plan .box {
  position: relative;
}
.plan .price {
  position: absolute;
  top: 0;
  right: 0;
  font-size: 30px;
  font-size: 3.0rem;
  line-height: 1;
}
.plan .price span {
  margin-right: 5px;
  font-family: 'Open Sans', sans-serif;
  font-size: 64px;
  font-size: 6.4rem;
  font-weight: bold;
  letter-spacing: -.05em;
}
.plan .price::after {
  content: "(税抜)";
  position: absolute;
  top: 5px;
  right: -5px;
  font-size: 24px;
  font-size: 2.4rem;
}
.plan .detail ul li {
  font-size: 22px;
  font-size: 2.2rem;
  letter-spacing: .05em;
}
.plan .detail ul li::before {
  content: "■";
}
.plan .detail ul li:nth-child(-n+2) {
  padding-right: 210px;
}
.plan .counseling_party {
  margin: 85px auto 120px;
}
/* 店舗情報 */
.company {
  margin-bottom: 100px;
}
.company .h2_wrap {
  margin-bottom: 45px;
}
.company .box, .company .map {
  float: left;
  width: 47.222%;
}
.company .box {
  margin-right: 5.556%;
}
.company figure {
  margin-bottom: 30px;
}
.company dl {
  font-size: 15px;
  font-size: 1.5rem;
  letter-spacing: .1em;
  margin-bottom: 10px;
}
.company dl dt, .company dl dd {
  display: inline-block;
}

@media screen and (max-width: 1440px) {
/* header
------------------------------------------------------------ */
#header .to_contact {
  margin-right: auto;
}
/*------------------------------------------------------------
     index
------------------------------------------------------------ */
/* 厳選プラン */
.plan .detail ul li {
  font-size: 20px;
  font-size: 2.0rem;
}
}

/*==========================================================
      Target Devices # Tablet MobilePC #
============================================================ */
@media screen and (max-width: 1120px) {
/*------------------------------------------------------------
     common
------------------------------------------------------------ */
.tab {
  display: block;
}
/*------------------------------------------------------------
     index
------------------------------------------------------------ */
/* イベント情報 */
.event .to_conseling a {
  text-align: center;
  font-size: 30px;
}
.event .to_conseling a .ment_img {
  width: 200px;
}
/* 選ばれる５つの理由 */
.cause {
  background-size: cover;
}
/* 厳選プラン */
.plan .image, .plan .detail {
  float: none;
  width: 100%;
}
.plan .image img {
  width: 100%;
}
}

@media screen and (max-width: 960px) {
/*------------------------------------------------------------
    index 
------------------------------------------------------------ */
/* about */
.about {
  margin-top: -20px;
}
.about h1.logo span {
  font-size: 28px;
  font-size: 2.8rem;
}
/* イベント情報 */
.event .eyecatch {
  text-align: center;
}
.event .eyecatch, .event .box {
  float: none;
  width: 100%;
  margin-right: auto;
}
/* 選ばれる５つの理由 */
.cause {
  background: #FFCF18;
}
}

/*==========================================================
      Target Devices # Smart Phone and Tablet #
============================================================ */
@media screen and (max-width: 768px) {
/*------------------------------------------------------------
     common
------------------------------------------------------------ */
.h2_wrap {
  text-align: left;
}
/* header
------------------------------------------------------------ */
#header .logo {
  max-width: 80%;
}
#header .to_contact a {
  padding: 10px;
}
#header .to_contact .img_ment {
  display: none;
}
/*------------------------------------------------------------
     index
------------------------------------------------------------ */
/* about */
.about .ment {
  text-align: left;
}
.about .ment br.tab {
  display: none;
}
/* contact_box */
.contact_box .btn li {
  float: none;
  width: 100%;
  max-width: 510px;
  margin: 0 auto 20px;
}
.contact_box .tel {
  font-size: 20px;
  font-size: 2.0rem;
}
.contact_box .tel a {
  font-size: 34px;
  font-size: 3.4rem;
}
/* 厳選プラン */
.plan .data {
  padding-top: 80px;
  padding-right: 30px;
}
.plan h3 {
  top: -60px;
  bottom: auto;
}
.plan .data dl:nth-child(2) {
  float: none;
  margin-right: auto;
}
/* 店舗情報 */
.company .box, .company .map {
  float: none;
  width: 100%;
  margin-right: auto;
}
.company .box {
  margin-bottom: 50px;
}
.company .map iframe {
  height: 300px;
}
}

/*==========================================================
      Target Devices # Smart Phone #
============================================================ */
@media screen and (max-width: 600px) {
  .plan .considerations {
    text-align: left;
  }
}

/*==========================================================
      Target Devices # Smart Phone #
============================================================ */
@media screen and (max-width: 550px) {
/*------------------------------------------------------------
     index
------------------------------------------------------------ */
/* about */
.about h1.logo img {
  max-width: 70%;
}
.about h1.logo span {
  font-size: 20px;
}
/* イベント情報 */
.event .to_conseling a {
  padding-left: 20px;
}
/* 厳選プラン */
.plan .data {
  padding-top: 30px;
}
.plan h3 {
  width: 140px;
  height: 140px;
  padding-top: 15px;
}
}

/*==========================================================
      Target Devices # Smart Phone Only #
============================================================ */
@media screen and (max-width: 479px) {
/*------------------------------------------------------------
     index
------------------------------------------------------------ */
/* イベント情報 */
.event .to_conseling a {
  font-size: 24px;
  white-space: nowrap;
}
.event .to_conseling a i {
  margin-right: 10px;
}
.event .to_conseling a .ment_img {
  width: 175px;
}
/* 選ばれる５つの理由 */
.cause .to_contact a {
  padding: 20px 15px;
}
/* 厳選プラン */
.plan .popularity {
  margin-bottom: 55px;
}
.plan .data {
  padding-left: 10px;
  padding-right: 10px;
}
.plan h3 {
  right: 5px;
}
.plan .price {
  display: inline-block;
  position: relative;
  margin-bottom: 5px;
}
.plan .detail ul li:nth-child(-n+2) {
  padding-right: 0;
}
}
