/* ================================================== *
 *
 *    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: #84c5ce; }

.frame1__inner {
  padding: 20px 10px; }

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

/* ------------------------------------------------- *
 *        text3
 * ------------------------------------------------- */
.text3 {
  margin: 20px 0 0;
  padding: 10px 10px 30px;
  background-color: #000; }
  .text3 p {
	text-align: center; }

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

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

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

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

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

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

/* ------------------------------------------------- *
 *        title2
 * ------------------------------------------------- */
.title2 {
  position: relative;
  border-top: 1px solid #84c5ce;
  border-bottom: 1px solid #84c5ce;
  padding-left: 60px; }

.title2__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 a {
  font-weight: bold;
  font-size: 15px;
  letter-spacing: -0.03em;
  line-height: 1.3;
  display: block;
  color: #fff;
  background: #84c5ce;
  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 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: #84c5ce; }

/* ------------------------------------------------- *
 *        keyVisual
 * ------------------------------------------------- */
.keyVisual {
  width: 100%;
  position: relative;
  background: url(/challenge/vol10/img_smp/kv_img1.jpg) 0 0 no-repeat;
  background-size: 100% auto; }
  .bxslider img {
    width: 100%; }

/* ------------------------------------------------- *
 *        block1
 * ------------------------------------------------- */
.block1 {
  color: #E95283;
  margin: 0 10px;
  padding-top: 20px;
  border-top: 1px solid #E95283;
  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; }
