@charset "UTF-8";
* { margin: 0; padding: 0; list-style: none; outline: none; }

html { font-size: 62.5%; height: 100%; }

body { line-height: 0; text-align: center; -webkit-text-size-adjust: 100%; font-family: "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif; overflow-x: hidden; }

img { border: none; }
@media all and (max-width: 768px) { img { max-width: 100%; } }

a { text-decoration: none; }

p, li, th, td, h1, h2, h3, h4, h5, dt, dd { text-align: left; line-height: 1.5; font-size: 21px; }
@media all and (max-width: 768px) { p, li, th, td, h1, h2, h3, h4, h5, dt, dd { font-size: 13px; } }

.pcOnly { display: block; }
@media all and (min-width: 768px) and (max-width: 1000px) { .pcOnly { display: none; } }
@media all and (max-width: 768px) { .pcOnly { display: none; } }

.tbOnly { display: none; }
@media all and (min-width: 768px) and (max-width: 1000px) { .tbOnly { display: block; } }
@media all and (max-width: 768px) { .tbOnly { display: none; } }

.spOnly { display: none; }
@media all and (min-width: 768px) and (max-width: 1000px) { .spOnly { display: none; } }
@media all and (max-width: 768px) { .spOnly { display: block; } }

br.spNone { display: block; }
@media all and (min-width: 768px) and (max-width: 1000px) { br.spNone { display: block; } }
@media all and (max-width: 768px) { br.spNone { display: none; } }

.cf { zoom: 1; }
.cf:after { content: "."; display: block; clear: both; height: 0; visibility: hidden; }
.cf .fl { float: left; }
.cf .fr { float: right; }

.keyVisual { background: url(../images/main_bg.jpg) #ffffff center top no-repeat; background-size: 100%; padding-top: 59.378%; width: 100%; position: relative; }
.keyVisual header { position: absolute; left: 50%; top: 34px; margin-left: -44px; }
@media all and (max-width: 1200px) { .keyVisual header { width: 60px; } }
.keyVisual h1 { position: absolute; left: 50%; top: 50%; margin: -170px 0 0 -319px; }
@media all and (max-width: 1400px) { .keyVisual h1 img { -webkit-transform: scale(0.8, 0.8); -moz-transform: scale(0.8, 0.8); -ms-transform: scale(0.8, 0.8); -o-transform: scale(0.8, 0.8); transform: scale(0.8, 0.8); } }
@media all and (max-width: 1200px) { .keyVisual h1 img { -webkit-transform: scale(0.7, 0.7); -moz-transform: scale(0.7, 0.7); -ms-transform: scale(0.7, 0.7); -o-transform: scale(0.7, 0.7); transform: scale(0.7, 0.7); } }
@media all and (max-width: 1000px) { .keyVisual h1 { margin-top: -140px; }
  .keyVisual h1 img { -webkit-transform: scale(0.6, 0.6); -moz-transform: scale(0.6, 0.6); -ms-transform: scale(0.6, 0.6); -o-transform: scale(0.6, 0.6); transform: scale(0.6, 0.6); } }
@media all and (max-width: 768px) { .keyVisual { padding: 13px 13px 0 13px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; -o-box-sizing: border-box; box-sizing: border-box; background: url(../images/main_bg_sp.jpg) #ffffff center top no-repeat; background-size: 100%; }
  .keyVisual header { position: relative; left: auto; top: auto; margin: 0 auto; }
  .keyVisual header img { width: 44px; }
  .keyVisual h1 { position: relative; left: auto; top: auto; margin: 0 0 0 0; padding: 0 0 0 0; text-align: center; line-height: 0; }
  .keyVisual h1 img { width: 100%; }
  .keyVisual .iconGw { position: absolute; top: 7%; left: 50%; margin-left: 10%; width: 20%; } }
.keyVisual ul li { position: absolute; z-index: 9999; left: 50%; top: 50%; display: none; animation: vertical 0.5s ease-in-out infinite alternate; }
.keyVisual ul li:nth-child(1) { margin: -310px 0px 0px -550px; animation-duration: 1.1s; }
.keyVisual ul li:nth-child(2) { margin: -280px 0px 0px -150px; animation-duration: 1.2s; }
.keyVisual ul li:nth-child(3) { margin: -310px 0px 0px 200px; animation-duration: 1.3s; }
.keyVisual ul li:nth-child(4) { margin: 70px 0px 0px -400px; animation-duration: 1.4s; }
.keyVisual ul li:nth-child(5) { margin: -20px 0px 0px 250px; animation-duration: 1.5s; }
.keyVisual ul li a { display: block; line-height: 0; }
.keyVisual ul li a:hover { opacity: 0.8; -moz-opacity: 0.8; filter: alpha(opacity=80); }
.keyVisual ul li a span { display: none; }
@media all and (max-width: 1400px) { .keyVisual ul li:nth-child(1) { margin: -260px 0px 0px -500px; }
  .keyVisual ul li:nth-child(2) { margin: -230px 0px 0px -150px; }
  .keyVisual ul li:nth-child(3) { margin: -260px 0px 0px 150px; }
  .keyVisual ul li:nth-child(4) { margin: 20px 0px 0px -350px; }
  .keyVisual ul li:nth-child(5) { margin: -70px 0px 0px 200px; }
  .keyVisual ul li img { -webkit-transform: scale(0.8, 0.8); -moz-transform: scale(0.8, 0.8); -ms-transform: scale(0.8, 0.8); -o-transform: scale(0.8, 0.8); transform: scale(0.8, 0.8); } }
@media all and (max-width: 1200px) { .keyVisual ul li:nth-child(1) { margin: -240px 0px 0px -450px; }
  .keyVisual ul li:nth-child(2) { margin: -210px 0px 0px -150px; }
  .keyVisual ul li:nth-child(3) { margin: -240px 0px 0px 100px; }
  .keyVisual ul li:nth-child(4) { margin: 10px 0px 0px -300px; }
  .keyVisual ul li:nth-child(5) { margin: -70px 0px 0px 150px; }
  .keyVisual ul li img { -webkit-transform: scale(0.7, 0.7); -moz-transform: scale(0.7, 0.7); -ms-transform: scale(0.7, 0.7); -o-transform: scale(0.7, 0.7); transform: scale(0.7, 0.7); } }
@media all and (max-width: 1000px) { .keyVisual ul li:nth-child(1) { margin: -200px 0px 0px -350px; }
  .keyVisual ul li:nth-child(2) { margin: -200px 0px 0px -30px; }
  .keyVisual ul li:nth-child(3) { margin: -160px 0px 0px 100px; }
  .keyVisual ul li:nth-child(4) { margin: 25px 0px 0px -250px; }
  .keyVisual ul li:nth-child(5) { margin: -30px 0px 0px 70px; }
  .keyVisual ul li img { -webkit-transform: scale(0.6, 0.6); -moz-transform: scale(0.6, 0.6); -ms-transform: scale(0.6, 0.6); -o-transform: scale(0.6, 0.6); transform: scale(0.6, 0.6); } }
@media all and (max-width: 768px) { .keyVisual ul { padding: 0 13px; background: rgba(255, 255, 255, 0.9); -webkit-border-radius: 8px; -moz-border-radius: 8px; -ms-border-radius: 8px; -o-border-radius: 8px; border-radius: 8px; position: relative; z-index: 5; }
  .keyVisual ul li { display: block !important; position: relative !important; top: auto !important; left: auto !important; margin: 0 !important; line-height: 1; animation: none; border-bottom: 1px solid rgba(0, 0, 0, 0.1); font-weight: bold; }
  .keyVisual ul li a { display: block; line-height: 1; padding: 21px 0; color: #000; background: url(../images/arr.png) right no-repeat; background-size: 15px; }
  .keyVisual ul li a img { display: none; }
  .keyVisual ul li a span { display: block; }
  .keyVisual ul li a span em { font-style: normal; color: #0072bb; } }
@keyframes vertical { 0% { transform: translateY(-10px); }
  100% { transform: translateY(0px); } }
.keyVisual .btn { display: block; position: absolute; left: 50%; bottom: 0; margin: 0 0 -40px -313px; }
.keyVisual .btn img { max-width: 100%; }
@media all and (max-width: 1200px) { .keyVisual .btn { width: 450px; margin: 0 0 -20px -225px; } }
@media all and (max-width: 768px) { .keyVisual .btn { width: 100%; margin: 21px auto; position: relative; left: auto; bottom: auto; } }
.keyVisual figure { display: block; position: absolute; left: 50%; bottom: 0; margin: 0 0 -25px 200px; }
.keyVisual figure img { max-width: 100%; }
@media all and (max-width: 1400px) { .keyVisual figure { width: 400px; } }
@media all and (max-width: 1200px) { .keyVisual figure { width: 300px; margin: 0 0 -25px 150px; } }
@media all and (max-width: 1000px) { .keyVisual figure { width: 250px; } }
@media all and (max-width: 768px) { .keyVisual figure { width: 30%; bottom: auto; left: auto; right: -1%; top: 20%; } }

main { display: block; }
main h2 { font-size: 55px; text-align: center; line-height: 1; padding-top: 145px; }
main h2 strong { color: #0072bb; }
@media all and (max-width: 1000px) { main h2 { font-size: 34px; line-height: 1.5; padding: 90px 21px 0; } }
@media all and (max-width: 768px) { main h2 { font-size: 21px; line-height: 1.5; padding: 34px 13px 0; } }
main .mainTxt { text-align: center; margin-top: 21px; font-size: 27px; }
@media all and (max-width: 1200px) { main .mainTxt { margin-top: 21px; font-size: 21px; padding: 0 21px; } }
@media all and (max-width: 768px) { main .mainTxt { margin-top: 13px; font-size: 13px; padding: 0 13px; } }
main .mainTxt2 { text-align: center; padding-top: 90px; font-size: 27px; }
@media all and (max-width: 1200px) { main .mainTxt2 { font-size: 21px; padding: 55px 21px 0; } }
@media all and (max-width: 768px) { main .mainTxt2 { font-size: 13px; padding: 34px 13px 0; } }
main h3 { font-size: 55px; text-align: center; line-height: 1; margin-top: 21px; }
main h3 strong { color: #0072bb; }
@media all and (max-width: 1000px) { main h3 { font-size: 34px; margin-top: 13px; } }
@media all and (max-width: 768px) { main h3 { font-size: 21px; margin-top: 8px; line-height: 1.5; } }
main .btn { margin-top: 90px; text-align: center; line-height: 0; }
main .btn a img:hover { opacity: 0.75; -moz-opacity: 0.75; filter: alpha(opacity=75); }
@media all and (min-width: 768px) and (max-width: 1000px) { main .btn { margin-top: 55px; position: relative; z-index: 100; }
  main .btn img { width: 450px; } }
@media all and (max-width: 768px) { main .btn { margin-top: 34px; padding: 0 21px; position: relative; z-index: 100; }
  main .btn img { width: 100%; } }
main .picArea { margin-top: 34px; position: relative; }
main .picArea ul { display: table; width: 100%; table-layout: fixed; }
main .picArea ul li { width: 50%; display: table-cell; line-height: 0; }
@media all and (max-width: 768px) { main .picArea { margin-top: 13px; }
  main .picArea ul { display: block; }
  main .picArea ul li { width: 100%; display: block; } }
main .picArea figure { position: absolute; left: 50%; }
main .picArea figure.pic1 { margin-left: -650px; bottom: -100px; }
main .picArea figure.pic2 { margin-left: 350px; bottom: -50px; }
main .picArea figure.pic3 { margin-left: 250px; bottom: -150px; }
@media all and (max-width: 1400px) { main .picArea figure.pic1 { margin-left: 0; left: 21px; bottom: -75px; }
  main .picArea figure.pic1 img { width: 200px; }
  main .picArea figure.pic2 { margin-left: 0; left: auto; right: 21px; bottom: -50px; }
  main .picArea figure.pic2 img { width: 250px; }
  main .picArea figure.pic3 { margin-left: 0; left: auto; right: 21px; bottom: -100px; }
  main .picArea figure.pic3 img { width: 250px; } }
@media all and (max-width: 768px) { main .picArea figure.pic1 { margin-left: 0px; bottom: -25px; left: 13px; width: 100px; }
  main .picArea figure.pic2 { margin-left: 0px; bottom: -25px; left: auto; right: 13px; width: 150px; }
  main .picArea figure.pic3 { margin-left: 0px; bottom: -50px; left: auto; right: 13px; width: 150px; } }
main #sec5 { margin-top: 90px; background: url(../images/bg.png) center top repeat; padding-bottom: 90px; }
@media all and (max-width: 1200px) { main #sec5 { padding: 0 21px 90px; } }
@media all and (max-width: 768px) { main #sec5 { margin-top: 34px; padding: 34px 13px 34px 13px; } }
main #sec5 .picArea2 { width: 100%; max-width: 1194px; margin: 0 auto; position: relative; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; -o-box-sizing: border-box; box-sizing: border-box; margin-top: 34px; position: relative; }
main #sec5 .picArea2 ul { display: table; width: 100%; table-layout: fixed; }
main #sec5 .picArea2 ul li { width: 50%; display: table-cell; line-height: 0; background: #fff; position: relative; }
main #sec5 .picArea2 ul li span { display: block; line-height: 1.4; font-weight: bold; padding: 13px 21px; text-align: center; }
main #sec5 .picArea2 ul li .pic1 { position: absolute; left: -50px; bottom: 70px; }
@media all and (max-width: 1200px) { main #sec5 .picArea2 ul li .pic1 { width: 150px; } }
@media all and (max-width: 768px) { main #sec5 .picArea2 ul li .pic1 { left: auto; right: -20px; bottom: -10px; width: 80px; z-index: 1000; } }
main #sec5 .picArea2 ul li .pic2 { position: absolute; right: -50px; bottom: 70px; }
@media all and (max-width: 1200px) { main #sec5 .picArea2 ul li .pic2 { width: 150px; right: -20px; } }
@media all and (max-width: 768px) { main #sec5 .picArea2 ul li .pic2 { left: auto; right: -10px; bottom: -10px; width: 80px; z-index: 1000; } }
@media all and (max-width: 768px) { main #sec5 .picArea2 { margin: 13px 0 34px; }
  main #sec5 .picArea2 ul { display: block; }
  main #sec5 .picArea2 ul li { width: 100%; display: table; }
  main #sec5 .picArea2 ul li img { display: table-cell; width: 100%; letter-spacing: normal; vertical-align: middle; }
  main #sec5 .picArea2 ul li span { display: table-cell; width: 50%; padding: 0; vertical-align: middle; letter-spacing: normal; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; -o-box-sizing: border-box; box-sizing: border-box; padding: 0 13px; } }
main #sec5 .picArea3 { width: 100%; max-width: 1194px; margin: 0 auto; position: relative; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; -o-box-sizing: border-box; box-sizing: border-box; margin-top: 34px; position: relative; }
main #sec5 .picArea3 ul { width: 100%; letter-spacing: -0.4em; line-height: 0; }
main #sec5 .picArea3 ul li { display: inline-block; letter-spacing: normal; line-height: 0; width: 33.33333%; }
main #sec5 .picArea3 ul li:nth-child(1) { width: 100%; display: block; }
@media all and (max-width: 768px) { main #sec5 .picArea3 { margin-top: 13px; } }

footer { padding: 34px 0 0; background: #fff; }
footer .bnr { text-align: center; letter-spacing: -0.4em; }
footer .bnr li { display: inline-block; letter-spacing: normal; vertical-align: top; line-height: 0; max-width: 282px; width: 25%; margin: 0 20px; }
footer .bnr li img { max-width: 100%; }
@media all and (min-width: 768px) and (max-width: 1000px) { footer .bnr li { margin: 0 10px; } }
@media all and (max-width: 768px) { footer { padding: 21px 0 0; }
  footer .bnr li { display: block; width: 100%; margin: 0; padding: 8px 16px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; -ms-box-sizing: border-box; -o-box-sizing: border-box; box-sizing: border-box; max-width: 500000px; text-align: center; }
  footer .bnr li img { max-width: 50000px; width: 50%; } }
footer .copy { margin-top: 34px; border-top: 1px solid #ccc; padding: 21px 0; text-align: center; font-size: 13px; }
@media all and (min-width: 768px) and (max-width: 1000px) { footer .copy { font-size: 14px; } }
@media all and (max-width: 768px) { footer .copy { font-size: 10px; padding: 16px 0; margin-top: 25px; } }
