@charset "utf-8";


@media screen and (max-width: 1140px) {
    section#fv .inner { width:100%; }
    section#fv .inner > img {
        width:100%;
        position:absolute;
        right:0;
        top:50%;
        transform: translateY(-50%);
    }
}

/*タブレット*/
@media screen and (max-width: 960px) {

  .pc { display:none; }
  .smp { display:block; }

  section .inner { width: 90%; }

  header .menu { display:none; }
  header .sp-menu-btn {
    display:block;
  }

  /*index*/
  section#fv .fv-con { left: 40px; }
  section#fv .fv-con .head { font-size: 48px; }
  section#fv .fv-con p { font-size: 18px; }
  section#service .inner .box .number { left: -30px; }

  /*contact*/
  section#flow .inner .flex-sb .box p { font-size: 10px; }

}

/*	スマホ		*/
@media screen and (max-width: 428px) {

  .pc { display:none; }
  .smp  { display:block; }
  br.pc { display:none; }
  br.sp  { display:inline; }

  body {margin: 56px auto 0; }

  /*header*/
  header { height:56px; }
  header .logo { top: 12px; left: 16px; }
  header .logo a:first-child img { height: 25px; }
  header .logo > img:last-child { margin: 0 0 0 9px; height: 34px; }
  header .sp-menu-btn { width: 20px; top: 20px; }

  /*footer*/
  footer { padding: 23px 0 33px; }
  footer img { width:80px; }
  footer .menu a { margin:0 0 13px; font-size: 12px; display: block; }

  /*index*/
  section#fv .inner { height:630px; }
  section#fv .inner > img { display:none; }
  section#fv .fv-con { width:100%; top:28px; left:50%; transform: translateX(-50%); }
  section#fv .sp-fv-img { display: block; }
  section#fv .fv-con .head { font-size: 32px; text-align: center; }
  section#fv .fv-con p { font-size: 14px; text-align: center; }
  section#fv .fv-con .slider { width:290px; margin:0 auto 30px; }
  section#fv .fv-con .slider .slick-slide { padding:0 4px; }
  section#fv .fv-con .slider .slick-slide .box { width:141px; height:141px; }
  section#fv .fv-con .slider .slick-slide .box .icn01 {
      margin:25px auto 22px;
      width:30px;
  }
  section#fv .fv-con .slider .slick-slide .box .icn02 {
      margin:24px auto 18px;
      width:30px;
  }
  section#fv .fv-con .slider .slick-slide .box .icn03 {
      margin:25px auto 18px;
      width:30px;
  }
  section#fv .fv-con .slider .slick-slide .box .icn04 {
      margin:22px auto 14px;
      width:30px;
  }
  section#fv .fv-con .slider .slick-slide .box .icn05 {
      margin:14px auto 16px;
      width:55px;
  }
  section#fv .fv-con .slider .slick-slide .box .icn06 {
      margin:24px auto 30px;
      width:30px;
  }
  section#fv .fv-con .slider .slick-slide .box p { font-size:10px; }
  section#tokutyo { padding: 30px 0 37px; background-color: #fff; }
  section#tokutyo .bg { display: none; }
  section#tokutyo .inner .sub-head,
  section#service .inner .sub-head,
  section#price .inner .sub-head,
  section#news .inner .sub-head
  { margin: 0 0 8px; font-size: 14px; }
  section#tokutyo .inner .head,
  section#service .inner .head,
  section#price .inner .head,
  section#news .inner .head
  { margin: 0 0 10px; font-size: 24px; line-height: 24px; }
  section#tokutyo .inner .head img { height: 40px; }
  section#tokutyo .inner .head div { margin: 0 0 0 5px; font-size: 24px; line-height: 24px; }
  section#tokutyo .inner .bd { width:120%; margin:0 0 20px -10% }
  section#tokutyo .inner p { font-size: 12px; }
  section#service { padding: 30px 0 53px; }
  section#service .inner .head { margin: 0 0 48px; }
  section#service .inner .box .number { font-size: 20px; line-height: 20px; top:-30px; left:50%; transform: translateX(-50%); }
  section#service .inner .box { margin: 0 auto 50px; padding: 23px 10px 25px; border-radius: 16px; }
  section#service .inner .box .flex-sb { flex-wrap: wrap; }
  section#service .inner .box .flex-sb img { width: 160px; margin: 0 auto 10px; }
  section#service .inner .box .flex-sb .text { text-align: center; width:100%; }
  section#service .inner .box .flex-sb .text .cap { font-size: 18px; }
  section#service .inner .box .flex-sb .text p { padding:0 25px; font-size: 12px; text-align: left; }
  section#service .inner .box .flex-sb .text a { margin: 25px 0 0; font-size: 12px; display:inline-block }
  section#service .inner .box:nth-child(7) { padding: 23px 25px 25px; }
  section#service .inner .box:nth-child(7) .flex-sb .text { text-align: left; font-size: 12px; }
  section#service .inner .box:nth-child(7) .flex-sb .text .cap { text-align: center; }
  section#service .inner .box:nth-child(7) .flex-sb .text p { padding:0; }
  section#price { padding: 32px 0 26px; }
  section#price .inner .bd { display: none; }
  section#price .inner .head { margin: 0 0 10px; }
  section#price .inner .flex-ct { flex-wrap: wrap; margin: 0 auto 18px; }
  section#price .inner .flex-ct > img { width: 220px; margin: 0 0 28px; }
  section#price .inner .flex-ct .text .cap { margin: 0 auto 20px; font-size: 20px; text-align: center; }
  section#price .inner .flex-ct .text p { padding:0 25px; }
  section#price .inner .flex-ct .text p span:first-child { margin: 0 5px 0 -15px; }
  section#price .inner .flex-ct .text p span:nth-child(2) { font-size: 16px; }
  section#price .inner .flex-ct .text p span:nth-child(3) { font-size: 12px; }
  section#price .inner .flex-ct .text p.ano { margin: 16px auto 14px; padding:0; font-size: 10px; text-align: center; }
  section#price .inner .flex-ct .text img { width: 140px; margin: 0 auto; display:block }
  section#price .inner h3 { width:100%; padding: 4px 0; font-size: 12px; }
  section#price .inner .table-box { width:100%; }
  section#price .inner .table-box table tr th { padding: 5px 0; font-size: 10px; }
  section#price .inner .table-box table tr td { padding: 6px 0; }
  section#price .inner .table-box table tr td:first-child { font-size: 9px; }
  section#price .inner .table-box table tr td:first-child span { font-size: 13px; }
  section#price .inner .table-box table tr td:nth-child(2) { font-size: 10px; }
  section#price .inner .table-box table tr td:nth-child(3) div:first-child { font-size: 8px; margin: 0 8px 0 0; }
  section#price .inner .table-box table tr td:nth-child(3) div:last-child { font-size: 19px; }
  section#price .inner .table-box table tr td:nth-child(3) div:last-child span { font-size: 36px; }
  section#price .inner .table-box p { font-size: 8px; }
  section#news { padding: 30px 0 34px; }
  section#news .inner .head { margin: 0 0 20px; }
  section#news .inner .news-list { margin: 0 auto 12px; }
  section#news .inner .news-list .news { padding: 4px 0 14px;}
  section#news .inner .news-list .news .date { font-size: 12px; margin:0 0 0px; }
  section#news .inner .news-list .news .title { width:100%; font-size: 12px; display:block; }
  section#news .inner a { font-size:12px }

  section#top-contact { padding: 23px 0 37px; background-image: url(../images/sp/top_contact_bg.png); }
  section#top-contact .inner .head { margin: 0; font-size: 24px; }
  section#top-contact .inner .sub-head { font-size: 14px; }
  section#top-contact .inner a { margin: 0 0 15px; padding: 9px 46px 13px; font-size: 18px; }
  section#top-contact .inner p { font-size: 10px; }

  /*page*/
  section#page-title { padding: 22px 0 24px; }
  section#page-title .sub-head { margin: 0; font-size: 14px; }
  section#page-title .head { margin: 0; font-size: 24px; }
  /*company*/
  section#company { padding: 28px 0 67px; }
  section#company .inner .head { margin: 0 0 18px; font-size:18px; }
  section#company .inner .company-table { margin: 0 0 44px; }
  section#company .inner .company-table .flex-sb { width:100%; }
  section#company .inner .company-table .flex-sb .cap { width: 28%; padding: 21px 7px 23px 7px; font-size: 12px; text-align: center; }
  section#company .inner .company-table .flex-sb .con { width: 72%; padding: 21px 0 23px 13px; font-size:12px; }
  section#company .inner .head.h02 { margin: 0 0 11px; }
  section#company .inner .saiyo { font-size: 12px; }
  /*contact*/
  section#flow { padding: 28px 0; }
  section#flow .inner { width:100%; text-align:center; }
  section#flow .inner .head , section#contact .inner .head { margin: 0 0 15px; font-size:18px; }
  section#flow .inner .flex-sb { flex-wrap: wrap; }
  section#flow .inner .flex-sb .box { width:100%; margin:0 0 5px; }
  section#flow .inner .flex-sb .box img { width:140px; margin:0 8px 0 0 ; display: inline-block; vertical-align: middle; }
  section#flow .inner .flex-sb .box p { width:184px; font-size:8px; text-align:left; display: inline-block; vertical-align: middle; }
  section#flow .inner .flex-sb .box:nth-child(1) p , section#flow .inner .flex-sb .box:nth-child(2) p { margin:0 0 5px; }
  section#contact { padding: 0px 0 80px; }
  section#contact .inner > p { margin: 0 0 15px; font-size: 10px; }
  section#contact .inner .contact-table { margin: 0 auto 20px; }
  section#contact .inner .contact-table .flex-sb { width:100%; }
  section#contact .inner .contact-table .flex-sb .cap { width: 28%; padding: 17px 7px 24px 7px; font-size: 10px; text-align: center; }
  section#contact .inner .contact-table .flex-sb:nth-child(1) .cap { padding: 24px 7px 17px 7px; letter-spacing: .26em; }
  section#contact .inner .contact-table .flex-sb:nth-child(2) .cap { letter-spacing: .26em; }
  section#contact .inner .contact-table .flex-sb:nth-child(4) .cap { letter-spacing: .26em; }
  section#contact .inner .contact-table .flex-sb .cap div { font-size: 7px; letter-spacing: 0; top:32px; right:50%; transform: translateX(50%); padding: 0px 6px; }
  section#contact .inner .contact-table .flex-sb .con { width: 72%; padding: 10px 0 10px 10px; }
  section#contact .inner .contact-table .flex-sb .con input[type="text"],
  section#contact .inner .contact-table .flex-sb .con input[type="email"],
  section#contact .inner .contact-table .flex-sb .con input[type="tel"]
  { padding: 10px; }
  section#contact .inner > p.ano { margin: 0 0 20px; font-size: 12px; }
  section#contact .inner .submit-btn { padding: 10px; }

  /*single*/
  section#single-top { height: 170px; background-position: center center; }
  .bread { font-size: 10px; padding: 15px 0; }
  .single section#news { padding: 20px 0 90px; }
  section#news-single { padding: 20px 0 90px; }
  section#news-single .section-title { font-size: 22px; }
  section#news-single .section-title-border { width: 120px; margin-bottom: 30px; }
  section#news-single .date { padding-bottom: 1em; }
  section#news-single p { font-size: 14px; }
  section#news-single .button-box .button.default { width: 240px; padding: 15px 60px; }

}
