/*=============================================================
 02_base
=============================================================*/
/*!  02_base
================================================ */
html { overflow: auto; }
body { min-width: 320px; overflow: hidden; color: #353536; font-family: "Noto Sans Japanese","sans-serif"; letter-spacing: .05em; }
/* forPC */
@media screen and (min-width: 600px) { body { min-width: 1050px; } }
img { max-width: 100%; }
.viewPc { display: none; }
/* forPC */
@media screen and (min-width: 600px) { .viewSp { display: none; }  .viewPc { display: inherit; } }
.colorRed { color: #eb392d; }
.colorBlue { color: #123a80; }
/*=============================================================
 03_layout
=============================================================*/
/*!  #gHeader
================================================ */
#gHeader { position: fixed; top: 0; right: 0; left: 0; z-index: 10; width: 100%; -webkit-transition: all linear .3s; transition: all linear .3s; }
#gHeader.fixed { background: #fff; }
#gHeader .hdIn { overflow: hidden; padding: 10px 10px 10px 15px; }
#gHeader .logo { float: left; width: 196px; padding: 14px 0 0 0; }
#gHeader .scrollToContact { position: relative; top: 0; float: right; width: 50px; border-radius: 4px; background: #eb392d; text-align: center; box-shadow: 0 4px 0 0 #c31d12; }
#gHeader .scrollToContact:hover { top: 4px; -webkit-transition: all linear .3s; transition: all linear .3s; box-shadow: none; }
@media screen and (min-width: 600px) { #gHeader .scrollToContact { box-shadow: 0 5px 0 0 #c31d12; }  #gHeader .scrollToContact:hover { top: 5px; } }
#gHeader .scrollToContact a { display: block; padding: 12px 0 10px; color: #fff; font-weight: bold; text-decoration: none; letter-spacing: .1em; }
#gHeader .scrollToContact img { display: block; width: 23px; margin: 0 auto 2px; }
/* forPC */
@media screen and (min-width: 600px) { #gHeader .hdIn { padding: 15px 0 19px; }  #gHeader .logo { width: 297px; padding: 5px 0 0 0; }  #gHeader .scrollToContact { width: 180px; }  #gHeader .scrollToContact a { position: relative; line-height: 1.23; padding: 11px 0 10px; font-size: 1.3rem; }  #gHeader .scrollToContact a:after { display: block; position: absolute; right: 5px; bottom: 5px; clear: both; width: 0; height: 0; border-width: 0 0 7px 7px; border-style: solid; border-color: transparent transparent #fff transparent; content: ""; }  #gHeader .scrollToContact img { display: inline-block; position: relative; top: -5px; margin: 0 8px -2px 0; }  #gHeader .scrollToContact .viewPc { display: inline-block; } }
#gNav { float: right; width: 540px; }
#gNav .link { width: 100%; }
#gNav .link:after { display: block; clear: both; content: ""; }
#gNav .link li { display: table; float: left; width: 20%; min-height: 50px; }
#gNav .link li a { display: table-cell; position: relative; line-height: 1.14; padding: 10px 0; color: #353536; font-weight: bold; font-size: 1.4rem; text-decoration: none; text-align: center; vertical-align: middle; }
#gNav .link li a:after { display: block; position: absolute; bottom: -6px; left: 50%; width: 11px; height: 7px; margin-left: -5.5px; background-image: url("../img/common/ico_arw01_bottom.png"); background-repeat: no-repeat; background-position: center; background-size: contain; content: ""; -webkit-transition: all linear .3ss; transition: all linear .3ss; }
#gNav .link li:hover a:after { bottom: -8px; }
/*!  #mainimg
================================================ */
#mainImg { position: relative; padding: 140px 15px 130px; background: url("../img/home/bg_mainimg01_sp.png") no-repeat center; background-size: cover; }
#mainImg .mainimgIn { position: relative; height: 255px; }
#mainImg .mainTxt { position: absolute; top: 50%; left: 50%; width: 100%; text-align: center; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }
#mainImg .copy { position: relative; padding: 5px 0; border: 2px solid #353536; border-radius: 2px; background: #fff; font-size: 1.5rem; letter-spacing: .075em; }
#mainImg .copy:after { display: block; position: absolute; left: 50%; box-sizing: border-box; width: 10px; height: 10px; border-width: 2px; border-style: solid; border-color: transparent transparent #353536 #353536; background: #fff; content: ""; -webkit-transform: rotate(-45deg); transform: rotate(-45deg); }
#mainImg .copy img { width: 21px; }
#mainImg .copy span { display: inline-block; padding: 0 0 5px; font-weight: bold; }
#mainImg .tit { line-height: 1.25; margin-top: 15px; font-weight: bold; font-size: 2.4rem; letter-spacing: -.015em; }
#mainImg .tit img { position: relative; bottom: -4px; width: 114px; }
#mainImg .txt { width: 243px; overflow: hidden; margin: 10px auto 0; }
#mainImg .txt li { position: relative; float: left; width: 118px; height: 118px; border-radius: 50%; background: #fff; }
#mainImg .txt li + li { float: right; }
#mainImg .txt li span { position: absolute; top: 50%; left: 50%; width: 100%; line-height: 1.33; color: #1693d4; font-weight: 900; font-size: 1.5rem; text-align: center; letter-spacing: .075em; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }
/* forPC */
@media screen and (min-width: 600px) { #mainImg { padding: 228px 0 198px; background-image: url("../img/home/bg_mainimg01_pc.png"); }  #mainImg .mainimgIn { height: 494px; }  #mainImg .copy { box-sizing: border-box; width: 500px; margin: 0 auto; padding: 12px 0 12px; border-width: 3px; border-radius: 3px; font-size: 2.4rem; }  #mainImg .copy:after { bottom: -10px; width: 20px; height: 20px; margin-left: -10px; border-width: 3px; }  #mainImg .copy img { width: 36px; margin: 0 4px -8px -4px; }  #mainImg .copy span { padding: 0 0 5px; }  #mainImg .tit { line-height: 1.26; margin-top: 30px; font-size: 6.8rem; letter-spacing: .01em; }  #mainImg .tit img { bottom: -4px; width: 281px; }  #mainImg .txt { width: 366px; margin: 20px auto 0; }  #mainImg .txt li { width: 176px; height: 176px; }  #mainImg .txt li span { line-height: 1.4; font-size: 2rem; } }
.pageTop { padding: 20px 0; background: #65b1e1; text-align: center; }
.pageTop a { display: inline-block; width: 35px; height: 35px; overflow: hidden; background: url("../img/common/ico_pagetop01.png") no-repeat center; background-size: contain; text-indent: 200%; white-space: nowrap; }
/* forPC */
@media screen and (min-width: 600px) { .pageTop { position: fixed; right: 30px; bottom: 268px; width: 50px; height: 50px; padding: 0; border-radius: 50%; background-color: #123a80; opacity: 0; -webkit-transition: all linear .3s; transition: all linear .3s; -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)"; }  .pageTop.visible { opacity: 1; -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)"; }  .pageTop a { width: 50px; height: 50px; background-image: url("../img/common/ico_pagetop02.png"); } }
/*!  #gFooter
================================================ */
#gFooter { background: #fff; }
#gFooter .ftIn { position: relative; line-height: 1.33; padding: 22px 20px 0; font-size: 1.2rem; }
#gFooter .logo { width: 200px; }
#gFooter .appeal { width: 107px; line-height: 1; margin-top: 15px; padding: 9px 0 8px; border: 1px solid #1693d4; color: #1693d4; font-size: 1.3rem; text-align: center; }
#gFooter address { margin-top: 13px; }
#gFooter .telAndFax { margin-top: 6px; }
#gFooter .time { margin-top: 6px; }
#gFooter .listBnr { overflow: hidden; margin: 13px -3px 0 -2px; }
#gFooter .listBnr li { float: left; box-sizing: border-box; width: 50%; }
#gFooter .listBnr li:nth-child(odd) { padding-right: 3px; }
#gFooter .listBnr li:nth-child(even) { padding-left: 3px; }
#gFooter .listBnr li:nth-child(n+3) { margin-top: 5px; }
#gFooter .copyright { margin: 20px -20px 0; background: #1693d4; color: #fff; text-align: center; }
#gFooter .copyright small { display: block; padding: 20px 0 16px; font-size: 1rem; }
/* forPC */
@media screen and (min-width: 600px) { #gFooter .ftIn { line-height: 1.85; padding: 40px 20px 0; font-size: 1.3rem; letter-spacing: .05em; }  #gFooter .ftIn:after { display: block; clear: both; content: ""; }  #gFooter .logo { width: 280px; padding-left: 0; }  #gFooter .appeal { position: absolute; top: 46px; left: 320px; width: 116px; padding: 2px 0 3px; }  #gFooter address { margin-top: 17px; }  #gFooter .telAndFax { overflow: hidden; margin-top: 0; }  #gFooter .telAndFax li { float: left; }  #gFooter .telAndFax li + li { margin-left: 14px; }  #gFooter .time { margin-top: 0; }  #gFooter .listBnr { position: absolute; top: 50px; right: 0; width: 536px; margin: 0; }  #gFooter .listBnr li { width: 172px; }  #gFooter .listBnr li + li { margin-left: 10px; }  #gFooter .listBnr li:nth-child(odd) { padding: 0; }  #gFooter .listBnr li:nth-child(even) { padding: 0; }  #gFooter .listBnr li:nth-child(n+3) { margin-top: 0; }  #gFooter .copyright { margin: 45px -200% 0; padding: 0 200%; letter-spacing: .075em; }  #gFooter .copyright small { padding: 20px 0 16px; font-size: 1.2rem; } }