@charset "UTF-8";
/* ==========================================================
 html5 elements
========================================================== */
article, aside, figure, figcaption, footer, header, nav, section
{ display: block;}
/* ==========================================================
 reseting
========================================================== */
body {
  line-height: 1.6;
  color: #000000;
  font-size: 10px;
  -webkit-text-size-adjust: 100%;
}
body, input, textarea, select, button {
  font-family: "Hiragino Sans", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}
body, div, pre, p, blockquote, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, form, fieldset, th, td, button, figure, figcaption
{ margin: 0; padding: 0;}
input, textarea
{ margin: 0; font-size: 100%;}
textarea
{ resize: none;}
button
{ border: none; overflow: visible; background: none; vertical-align: top;  font-size: 100%; color: inherit; cursor: pointer; -webkit-appearance: none;}
label
{ cursor: pointer;}
table
{ border-collapse: collapse; border-spacing: 0; font-size: 100%;}
fieldset, img
{ border: 0;}
img
{ height: auto; vertical-align: top;}
address, caption, code, em, th
{ font-style: normal; font-weight: normal;}
ol, ul
{ list-style: none;}
caption, th
{ text-align: left;}
h1, h2, h3, h4, h5, h6, strong, em
{ font-size: 100%; font-weight: normal;}
sup, sub
{ font-size: 63%;}
sup
{ vertical-align: top;}
sub
{ vertical-align: baseline;}
*
{ box-sizing: border-box; -webkit-box-sizing: border-box;}
/* ==========================================================
 base Link
========================================================== */
a {
  color: #000;
  text-decoration: none;
}
a:visited {
  color: #000;
  text-decoration: none;
}
a:hover,
a:active,
a:focus { text-decoration: underline;}
/* ==========================================================
 clearfix
========================================================== */
.clearfix:before, .clearfix:after,
.contents:before, .contents:after
{
  content: "";
  display: table;
}
.clearfix:after,
.contents:after
{
  clear: both;
}
/* ==========================================================
 layout
========================================================== */
html { width: 100%; height: 100%; overflow-y: scroll;}
body { text-align: center; height: 100%; }
/* ==========================================================
 wrapper
========================================================== */
.body-in { width: 100%; height: 100%; padding-top: 48px; }
.body-in::before {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100vh;
  background: url(../img/bg_01.svg) 50% 100%/cover no-repeat;
  content: "";
  }
/* ==========================================================
 header
========================================================== */
.header {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 9999;
  width: 100%;
  height: 48px;
  margin: 0 auto;
  background-color: #FFF;
  text-align: left;
}
.header-logo {
  float: left;
  margin: 3px 0 0 16px;
}
.header-logo a {
  display: inline-block;
  height: 21px;
  font-size: 19px;
}
.logo-top {
  width: 59px;
  height: 43px;
}
.ico-top {
  width: 49px;
  height: 21px;
}
.header-utility {
  font-size: 0;
  text-align: right;
}
.header-utility li {
  display: inline-block;
  font-size: 9px;
  text-align: center;
}
.still {
  width: 67px;
  height: 48px;
  background: url(../img/bg_02.svg) center no-repeat;
}
.sparkling {
  width: 91px;
  height: 48px;
  background: url(../img/bg_03.svg) center no-repeat;
}
.header-utility p {
  padding-top: 9px;
}
#unpushed a img {
  width: 32px;
}
#pushed {
  display: none;
}
#pushed a img {
  width: 32px;
}
/* ==========================================================
 footer
========================================================== */
.footer {
  position: fixed;
  z-index: 9999;
  bottom: 0;
  width: 100%;
  height: 83px;
  background: #FFF;
}
.footer-links {
  height: 10px;
  margin: 19px 0 0 0;
}
.footer-links a {
  display: inline-block;
  padding: 0 16.5px 0 16.5px;
  border-right: 1px solid #000 ;
}
.footer-links a:last-child {
  border-right: none;
}
.footer-utility {
  width: 240.42px;
  margin: 7px 0 0 67.09px;
}
.footer-logo-01 {
  width: 126.5px;
}
.footer-logo-02 {
  width: 62px;
}
.footer-logo-03 {
  width: 30.25px;
}
.footer-utility li {
  display: inline-block;
}
.footer-copyright {
  margin: 1.75px 0 0 0;
  font-size: 6px;
}
/* ==========================================================
 style
========================================================== */
.s-fw-n     { font-weight: normal;}
.s-fw-b     { font-weight: bold;}
.s-ta-l     { text-align: left !important;}
.s-ta-c     { text-align: center !important;}
.s-ta-r     { text-align: right !important;}
.s-va-t     { vertical-align: top !important;}
.s-va-m     { vertical-align: middle !important;}
.s-va-b     { vertical-align: bottom !important;}
.s-ov-h     { overflow: hidden;}
.s-clear    { clear: both;}
.s-hide     { display: none;}
.s-txt-hide { text-indent: 100%; white-space: nowrap; overflow: hidden;}
.s-bg-n     { background: none !important;}
.s-mt-00    { margin-top: 0 !important;}
.s-mb-00    { margin-bottom: 0 !important;}
.s-ml-00    { margin-left: 0 !important;}
.s-mr-00    { margin-right: 0 !important;}
/* ==========================================================
 rwd switch
========================================================== */
/* pc
---------------------------------------------------------- */
.only-pc { display: block !important; }
.only-tb,
.only-sp,
.no-pc { display: none !important;}
/* tb
---------------------------------------------------------- */
@media screen and (max-width: 1024px) {
.only-pc,
.no-tb    { display: none !important;}
.only-tb,
.no-pc    { display: block !important;}
img.only-tb,
img.no-pc { display: inline-block !important;}
}
/* sp
---------------------------------------------------------- */
@media screen and (max-width: 768px) {
.only-pc,
.no-sp,
.only-tb,
img.only-tb  { display: none !important;}
.only-sp,
.no-pc,
.no-tb     { display: block !important;}
img.only-sp,
img.no-pc,
img.no-tb  { display: inline-block !important;}
}
/* ==========================================================
 tool
========================================================== */
.atode { padding: 10px; border: 2px solid #8c0000; background-color: #ff4d4d; color: #fff; font-size: 30px; text-align: center;}