@charset "utf-8";

/*------------  reset  ------------*/
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote,
pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small,
strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label,
legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside,
canvas, details, figcaption, figure, footer, header, hgroup, menu, nav,
section, main, summary, time, mark, audio, video, a, button, input, select,
textarea { margin: 0; padding: 0; }
address,caption,cite,code,dfn,em,strong,th,var { font-style: normal; }
form { margin: 0; padding: 0; }
li { list-style-type: none; }
table { border-collapse: collapse; border-spacing: 0; }
caption,th { text-align: left; }
q:before,q:after { content:''; }
object,embed { vertical-align: top; }
hr,legend { display: none; }
h1,h2,h3,h4,h5,h6 { font-size: 100%; }
abbr,acronym,fieldset { border: 0; }
img { border: none; max-width: 100%; vertical-align: bottom; }

a { text-decoration:none; opacity: 1; transition: all .3s; cursor: pointer; }
a:hover { text-decoration: none; opacity: .5; }

html { font-size: 62.5%; }
body { height: 100%; min-height: 100%; min-width: 320px; font-size: 1.5em; line-height: 1; font-family: sans-serif; color: #000; -webkit-font-smoothing: antialiased; -webkit-text-size-adjust: 100%; }
#wrapper { position: relative; z-index: 1; }
#loading { background: #fff; margin: 0; padding: 0; width: 100%; height: 100%; position: fixed; top: 0; left: 0; z-index: 100; overflow: hidden; }



/*------------  header  ------------*/
#header { padding: 110px 6% 140px; }
#header .header_inner { display: flex; margin: 0 auto; max-width: 1080px; }
#header .main { flex-basis: 40%; box-sizing: border-box; padding: 0 1%; }
#header .logo { width: 270px; }
#header .intro { flex-basis: 60%; box-sizing: border-box; }
#header .intro .copy { font-size: 5.2rem; font-weight: 500; font-family: 'Roboto', sans-serif; font-feature-settings: "palt"; letter-spacing: .3rem; }
#header .intro .title { padding: 16px 0 0; font-size: 2rem; font-weight: 700; font-family: 'Noto Sans JP', sans-serif; font-feature-settings: "palt"; letter-spacing: .15rem; }
#header .intro .txt { padding: 40px 0 0; font-size: 1.6rem; line-height: 1.9; font-weight: 500; font-family: 'Noto Sans JP', sans-serif; letter-spacing: .05rem; }
#header .intro .pic { padding: 60px 0 0; }


/*------------  content  ------------*/
.content { padding: 0 6% 130px; }
.content .content_inner { margin: 0 auto; max-width: 1080px; }
.content .title { padding: 0 0 4.8rem; font-size: 3.5rem; font-weight: 500; font-family: 'Roboto', sans-serif; font-feature-settings: "palt"; letter-spacing: .15rem; }
.content .title .sub { display: block; padding: 12px 0 0; font-size: 1.8rem; font-weight: 700; font-family: 'Noto Sans JP', sans-serif; }


/*------------  service  ------------*/
.service { display: flex; justify-content: space-between; }
.service .block { flex-basis: 29%; }
.service .pic { padding: 1rem 0 4.4rem; }
.service .ttl { padding: 0 0 2.2rem; font-size: 2rem; font-weight: 700; font-family: 'Noto Sans JP', sans-serif; font-feature-settings: "palt"; letter-spacing: .1rem; }
.service .txt { line-height: 1.6; }
.service .txt .item { position: relative; padding: 0 0 1rem 10px; }
.service .txt .item::before { content: "-"; position: absolute; top: 0; left: 0; }


/*------------  company  ------------*/
.company { padding: 100px 6% 130px; background: #f4f4f4; }
.company .summary { margin: 0 auto; line-height: 1.6; }
.company .summary .item { display: flex; position: relative; padding: 24px 4%; border-bottom: 1px solid #ddd; }
.company .summary .item:first-child { border-top: 1px solid #ddd; }
.company .summary .type { flex-basis: 18%; font-weight: bold; }
.company .summary .data { flex-basis: 82%; position: relative; }
.company .summary .position { display: inline-block; width: 7em; }
.company .summary .btn { display: block; position: absolute; top: 50%; right: 4%; transform: translate(0,-50%); width: 84px; }
.company .summary .btn .btn_map { display: flex; justify-content: center; align-items: center; height: 34px; background: #000; font-size: 1.3rem; line-height: 1; font-weight: 500; font-family: 'Roboto', sans-serif; color: #fff; border-radius: 3px; }
.company .summary .btn .btn_map .label { position: relative; padding: 0 4px 0 17px; }
.company .summary .btn .btn_map .label::after { content:""; position: absolute; top: 50%; left: 0; transform: translate(0,-48%); width: 12px; height: 16px; background: url('/images/icon_map.png') no-repeat; background-size: contain; }

.contact { margin: 0 auto; padding: 50px 0 0; width: 320px; }
.contact .btn_contact { display: flex; justify-content: center; align-items: center; height: 54px; background: #000; font-size: 1.4rem; line-height: 1; font-weight: 700; font-family: 'Noto Sans JP', sans-serif; color: #fff; border-radius: 3px; }
.contact .btn_contact .label { position: relative; padding: 0 4px 0 26px; }
.contact .btn_contact .label::after { content:""; position: absolute; top: 50%; left: 0;  transform: translate(0,-48%);  width: 16px; height: 14px; background: url('/images/icon_contact.png') no-repeat; background-size: contain; }


/*------------  footer  ------------*/
#footer { padding: 60px 0 80px; }
#footer .footer_logo { margin: 0 auto; padding: 0 0 30px; width: 124px; }
#footer .copyright { font-size: 1.4rem; text-align: center; }







@media screen and (max-width: 1020px) {

  #header { padding: 90px 6% 120px; }
  #header .main { flex-basis: 42%; }
  #header .logo { width: 230px; }
  #header .intro { flex-basis: 58%; }
  #header .intro .copy { font-size: 4.6rem; }
  #header .intro .title { padding: 14px 0 0; font-size: 1.8rem; }
  #header .intro .txt { padding: 35px 0 0; font-size: 1.5rem; }
  #header .intro .pic { padding: 50px 0 0; }

  .content { padding: 0 6% 110px; }
  .content .title { padding: 0 0 4rem; font-size: 3rem; }
  .content .title .sub { padding: 12px 0 0; font-size: 1.7rem; }

  .service .ttl { font-size: 1.8rem; }
  .service .txt { font-size: 1.4rem; }

  .company { padding: 80px 6% 110px; font-size: 1.4rem; }
  .company .summary .item { padding: 15px 2%; }

  .contact { padding: 40px 0 0; }

  #footer .footer_logo { padding: 0 0 20px; width: 110px; }
  #footer .copyright { font-size: 1.4rem; }
}






@media screen and (max-width: 780px) {

  a { transition: all 0s; }
  a:hover {  opacity: 1; }

  /*------------  header  ------------*/
  #header { padding: 70px 6% 70px; }
  #header .header_inner { flex-direction: column; }
  #header .main { flex-basis: 100%; padding: 0 0 70px; }
  #header .logo { margin: 0 auto; width: 200px; }
  #header .intro { flex-basis: 100%; }
  #header .intro .copy { font-size: 3rem; }
  #header .intro .title { padding: 10px 0 0; font-size: 1.5rem; }
  #header .intro .txt { padding: 24px 0 0; font-size: 1.4rem; line-height: 1.8; }
  #header .intro .pic { padding: 32px 0 0; }

  /*------------  content  ------------*/
  .content { padding: 0 6% 60px; }
  .content .title { padding: 0 0 30px; font-size: 2.4rem; }
  .content .title .sub { padding: 8px 0 0; font-size: 1.5rem; }

  /*------------  service  ------------*/
  .service { flex-direction: column; justify-content: center; margin: 0 auto; max-width: 420px; }
  .service .block { flex-basis: 100%; padding: 0 0 36px; }
  .service .block:last-child { padding: 0; }
  .service .pic { padding: 4px 2% 28px; }
  .service .ttl { padding: 0 0 18px; font-size: 1.6rem; }
  .service .txt { font-size: 1.3rem; }
  .service .txt .item { padding: 0 0 6px 10px; }

    /*------------  company  ------------*/
  .company { padding: 35px 7% 60px; font-size: 1.3rem; }
  .company .summary .item { flex-direction: column; padding: 18px 0; }
  .company .summary .type { flex-basis: 100%; padding: 0 0 6px; }
  .company .summary .data { flex-basis: 100%; }
  .company .summary .btn { position: relative; top: 0; right: 0; transform: translate(0,0); margin: 12px 0 0 auto; }
  .company .summary .btn .btn_map { height: 34px; font-size: 1.3rem; }

  .contact { padding: 30px 0 0; width: 250px; }
  .contact .btn_contact { height: 46px; font-size: 1.3rem; }

  /*------------  footer  ------------*/
  #footer { padding: 30px 0; }
  #footer .footer_logo { padding: 0 0 18px; width: 100px; }
  #footer .copyright { font-size: 1.3rem; }

}



