/* ================================================== *
 *
 *    reset
 *
 * ================================================== */
section, nav, article, aside, hgroup, header, footer, figure, figcaption, details {
  display: block; }

video, audio, canvas {
  display: inline-block;
  *display: inline;
  *zoom: 1; }

audio:not([controls]) {
  display: none; }

[hidden] {
  display: none; }

html {
  font-size: 100%;
  overflow-y: scroll;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%; }

body {
  margin: 0; }

h1, h2, h3, h4, h5, h6 {
  font-size: 1em;
  margin: 0; }

p, blockquote, dl, dd, figure {
  margin: 0; }

hr {
  color: inherit;
  height: auto;
  -moz-box-sizing: content-box;
  box-sizing: content-box; }

pre {
  font-family: monospace, sans-serif;
  white-space: pre-wrap;
  word-wrap: break-word;
  margin: 0; }

ol, ul {
  padding: 0;
  margin: 0; }

li {
  list-style: none; }

a:focus {
  outline: thin dotted; }

a:hover, a:active {
  outline: 0; }

strong, b {
  font-weight: bold; }

small {
  font-size: 0.83em; }

q {
  quotes: none; }

abbr[title] {
  border-bottom: 1px dotted; }

code, samp, kbd {
  font-family: monospace, sans-serif; }

mark {
  color: black;
  background-color: yellow; }

