@charset "UTF-8";

/* ------------------------------------------------------------------
reset
------------------------------------------------------------------*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-style: normal;
  font-weight: normal;
  font-size: 100%;
  vertical-align: baseline;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}
input, textarea,{
  margin: 0;
  padding: 0;
}
ol, ul{
    list-style: none;
}
caption, th{
    text-align: left;
}
/* clearfix */
.cf {
  zoom: 1;
}
.cf:before, .cf:after {
  content: "";
  display: table;
}
.cf:after {
  clear: both;
}
html,body {
  width: 100%;
  font-size: 15px;
  font-family: Verdana, Roboto, "ヒラギノ角ゴ ProN W3", "Droid Sans", "游ゴシック", YuGothic, "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
}
input[type="submit"],
input[type="reset"],
input[type="button"],
button {
    cursor: pointer;
    -webkit-appearance: button;
    *overflow: visible;
}
input[type="text"], textarea, input[type="submit"]{
  -webkit-appearance: none;
}
.mt_0 {
  margin-top: 0 !important;
}

/* ------------------------------------------------------------------
320px 〜 768px
------------------------------------------------------------------*/
@media screen and (min-width:320px) {
  .inner {
    padding: 2%;
  }
  .sp_header {
    border-bottom: solid 1px #f2f2f2;
  }
  .kv_sp {
    max-width: 100%;
    line-height: 0;
    padding-top: 56px;
  }
  .kv_sp img {
    width: 100%;
  }
  .kv_pc {
    display: none;
  }
  .pc_header {
    display: none;
  }
  #logo {
    max-width: 135px;
    position: fixed;
    top: 6px;
    left: 2%;
    z-index: 1000000;
  }
  #logo img {
    width: 100%;
  }
  .title {
    padding-top: 90px;
    font-size: 161.5%;
    font-weight: bold;
    letter-spacing: 1px;
    text-align: center;
    position: relative;
    margin-bottom: 1em;
  }
  .title:before {
    content: '';
    position: absolute;
    bottom: -15px;
    display: inline-block;
    width: 60px;
    height: 1px;
    left: 50%;
    -moz-transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    background-color: black;
    border-radius: 2px;
  }
  .gnav {
    display: none;
  }
  .trouble {
    max-width: 100%;
    margin: 5% 0;
  }
  .trouble img {
    width: 100%;
  }
  /* block1 */
  .block1 {
    background: url(../images/bg_block1.jpg) no-repeat 0 0;
    background-size: cover;
  }
  .block1_text {
    max-width: 100%;
  }
  .block1_text img {
    width: 100%;
  }
  .block_text {
    margin: 5% 0;
  }
  .block_text p {
    margin-top: 5%;
  }
  .block_text ul {
    margin: 4% 0;
  }
  .to_contact a {
    display: block;
    width: 80%;
    height: 38px;
    line-height: 38px;
    text-align: center;
    margin: 5% auto 8%;
  }
  .to_contact a:link {
    text-decoration: none;
    color: #fff;
    background: #2394f7;
    border: 1px solid #2394f7;
  }
  .to_contact a:visited {
    text-decoration: none;
    color: #fff;
    background: #2394f7;
    border: 1px solid #2394f7;
  }
  .to_contact a:hover {
    text-decoration: none;
    color: #2394f7;
    background: #fff;
    border: 1px solid #2394f7;
  }
  /* alert */
  .alert_title {
    max-width: 100%;
  }
  .alert_title img {
    width: 100%;
  }
  /* block2 */
  .block2 {
    padding-bottom: 5%;
  }
  .block2 .inner {
    padding-top: 0;
  }
  .reason_text {
    font-size: 116%;
    font-weight: bold;
    text-align: center;
    margin-top: 45px;
  }
  .block_welcome {
    background: #fafafa;
  }
  .block_welcome .title {
    padding-top: 40px;
  }
  .block_welcome p {
    font-size: 116%;
    font-weight: bold;
    text-align: center;
    margin: 30px 0;
  }
  .about {
    margin-top: 10%;
  }
  .reason_box {
    max-width: 100%;
  }
  .reason_box img {
    width: 100%;
  }
  .slide_box img {
    height: auto;
    max-width: 100%;
    margin-bottom: 5%;
  }
  .block4 {
    background: #fafafa;
    padding-bottom: 5%;
  }

  .about_box {
    width: 350px;
    margin: 20px auto 0;
  }
  .about_image {
    max-width: 100%;
  }
  .about_image img {
    width: 100%;
  }
  .about_text {
    font-size: 116%;
    margin-top: 5%;
  }
  /* sale */
  .sale_image {
    max-width: 100%;
    margin: 5% 0;
  }
  .sale_image img {
    width: 100%;
  }
  /* block3 */
  .block3 {
    padding: 5% 0;
  }
  .block3 .inner {
    position: relative;
  }
  .subtitle {
    position: relative;
    border-bottom: 1px solid #ccc;
    font-size: 123.1%;
    width: 100%;
    margin: 20px 0;
  }
  .subtitle::after {
    position: absolute;
    top: 26px;
    left: 0;
    z-index: 2;
    content: '';
    width: 20%;
    height: 3px;
    background-color: #333;
  }
  .block3 .more {
    margin-top: 5%;
    text-align: center;
  }
  .block3 .more a:link {
    color: #2394f7;
  }
  .block3 .more a:visited {
    color: #2394f7;
  }
  .block3 .more a:hover {
    text-decoration: none;
  }
  .block3_image {
    max-width: 100%;
    margin: 5% 0;
  }
  .block3_image img {
    width: 100%;
  }
  /* block4 */
  .block4 .sp {
    max-width: 100%;
    margin: 8% 0 5%;
  }
  .block4 .sp img {
    width: 100%;
  }
  .block4 .pc {
    display: none;
  }
  /* block5 */
  .block5 {
    padding: 5% 0;
  }
  .block5 p {
    margin: 5% 0 2%;
  }
  /* block6 */
  .block6 {
    background: url(../images/paper2.png);
    padding-bottom: 5%;
  }
  /* footer */
  .footer {
    background: #fff;
    padding: 2% 0;
    overflow: hidden;
  }
  .footer .logo {
    max-width: 177px;
  }
  .footer .logo img {
    width: 100%;
  }
  .footer dl {
    margin: 5% 0;
  }
  .footer dt {
    font-weight: bold;
    font-size: 1.1rem;
  }
  .footer ul {
    overflow: hidden;
    margin-top: 2%;
  }
  .footer ul li {
  }
  .footer ul li:first-child {
    margin-left: 0;
  }
  .footer ul li a:link {
    color: #232323;
    text-decoration: none;
  }
  .footer ul li a:visited {
    color: #232323;
    text-decoration: none;
  }
  .footer ul li a:hover {
    color: #232323;
    text-decoration: underline;
  }
  .copy {
    background: #3d5c82;
    text-align: center;
    padding: 10px 0;
    color: #fff;
  }
  .slide_in {
    background: #aaa;
    display: block;
    position: fixed;
    right: -300px;
    bottom: 50px;
    text-align: center;
    width: 300px;
    background: #fff;
    border: solid 1px #f2f2f2;
  }
  .slide_in h3 {
    height: 60px;
    color: #fff;
    font-size: 108%;
    font-weight: bold;
    background: #2e3947;
    padding-top: 15px;
  }
  .slide_in p {
    text-align: left;
    margin: 20px 0;
    padding: 0 5px;
  }
  .slide_in .btn {
    overflow: hidden;
  }
  .slide_in h4 {
    font-size: 108%;
    text-align: center;
    font-weight: bold;
  }
  .btn_right a {
    display: block;
    height: 40px;
    font-size: 108%;
    line-height: 40px;
    background: #2394f7;
  }
  .slide_btn1 {
    width: 140px;
    float: left;
    margin-left: 5px;
  }
  .slide_btn2 {
    width: 96%;
    margin: 20px auto;
  }
  .slide_in .btn a:link {
    color: #fff;
    text-decoration: none;
  }
  .slide_in .btn a:visited {
    color: #fff;
    text-decoration: none;
  }
  .slide_in .btn a:hover {
    color: #fff;
    text-decoration: none;
  }
  .contact_banner {
    background: #4dbaa9;
    margin-top: 5%;
    padding: 20px 0;
  }
  .contact_banner_title {
    color: #fff;
    font-size: 123.1%;
    text-align: center;
  }
  .contact_banner_btn {
    margin: 12px auto;
  }
  .contact_banner_btn a {
    display: block;
    width: 98%;
    height: 40px;
    line-height: 40px;
    text-align: center;
    font-size: 116%;
    font-weight: bold;
    letter-spacing: 1px;
    border: solid 3px #5cb1a4;
  }
  .contact_banner_btn a:link {
    background: #f19f2b;
    color: #fff;
    text-decoration: none;
  }
  .contact_banner_btn a:visited {
    background: #f19f2b;
    color: #fff;
  }
  .contact_banner_btn a:hover {
    opacity: 0.8;
  }
  .contact_banner_tel {
    max-width: 100%;
  }
  .contact_banner_tel img {
    width: 100%;
  }
  .fa-envelope-o {
    margin-right: 5px;
  }
  .line {
    max-width: 100%;
    margin-top: 5%;
  }
  .line img {
    width: 100%;
  }
  /* pagetitle */
  .pagetitle {
    font-size: 138.5%;
    margin: 90px auto 40px;
    text-align: center;
  }
  /* policy */
  .policy dl {
    margin: 15px 0;
  }
  .policy dt {
    font-size: 108%;
    border-bottom: dotted 1px #ccc;
    border-left: solid 5px #ccc;
    margin-top: 10px;
    padding: 2%;
  }
  .policy dd {
    margin-top: 10px;
  }
  .policy ul {
    margin: 15px 0;
  }
}

