@charset "UTF-8";
@import url(reset.css);
@import url(https://fonts.googleapis.com/css?family=Lato:400,200,300,700,900);
@import url(https://fonts.googleapis.com/css?family=Fjalla+One);
/* pc */
.pc { display: block; }

.sp { display: none; }

/* pc */
/* base */
html { font-family: 'Lato', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif, serif; -webkit-font-smoothing: antialiased !important; -webkit-text-stroke: 1px transparent; -webkit-tap-highlight-color: rgba(0, 0, 0, 0); -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; text-rendering: optimizeLegibility; color: #000; font-size: 14px; font-weight: normal; line-height: 1.5; word-wrap: break-word; letter-spacing: 0; height: 100%; }

body { margin: 0; padding: 0; width: 100%; height: 100%; background: #fff; }

.clearfix { min-height: 1%; }

.clearfix::after { clear: both; content: ""; display: block; }

p { line-height: 1.75; }

img { height: auto; }

a{ border:none; color: #000000;}

.center { text-align: center; }

.mb20 { margin-bottom: 20px; }

.mb50 { margin-bottom: 50px; }

.pt50 { padding-top: 50px; }

.pt10 { padding-top: 10px; }

.pb50 { padding-bottom: 50px; }

.pt150 { padding-top: 150px; }

.pb150 { padding-bottom: 150px; }

.require { color: #FF0000; }

.w100 { width: 100%; }

.error { color: #FF0000; margin-top: 5px; }

.c_blue { background-color: #2c51a2; }

.c_red { background-color: #da282c; }

.c_green { background-color: #047d34; }


/* リストデザイン003 */
.list_design003 {
  padding: 0 20px;
}

.list_design003 li {
  list-style: none;
}

.list_design003 li::before {
  content: '▶︎';
  padding: 0 5px;
}



.fadeInDown { -webkit-animation-fill-mode: both; -ms-animation-fill-mode: both; animation-fill-mode: both; -webkit-animation-duration: 1s; -ms-animation-duration: 1s; animation-duration: 1s; -webkit-animation-name: fadeInDown; animation-name: fadeInDown; visibility: visible !important; }

@-webkit-keyframes fadeInDown { 0% { opacity: 0; -webkit-transform: translateY(-20px); }
  100% { opacity: 1; -webkit-transform: translateY(0); } }
@keyframes fadeInDown { 0% { opacity: 0; -webkit-transform: translateY(-20px); -ms-transform: translateY(-20px); transform: translateY(-20px); }
  100% { opacity: 1; -webkit-transform: translateY(0); -ms-transform: translateY(0); transform: translateY(0); } }
.fadeInDownContact { -webkit-animation-fill-mode: both; -ms-animation-fill-mode: both; animation-fill-mode: both; -webkit-animation-duration: 1s; -ms-animation-duration: 1s; animation-duration: 1s; -webkit-animation-name: fadeInDownContact; animation-name: fadeInDownContact; visibility: visible !important; }

@-webkit-keyframes fadeInDownContact { 0% { opacity: 0; -webkit-transform: translateY(-20px); }
  100% { opacity: 1; -webkit-transform: translateY(0); } }
@keyframes fadeInDownContact { 0% { opacity: 0; }
  100% { opacity: 1; -webkit-transform: translateY(0); -ms-transform: translateY(0); transform: translateY(0); } }
/* base */
/* container */
#container { position: relative; min-height: 100%; height: auto !important; height: 100%; }

/* container */
/* main */
#main { padding-bottom: 130px; position: relative; }

/* main */
/* header */
#header { position: absolute; top: 15px; width: 100%; height: auto; }
#header #header_inn { margin: 0 auto; }
#header #nav ul.pc { display: flex; justify-content: flex-end; }
#header #nav ul.pc li { text-align: center; margin-right: 40px; }
#header #nav ul.pc li a { color: #000000; font-size: 16px; font-weight: bold; text-decoration: none; z-index: 1; }
#header #nav ul.pc li a span { font-size: 12px; font-weight: normal; }
#header #nav ul li:last-child { margin-top: 10px; }

/* header */
/* section */
section .content_inn .inn { width: 1080px; margin: 0 auto; }

#top_image .logo .inn { width: 1080px; margin: 0 auto; margin-top: -30px; text-align: right; }

#service .content_inn .menu_block img:first-child { float: left; }
#service .content_inn .menu_block img:last-child { float: right; }
#service .content_inn #menu { width: 1080px; margin: 30px auto 100px; }
#service .content_inn #menu .menu_box.left { float: left; width: 45%; }
#service .content_inn #menu .menu_box.left dl dt { background-color: #000000; color: #FFFFFF; }
#service .content_inn #menu .menu_box.right { float: right; width: 45%; }
#service .content_inn #menu .menu_box.right dl dt { background-color: #2a2a2a; color: #FFFFFF; }
#service .content_inn #menu .menu_box dl { box-sizing: border-box; border: 1px solid #000000; }
#service .content_inn #menu .menu_box dl dt { color: #000000; padding: 30px 10px; font-size: 18px; font-weight: bold; text-align: center; border-bottom: 1px solid #000000; }
#service .content_inn #menu .menu_box dl dd { box-sizing: border-box; padding: 15px 10px; font-size: 18px; border-bottom: 1px solid #000000; }
#service .content_inn #menu .menu_box dl dd .price { font-size: 24px; display: block; margin-bottom: 10px; }
#service .content_inn #menu .menu_box dl dd .price .small { font-size: 14px; margin-left: 5px; }
#service .content_inn #menu .menu_box dl dd .agreetment { font-size: 14px; display: block; }
#service .content_inn #menu .menu_box dl dd.odd { background-color: #FFFFFF; }
#service .content_inn #menu .menu_box dl dd.even { background-color: #f0f0f0; }
#service .content_inn #menu .menu_box dl dd:last-child { border-bottom: none; }

#company .content_inn .detail_box { text-align: left; }
#company .content_inn .detail_box p { font-size: 17px; text-align: left; display: inline-block; vertical-align: top; }
#company .content_inn .map { margin-top: 50px; position: relative; width: 100%; height: 0; padding-bottom: 30%; overflow: hidden; box-sizing: border-box; }
#company .content_inn .map iframe { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

#contact .form { background-image: url("../images/bg_contact.jpg"); background-repeat: no-repeat; background-size: cover; }
#contact .form .inputBox { width: 700px; margin: 0 auto; }
#contact .form .inputBox dl { margin-bottom: 30px; box-sizing: border-box; }
#contact .form .inputBox dl dt { width: 35%; float: left; font-weight: bold; font-size: 17px; padding: 3px 0; }
#contact .form .inputBox dl dt span { margin-left: 10px; }
#contact .form .inputBox dl dd { width: 65%; float: right; }
#contact .form .inputBox dl dd input, #contact .form .inputBox dl dd textarea { width: 100%; padding: 3px 5px; font-size: 17px; box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.4); border: 1px solid #aaaaaa; }
#contact .form .inputBox dl dd textarea { padding: 5px; height: 300px; }
#contact .form .inputBox .button_area { margin-top: 100px; text-align: center; }
#contact .form .inputBox .button_area .btn { font-size: 17px; width: 200px; margin: 0 auto; padding: 15px 0; background-color: #000; color: #FFF; }

#confirm .form .inputBox { text-align: center; width: 700px; margin: 0 auto; }
#confirm .form .inputBox dl { margin-bottom: 30px; box-sizing: border-box; }
#confirm .form .inputBox dl dt { width: 49%; text-align: left; display: inline-block; font-weight: bold; font-size: 17px; }
#confirm .form .inputBox dl dd { text-align: left; width: 50%; display: inline-block; font-size: 17px; }
#confirm .form .inputBox dl.detail dt { vertical-align: top; }
#confirm .form .inputBox .button_area { margin-top: 100px; text-align: center; }
#confirm .form .inputBox .button_area .btn { box-sizing: border-box; font-size: 17px; width: 200px; margin: 0 auto; padding: 15px 0; background-color: #000; color: #FFF; display: inline-block; }
#confirm .form .inputBox .button_area .back_btn { box-sizing: border-box; height: 57px; padding-top: 19px; width: 200px; background-color: #AAAAAA; color: #FFFFFF; text-decoration: none; margin-right: 15px; }

/* section */
#main.confirm footer .inn .copy_right { margin-top: 70px; }

/* footer */
footer { position: absolute; bottom: 0; background-color: #000; width: 100%; height: 100px; padding: 15px 0; color: #FFF; }
footer .inn { width: 1080px; margin: 0 auto; position: relative; }
footer .inn nav { text-align: center; margin: 0 auto; margin-top: 45px; }
footer .inn nav ul { display: flex; justify-content: center; }
footer .inn nav ul li { margin-right: 45px; }
footer .inn nav ul li a { color: #FFF; font-size: 17px; text-decoration: none; }
footer .inn nav ul li:last-child { margin-right: 0; }
footer .inn nav li.sns { display: none; }
footer .inn .sns_area { position: absolute; right: 15px; top: -15px; }
footer .inn .sns_area li { display: inline-block; margin-right: 15px; }
footer .inn .sns_area li:last-child { margin-right: 0; }
footer .inn .copy_right { text-align: center; margin-top: 20px; }

/* footer */
@media screen and (max-width: 1080px) { .pc { display: none !important; }
  .sp { display: block; }
  #main { padding-bottom: 100px; }
  #header { position: relative; top: 0; width: 100%; }
  #header #nav #accordion { display: none; }
  #header #nav ul li { vertical-align: middle; display: block; margin-right: 0; width: 100%; text-align: left; border-bottom: 1px solid #000000; background-color: #F4F4F4; }
  #header #nav ul li a { display: block; box-sizing: border-box; padding: 15px 10px; height: auto; color: #000000; font-size: 16px; font-weight: bold; text-decoration: none; z-index: 1; }
  #header #nav ul li a span { font-size: 12px; font-weight: normal; margin-left: 10px; }
  #header #nav ul li .button { padding: 15px 10px; background-color: #F4F4F4; color: #000000; }
  #header #nav .sp_header { box-sizing: border-box; padding: 10px 10px; background-color: #F4F4F4; width: 100%; }
  #header #nav .sp_header h1 { float: left; }
  #header #nav .sp_header h1 img { height: 35px; }
  #header #nav .sp_header span { float: right; }
  #header #nav .sp_header #humbuger_button { position: relative; }
  #header #nav .sp_header #humburger_button span { width: 40px; height: 2px; display: block; background: #000000; position: absolute; right: 15px; top: 30px; margin-left: -25px; }
  #header #nav .sp_header .type-4 span { -webkit-transition: all 0.5s; transition: all 0.5s; -webkit-transform: translateY(0px) !important; -ms-transform: translateY(0px) !important; transform: translateY(0px) !important; }
  #header #nav .sp_header .type-4 .top { margin-top: -13px; -webkit-transform: rotate(0deg) !important; -ms-transform: rotate(0deg) !important; transform: rotate(0deg) !important; }
  #header #nav .sp_header .type-4 .bottom { margin-top: 13px; -webkit-transform: rotate(0deg) !important; -ms-transform: rotate(0deg) !important; transform: rotate(0deg) !important; }
  #header #nav .sp_header .type-4.is-open .middle { background: rgba(255, 255, 255, 0); }
  #header #nav .sp_header .type-4.is-open .top { -webkit-transform: rotate(-405deg) !important; -ms-transform: rotate(-405deg) !important; transform: rotate(-405deg) !important; margin-top: 0px; }
  #header #nav .sp_header .type-4.is-open .bottom { -webkit-transform: rotate(405deg) !important; -ms-transform: rotate(405deg) !important; transform: rotate(405deg) !important; margin-top: 0px; }
  #header #nav ul li:first-child { border-top: 1px solid #000000; }
  #header #nav ul li:last-child { margin-top: 0; border-bottom: none; }
  section .content_inn .title_area { padding-left: 15px; padding-right: 15px; }
  section .content_inn .inn { width: 100%; margin: 0 auto; }
  #top_image .logo .inn { width: 100%; margin: 0 auto; margin-top: -41px; text-align: right; }
  #top_image .logo .inn img { margin-right: 30px; }
  #concept { padding: 50px 0; }
  #service .content_inn .inn { box-sizing: border-box; padding: 0 15px; }
  #service .content_inn .menu_block { text-align: center; margin-bottom: 0 !important; }
  #service .content_inn .menu_block img { float: none !important; margin-bottom: 30px; width: 100%; max-width: 514px; }
  #service .content_inn #menu { width: auto; margin: 30px 50px 100px; }
  #company .content_inn .detail_box { padding: 0 30px; text-align: center; }
  #company .content_inn .detail_box p { text-align: left; display: block; }
  #company .content_inn .detail_box p:first-child { margin-right: 0; }
  #company .content_inn .map { margin-top: 50px; }
  #contact .form { padding: 30px 15px; }
  #contact .form .inputBox { width: 100%; }
  #contact .form .inputBox dl { margin-bottom: 30px; }
  #contact .form .inputBox dl dt { width: 35%; float: left; font-weight: bold; font-size: 15px; padding: 3px 0; }
  #contact .form .inputBox dl dt span { margin-left: 10px; }
  #contact .form .inputBox dl dd { width: 65%; float: right; }
  #contact .form .inputBox dl dd input, #contact .form .inputBox dl dd textarea { box-sizing: border-box; padding: 3px 5px; font-size: 15px; box-shadow: 3px 3px 3px rgba(0, 0, 0, 0.4); border: 1px solid #aaaaaa; }
  #contact .form .inputBox dl dd textarea { padding: 5px; height: 200px; }
  #contact .form .inputBox .button_area { margin-top: 100px; text-align: center; }
  #contact .form .inputBox .button_area .btn { font-size: 17px; width: 200px; margin: 0 auto; padding: 15px 0; background-color: #000; color: #FFF; }
  #confirm .form .inputBox { width: 100%; padding: 0 15px; box-sizing: border-box; }
  footer { padding: 0; }
  footer .inn { width: 100%; box-sizing: border-box; }
  footer .inn nav { margin: 0; }
  footer .inn nav ul { flex-direction: column; }
  footer .inn nav ul li { text-align: left; display: block; background-color: #000; margin: 0; }
  footer .inn nav ul li a, footer .inn nav ul li span { display: block; padding: 15px 10px; font-size: 17px; }
  footer .inn nav ul li span, footer .inn nav ul li a.inline { display: inline-block; }
  footer .inn nav ul li span img, footer .inn nav ul li a.inline img { height: 20px; vertical-align: middle; margin-bottom: 1px; }
  footer .inn nav ul li:last-child { border-bottom: 0; }
  footer .inn nav ul li.sns { display: block; }
  footer .inn .copy_right { margin: 0; background-color: #000; padding-bottom: 5px; } }
@media screen and (max-width: 768px) { section .content_inn .title_area img { width: 80%; }
  #concept p { padding: 0 15px; }
  #concept img.txt_concept { width: 40%; margin-bottom: 15px; }
  #company .content_inn .map { padding-bottom: 56%; }
  #confirm .form .inputBox .button_area .back_btn { margin-right: 0; margin-bottom: 10px; }
  #service .content_inn #menu { width: auto; margin: 0 50px 50px; }
  #service .content_inn #menu .menu_box.left { float: none; width: 100%; margin-bottom: 30px; }
  #service .content_inn #menu .menu_box.left p { font-size: 18px; }
  #service .content_inn #menu .menu_box.left dl dd { font-size: 16px; height: auto; }
  #service .content_inn #menu .menu_box.right { float: none; width: 100%; }
  #service .content_inn #menu .menu_box.right p { font-size: 18px; }
  #service .content_inn #menu .menu_box.right dl dd { font-size: 16px; height: auto; } }

/*# sourceMappingURL=style.css.map */