sub, sup {
  font-size: 0.83em;
  line-height: 0;
  vertical-align: baseline;
  position: relative; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

br {
  *letter-spacing: 0; }

img {
  border: 0;
  vertical-align: middle;
  -ms-interpolation-mode: bicubic; }

svg:not(:root) {
  overflow: hidden; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption {
  padding: 0;
  text-align: left; }

th, td {
  text-align: left;
  vertical-align: baseline;
  padding: 0; }

form {
  margin: 0; }

fieldset {
  border: 0;
  padding: 0;
  margin: 0; }

legend {
  border: 0;
  *margin-left: -7px; }

input, button, select, textarea {
  font-family: inherit;
  font-size: 1em;
  color: inherit;
  margin: 0; }

input, button {
  line-height: normal;
  vertical-align: inherit;
  *vertical-align: middle; }

input::-moz-focus-inner, button::-moz-focus-inner {
  border: 0;
  padding: 0; }

input[type="search"] {
  -webkit-appearance: textfield;
  -moz-box-sizing: content-box;
  box-sizing: content-box; }

input[type="search"]:focus {
  outline-offset: -2px; }

input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

input[type="checkbox"], input[type="radio"] {
  -moz-box-sizing: border-box;
       box-sizing: border-box;
  padding: 0; }

input[type="submit"], input[type="reset"], input[type="button"], button {
  cursor: pointer;
  -webkit-appearance: button;
  *overflow: visible; }

select {
  line-height: normal; }

textarea {
  vertical-align: top;
  overflow: auto;
  *font-family: sans-serif; }

/* ================================================== *
 *
 *    base
 *
 * ================================================== */
body {
  font-size: 87.5%;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", sans-serif;
  line-height: 1.5;
  color: #000;
  background: #fff;
  -webkit-text-size-adjust: 100%; }

a:visited, a:link {
  color: #00f; }

a:active, a:hover {
  color: #999; }

/* ================================================== *
 *
 *    helper
 *
 * ================================================== */
/* ------------------------------------------------- *
 *        clearfix
 * ------------------------------------------------- */
.h-clearfix:before, .h-clearfix:after {
  content: "";
  display: table; }

.h-clearfix:after {
  clear: both; }

.h-clearfix {
  *zoom: 1; }

/* ------------------------------------------------- *
 *        marginTop
 * ------------------------------------------------- */
.h-mt0 {
  margin-top: 0px !important; }

.h-mt5 {
  margin-top: 5px !important; }

.h-mt10 {
  margin-top: 10px !important; }

.h-mt15 {
  margin-top: 15px !important; }

.h-mt20 {
  margin-top: 20px !important; }

.h-mt25 {
  margin-top: 25px !important; }

.h-mt30 {
  margin-top: 30px !important; }

.h-mt35 {
  margin-top: 35px !important; }

.h-mt40 {
  margin-top: 40px !important; }

.h-mt45 {
  margin-top: 45px !important; }

.h-mt50 {
  margin-top: 50px !important; }

.h-mt55 {
  margin-top: 55px !important; }

.h-mt60 {
  margin-top: 60px !important; }

/* ------------------------------------------------- *
 *        responsiveImg
 * ------------------------------------------------- */
.h-responsiveImg {
  width: 100%;
  height: auto; }

/* ================================================== *
 *
 *    frame
 *
 * ================================================== */
/* ------------------------------------------------- *
 *        frame1
 * ------------------------------------------------- */
.frame1 {
  background: #333; }

.frame1__inner {
  padding: 20px 10px; }

/* ================================================== *
 *
 *    text
 *
 * ================================================== */
/* ------------------------------------------------- *
 *        text1
 * ------------------------------------------------- */
.text1 {
  margin: 20px 10px 0; }
  .text1 p {
    margin: 15px 0 0; }

/* ------------------------------------------------- *
 *        caption1
 * ------------------------------------------------- */
.caption1 {
  font-size: 10px;
  color: #666;
  margin: 5px 10px 0; }

/* ------------------------------------------------- *
 *        caption2
 * ------------------------------------------------- */
.caption2 {
  font-size: 10px;
  color: #666;
  margin: 20px 10px 0; }
  .caption2 a {
    color: #666; }

/* ------------------------------------------------- *
 *        caption3
 * ------------------------------------------------- */
.caption3 {
  font-size: 12px;
  color: #fff;
  background-color: #000;
  padding: 5px 0 10px;
  text-align: center; }

/* ------------------------------------------------- *
 *        caption4
 * ------------------------------------------------- */
.caption4 {
  margin: 0;
}
.caption4 span {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}
.caption4 li {
  position: relative;
  margin-top: 10px;
  padding: 0 0 0 24px;
  font-size: 10px;
  color: #666;
}
.caption4 a {
  color: #666;
}

/* ------------------------------------------------- *
 *        caption5
 * ------------------------------------------------- */
.caption5 {
  margin: 10px 0 0;
}
.caption5 li {
  position: relative;
  padding: 0 0 0 1.5em;
  text-indent: -1.5em;;
  font-size: 10px;
  color: #666;
}
.caption5 li:first-child {
  margin-top: 0;
}

/* ================================================== *
 *
 *    movie
 *
 * ================================================== */
/* ------------------------------------------------- *
 *        movie
 * ------------------------------------------------- */
.movie1 {}
.movie1__link {
  position: relative;
  display: block;
  padding: 5px 100px 5px 20px;
  background: #fd8300;
  text-decoration: none;
}
.movie1__link:after {
  content: "";
  position: absolute;
  right: 26px;
  bottom: 2px;
  display: block;
  width: 52px;
  height: 67px;
  background: url('../img_smp/img_robohon.png') 0 0 no-repeat;
  background-size: 52px auto;
}
.movie1__link__mainLabel {
  display: inline-block;
  padding-right: 12px;
  background: url('../img_smp/ico_arrow4_right.png') 100% 50% no-repeat;
  background-size: 4px auto;
  color: #fff;
  font-size: 12px;
  font-weight: bold;
}
.movie1__link__subLabel {
  display: block;
  color: #000;
  font-size: 11px;
}

/* ================================================== *
 *
 *    layout
 *
 * ================================================== */
.l-document {
  position: relative; }

/* ================================================== *
 *
 *    title
 *
 * ================================================== */
/* ------------------------------------------------- *
 *        title1
 * ------------------------------------------------- */
.title1 {
  position: relative;
  border-top: 1px solid #333;
  padding-left: 60px; }

.title1__logo {
  position: absolute;
  left: 0;
  top: 0; }


/* ================================================== *
 *
 *    button
 *
 * ================================================== */
/* ------------------------------------------------- *
 *        button1
 * ------------------------------------------------- */
.button1 a {
  font-weight: bold;
  font-size: 15px;
  letter-spacing: -0.03em;
  display: block;
  color: #000;
  background: #fff;
  text-decoration: none;
  text-align: center;
  position: relative;
  padding: 15px; }
  .button1 a:before {
    display: block;
    content: '';
    width: 7px;
    height: 15px;
    background: url('../img_smp/ico_arrow_right.png') 0 0 no-repeat;
    background-size: 7px auto;
    position: absolute;
    right: 10px;
    top: 0;
    bottom: 0;
    margin: auto 0; }

/* ------------------------------------------------- *
 *        button2
 * ------------------------------------------------- */
.button2 a {
  font-weight: bold;
  font-size: 15px;
  letter-spacing: -0.03em;
  line-height: 1.3;
  display: block;
  color: #fff;
  background: #333;
  text-decoration: none;
  text-align: center;
  position: relative;
  padding: 9px;
  border: 1px solid #fff; }
  .button2 a:before {
    display: block;
    content: '';
    width: 7px;
    height: 15px;
    background: url('../img_smp/ico_arrow_right_2.png') 0 0 no-repeat;
    background-size: 7px auto;
    position: absolute;
    right: 10px;
    top: 0;
    bottom: 0;
    margin: auto 0; }

/* ================================================== *
 *
 *    block
 *
 * ================================================== */
/* ------------------------------------------------- *
 *        header
 * ------------------------------------------------- */
.header__logo {
  line-height: 1;
  text-align: center;
  padding: 16px 0; }

.header__btnShare {
  display: block;
  width: 50px;
  height: 50px;
  border: none;
  background: #fff url('../img_smp/btn_share_off.png') 0 0 no-repeat;
  background-size: 50px auto;
  white-space: nowrap;
  overflow: hidden;
  text-indent: 200%;
  position: absolute;
  right: 0;
  top: 0; }

.header__share {
  background: #E6E6E6;
  text-align: center;
  display: none; }
  .header__share li {
    display: inline-block;
    vertical-align: middle;
    height: 24px;
    overflow: hidden;
    margin: 10px 2px; }

/* ------------------------------------------------- *
 *        footer
 * ------------------------------------------------- */
.footer__navs {
  overflow: hidden; }
  .footer__navs li {
    width: 50%;
    float: left;
    -moz-box-sizing: border-box;
         box-sizing: border-box; }
    .footer__navs li:first-child a {
      border-right: 1px solid #DCDCDC; }
    .footer__navs li:last-child {
      width: 100%; }
      .footer__navs li:last-child a {
        text-align: center; }
        .footer__navs li:last-child a:after {
          display: block;
          content: '';
          width: 15px;
          height: 15px;
          background: url('../img_smp/ico_global.png') 0 0 no-repeat;
          background-size: 15px auto;
          position: absolute;
          left: 10px;
          top: 0;
          bottom: 0;
          margin: auto 0; }
  .footer__navs a {
    position: relative;
    display: block;
    background: #FAFAFA;
    border-bottom: 1px solid #DCDCDC;
    color: #666666;
    text-decoration: none;
    padding: 16px 10px; }
    .footer__navs a:before {
      display: block;
      content: '';
      width: 12px;
      height: 15px;
      background: url('../img_smp/ico_arrow2_right.png') 0 0 no-repeat;
      background-size: 12px auto;
      position: absolute;
      right: 10px;
      top: 0;
      bottom: 0;
      margin: auto 0; }

.footer__copy {
  padding: 15px 0;
  display: block;
  text-align: center;
  font-family: 'Helvetica Neue';
  font-weight: bold; }

/* ------------------------------------------------- *
 *        heading
 * ------------------------------------------------- */
.heading {
  background: #333; }

/* ------------------------------------------------- *
 *        keyVisual
 * ------------------------------------------------- */
.keyVisual {
  position: relative; }

/* ------------------------------------------------- *
 *        block1
 * ------------------------------------------------- */
.block1 {
  background-color: #ececec;
  padding: 20px;
  font-size: 85.7%; }

.block1__title {
  font-weight: bold; }
  .block1__title:before {
    content: '●'; }

/* ------------------------------------------------- *
 *        lnav
 * ------------------------------------------------- */
.lnav {
  overflow: hidden; }
  .lnav .link_challenge-top {
    -moz-box-sizing: border-box;
         box-sizing: border-box; }
  .lnav .link_challenge-top a {
    position: relative;
    display: block;
    border-bottom: 1px solid #DCDCDC;
    color: #666666;
    text-decoration: none;
    text-align: center;
    padding: 16px 10px; }
    .lnav .link_challenge-top a:before {
      display: block;
      content: '';
      width: 12px;
      height: 15px;
      background: url('../img_smp/ico_arrow2_right.png') 0 0 no-repeat;
      background-size: 12px auto;
      position: absolute;
      right: 10px;
      top: 0;
      bottom: 0;
      margin: auto 0; }
  .lnav .archive {
    -moz-box-sizing: border-box;
         box-sizing: border-box; }
    .lnav .archive .bold {
	  font-family: 'Helvetica Neue';
	  font-weight: bold;
	}
  .lnav .archive a, .lnav .archive .current {
    position: relative;
    display: block;
    border-bottom: 1px solid #DCDCDC;
    color: #666666;
    text-decoration: none;
    padding: 16px 10px; }
    .lnav .archive a:before {
      display: block;
      content: '';
      width: 12px;
      height: 15px;
      background: url('../img_smp/ico_arrow2_right.png') 0 0 no-repeat;
      background-size: 12px auto;
      position: absolute;
      right: 10px;
      top: 0;
      bottom: 0;
      margin: auto 0; }
      .lnav .archive .img {
	    display: table-cell;
		width: 80px;
		height: 80px;
		line-height: 0; }
      .lnav .archive .txt {
	    display: table-cell;
		width: 100%;
		vertical-align: middle;
		padding: 0 20px 0 10px; }
  .lnav .archive .current {
    color: #999;
    background-color: #dcdcdc; }