/* ------------------------------------------------------------------
960px〜
------------------------------------------------------------------*/
@media screen and (min-width:959px) {
  .inner {
    padding: 0;
    margin: 0 auto;
  }
  .sp_header {
    display: none;
  }
  .pc_header {
    display: block;
    border-bottom: solid 1px #f2f2f2;
  }
  .pc_header h1 {
    color: #666;
    position: absolute;
    font-size: 93%;
    left: 2%;
    top: 5px;
  }
  #underlayer_header {
    width: 1028px;
    margin: 0 auto;
    position: relative;
  }
  #underlayer_header .logo {
    margin-left: 0;
  }
  #underlayer_header .top_text {
    margin-right: 0;
  }
  .kv_sp {
    display: none;
  }
  .kv_pc {
    display: block;
    height: auto;
    line-height: 0;
  }
  .kv_pc img {
    height: 100%;
  }
  .gnav {
    display: block;
    height: 60px;
  }
  #underlayer_nav {
    width: 1028px;
    margin: 0 auto;
  }
  .top {
    position: relative;
    line-height: 0;
  }
  .top_btn {
    max-width: 649px;
    position: absolute;
    bottom: 12%;
    left: 0;
  }
  .top_btn img {
    width: 100%;
  }
  .kv_pc {
    max-width: 100%;
    height: auto;
  }
  .kv_pc img {
    width: 100%;
  }

  .btn_kv {
    width: 100%;
  }
  .btn_kv a {
    height: 60px;
    line-height: 60px;
    font-size: 161%;
  }
  header {
    width: 100%;
    height: 60px;
    background: #fff;
    border-bottom: solid #4dbaa9 3px;
    border-top: solid #f2f2f2 1px;
  }
  .header_inner {
    overflow: hidden;
    margin-left: 2%;
  }
  .pc_header #underlayer_header h1 {
    left: 0;
  }
  .top_bar {
    width:100%;
    height: 113px;
    overflow: hidden;
  }
  .top_text {
    float: right;
    margin-right: 2%;
    margin-top: 25px;
  }
  .head_tel {
    font-weight: bold;
    font-size: 191.5%;
    color: #444;
  }
  .fa-phone {
    margin-right: 3px;
  }
  .logo {
    max-width: 220px;
    position: static;
    float: left;
    margin-top: 29px;
    margin-left: 2%;
  }
  .logo img {
    width: 100%;
  }
  .gnav {
    line-height: 60px;
    border-bottom: solid 1px #f2f2f2;
  }
  .gnav ul {
    margin-right: 10px;
    padding-left: 2%;
  }
  .gnav ul li {
    float: left;
    font-size: 108%;
    margin-left: 25px;
  }
  .gnav .f_r {
    float: right;
    margin: 9px 2% 0 0;
  }
  .gnav ul li:first-child {
    margin-left: 0;
  }
  .nav_logo {
    max-width: 42px;
    margin-top: 9px;
  }
  .nav_logo img {
    width: 100%;
  }
  .gnav ul {
    overflow: hidden;
    max-width: 1170px;
    margin: 0 auto;
  }
  .gnav ul li a {
    display: block;
    font-weight: bold;
    letter-spacing: 1px;
  }
  .gnav ul li a:link {
    color: #444;
    text-decoration: none;
  }
  .gnav ul li a:visited {
    color: #444;
    text-decoration: none;
  }
  .gnav ul li a:hover {
    color: #66c4b6;
    text-decoration: underline;
  }
  .gnav .f_r a {
    display: block;
    width: 200px;
    height: 40px;
    text-align: center;
    line-height: 40px;
    font-weight: normal;
  }
  .gnav .f_r a:link {
    background: #ba4d4d;
    color: #fff;
    text-decoration: none;
    border: 1px solid #ba4d4d;
  }
  .gnav .f_r a:visited {
    background: #ba4d4d;
    color: #fff;
    text-decoration: none;
  }
  .gnav .f_r a:hover {
    background: #fff;
    color: #ba4d4d;
    text-decoration: none;
  }
  .follow {
    width: 100%;
    background: #fff;
    position: fixed;
    top: 0;
    left: 50%;
    z-index: 10;
    transform: translate(-50%, 0);
  }
  .follow ul {
    max-width: 1170px;
    padding-left: 2%;
  }
  .title {
    font-size: 212%;
    margin: 0 0 5% 0;
    padding-top: 5%;
  }
  .title:before {
    bottom: -40px;
    width: 110px;
    height: 2px;
  }
  /* block1 */
  .block1 {
    background: url(../images/bg_block1.jpg) no-repeat 0 0;
    background-size: cover;
    padding-bottom: 50px;
  }
  .block_text {
    padding: 1% 0 1%;
    font-size: 116%;
    width: 620px;
    margin: 0 auto;
  }
  .block1_text {
    margin-top: 15px;
  }
  .trouble {
    max-width: 650px;
    margin: 0 auto;
    padding-top: 35px;
  }
  .to_contact a {
    width: 300px;
    height: 48px;
    line-height: 48px;
  }
  /* alert */
  .alert .about_box {
    width: 365px;
  }
  /* block2 */
  .block2 {
    padding-bottom: 50px;
  }
  .reason_text {
    margin-top: 80px;
  }
  .reason {
    max-width: 1170px;
    margin: 0 auto;
  }
  .about {
    display: flex;
    max-width: 1170px;
    margin: 45px auto 0;
  }
  .about_box {
    width: 280px;
  }
  .about_text {
    text-align: center;
    font-size: 123.1%;
    margin-top: 2%;
    font-weight: bold;
  }
  .block2 .to_contact a {
    margin-top: 2%;
    margin-bottom: 5%;
  }
  /* sale */
  .sale_image {
    max-width: 900px;
    margin: 90px auto 50px;
  }
  .sale_image img {
    width: 100%;
  }
  /* block3 */
  .block3 .inner {
    max-width: 900px;
    margin: 0 auto;
  }
  .block3_image {
    margin: 20px auto;
  }
  .block3_graph {
    max-width: 600px;
  }
  .subtitle {
    width: 100%;
    left: 1%;
    margin-bottom: 20px;
  }
  .subtitle:after {
    width: 40px;
  }
  .block3 .about {
    margin-top: 4%;
  }
  .block3 .more {
    position: absolute;
    top: -10px;
    right: 2%;
  }
  .block3 .to_contact a {
    margin-top: 4%;
    margin-bottom: 0;
  }
  /* block4 */
  .block4 {
    background: #fafafa;
  }
  .block4 .sp {
    display: none;
  }
  .block4 .pc {
    display: block;
    max-width: 1170px;
    margin: 8% auto 0;
  }
  .block4 .pc img {
    width: 100%;
  }
  .block4 .inner {
    max-width: 1170px;
    margin: 0 auto;
  }
  .about_box {
    margin: 0 auto;
  }
  /* block5 */
  .block5 {
    padding-bottom: 20px;
  }
  .block5 .subtitle {
    width: 220px;
  }
  .block5 .subtitle:after {
    width: 80px;
  }
  .block5 p {
    margin: 2% 0 5% 2%;
    font-size: 116%;
  }
  .block5 .inner {
    max-width: 1170px;
    margin: 0 auto;
  }
  .block5_image {
    max-width: 960px;
    margin: 0 auto;
  }
  .block5_image img {
    width: 100%;
  }
  .block5 ul {
    font-size: 173%;
    width: 820px;
    margin: 40px auto;
  }
  .block6 {
    padding-bottom: 50px;
  }
  .block6 .inner {
    max-width: 1170px;
    margin: 0 auto;
  }
  .block6 ul {
    overflow: hidden;
    width: 960px;
    margin: 0 auto;
  }
  .block6 ul li {
    max-width: 480px;
    float: left;
  }
  .block6 ul li img {
    width: 100%;
  }
  .block_welcome {
    padding: 30px 0 40px;
  }
  .block_welcome .inner {
    width: 820px;
    margin: 0 auto;
  }
  #contact textarea {
    margin-top: 15px;
  }
  /* footer */
  .footer {
    padding: 20px 0;
  }
  .footer .logo {
    margin: 0;
  }
  .footer dl {
    margin: 5px 0 0 3%;
    float: left;
  }
  .footer ul {
    float: right;
  }
  .footer .inner {
    max-width: 1105px;
    margin: 0 auto;
  }
  .contact_banner {
    margin-top: 60px;
  }
  .contact_banner .inner {
    max-width: 720px;
    margin: 0 auto;
  }
  .contact_banner_title {
    font-size: 183%;
  }
  .contact_banner_btn a {
    height: 64px;
    line-height: 64px;
    font-size: 183%;
  }
  .contact_banner_tel {
    max-width: 500px;
    margin: 0 auto;
  }
  .line {
    max-width: 69%;
    margin: 2% auto 0;
  }
  .line a:hover {
    opacity: 0.8;
  }
  .pagetitle {
    margin: 50px auto;
  }
  .policy {
    max-width: 1028px;
    margin: 0 auto;
  }
  .policy dt {
    margin-top: 10px;
    padding: 10px;
  }
  #reason {
    max-width: 1028px;
    margin: 0 auto;
  }

}
