@charset "UTF-8";
#navi::after, .news-category::after {
  display: block;
  clear: both;
  content: '';
}

/*! normalize.css v2.1.0 | MIT License | git.io/normalize */
/**
 * Correct `block` display not defined in IE 8/9.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
  display: block;
}

/**
 * Correct `inline-block` display not defined in IE 8/9.
 */
audio,
canvas,
video {
  display: inline-block;
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address styling not present in IE 8/9.
 */
[hidden] {
  display: none;
}

/**
 * Correct overflow displayed oddly in IE 9.
 */
svg:not(:root) {
  overflow: hidden;
}

/**
 * Address margin not present in IE 8/9 and Safari 5.
 */
figure {
  margin: 0;
}

/***************************************
 * Global
 ***************************************/
body {
  font-family: 'Noto Sans JP','Lucida Grande', "Yu Gothic", "游ゴシック", YuGothic, 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
  margin: 0;
  padding: 0;
  line-height: 1.4;
  color: #333;
  font-size: 90%;
}

@media screen and (max-width: 999px) {
  body {
    min-width: 0;
    -webkit-text-size-adjust: none;
  }
}

img {
  margin: 0;
  border: none;
  vertical-align: middle;
  max-width: 100%;
}

h1 {
  font-size: 180%;
}

p {
  line-height: 2;
}

hr {
  height: 0;
  border: 0;
  border-top: 1px solid #cfd5da;
}

hr.m-minus {
  margin: -7px 0;
}

a {
  color: #004d8e;
  text-decoration: none;
}

a:hover {
  color: #ff0966;
}

ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

ul.bullet {
  margin: 0;
  padding-left: 1em;
  list-style: none;
}

ul.bullet > li::before {
  margin-left: -1em;
  content: '\2022';
  display: inline-block;
  width: 1em;
  text-align: center;
}

.text-list > li {
  margin: 1em 0;
}

.ui-hidden {
  position: absolute;
  display: block;
  width: 1px;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

@media screen and (max-width: 999px) {
  .sp-hidden {
    display: none !important;
  }
}

@media screen and (min-width: 1000px) {
  .sp-only {
    display: none !important;
  }
}

.cn {
  text-align: center;
}

.round-arrow {
  position: relative;
  display: inline-block;
  padding: 0 0 0 16px;
  vertical-align: middle;
  text-decoration: none;
}

.round-arrow::before,
.round-arrow::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
  font-size: 15px;
}

.round-arrow::before {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #077f83;
}

.round-arrow::after {
  left: 3px;
  width: 3px;
  height: 3px;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
  transform: rotate(45deg);
}

/* h2 layout */
.red-line {
  font-size: 120%;
  padding: 20px;
  border-left: 6px solid #ef7000;
  background: #f9f9f9;
  margin: 3em 0 2em 0;
}

.red-line small {
  margin-left: 2em;
}

/* tag */
.tags li {
  display: inline-block;
  margin-bottom: 10px;
  margin-right: 5px;
}

.tags span {
  font-size: 83.33333%;
  padding: 5px 11px 4px;
  line-height: 1;
  border-radius: 3px;
  background-color: #f0f0f0;
  font-weight: normal;
  text-align: center;
  display: inline-block;
}

.tags a {
  color: inherit;
}

.tags a span {
  transition: all 0.2s ease;
}

.tags a:hover span {
  background-color: #ddd;
}

.tags a.active span {
  background-color: #e7cc1a;
}

/* category */
.cat-tip {
  font-size: 83.33333%;
  padding: 5px 11px 4px;
  line-height: 1;
  border-radius: 3px;
  background-color: #f0f0f0;
  font-weight: normal;
  text-align: center;
  display: inline-block;
}

.cat-tip.cat-case {
  color: #fff;
  background-color: #49b3df;
}

.cat-tip.cat-news {
  color: #fff;
  background-color: #077F83;
}

.cat-tip.cat-other {
  color: #fff;
  background-color: #6e6e6e;
}

.cat-tip.cat-report {
  color: #fff;
  background-color: #1c9ebe;
}

/* grid */
.columns {
  margin-right: -25px;
  margin-left: -25px;
}

.columns * {
  box-sizing: border-box;
}

@media screen and (max-width: 999px) {
  .columns {
    margin-right: -12px;
    margin-left: -12px;
  }
}

.columns::after {
  content: "";
  display: table;
  clear: both;
}

.columns .column {
  padding: 25px;
  float: left;
}

@media screen and (max-width: 999px) {
  .columns .column {
    padding: 12px;
  }
}

.columns .column.col1 {
  width: 8.33333%;
}

@media screen and (max-width: 999px) {
  .columns .column.col-sp1 {
    width: 8.33333% !important;
  }
}

.columns .column.col2 {
  width: 16.66667%;
}

@media screen and (max-width: 999px) {
  .columns .column.col-sp2 {
    width: 16.66667% !important;
  }
}

.columns .column.col3 {
  width: 25%;
}

@media screen and (max-width: 999px) {
  .columns .column.col-sp3 {
    width: 25% !important;
  }
}

.columns .column.col4 {
  width: 33.33333%;
}

@media screen and (max-width: 999px) {
  .columns .column.col-sp4 {
    width: 33.33333% !important;
  }
}

.columns .column.col5 {
  width: 41.66667%;
}

@media screen and (max-width: 999px) {
  .columns .column.col-sp5 {
    width: 41.66667% !important;
  }
}

.columns .column.col6 {
  width: 50%;
}

@media screen and (max-width: 999px) {
  .columns .column.col-sp6 {
    width: 50% !important;
  }
}

.columns .column.col7 {
  width: 58.33333%;
}

@media screen and (max-width: 999px) {
  .columns .column.col-sp7 {
    width: 58.33333% !important;
  }
}

.columns .column.col8 {
  width: 66.66667%;
}

@media screen and (max-width: 999px) {
  .columns .column.col-sp8 {
    width: 66.66667% !important;
  }
}

.columns .column.col9 {
  width: 75%;
}

@media screen and (max-width: 999px) {
  .columns .column.col-sp9 {
    width: 75% !important;
  }
}

.columns .column.col10 {
  width: 83.33333%;
}

@media screen and (max-width: 999px) {
  .columns .column.col-sp10 {
    width: 83.33333% !important;
  }
}

.columns .column.col11 {
  width: 91.66667%;
}

@media screen and (max-width: 999px) {
  .columns .column.col-sp11 {
    width: 91.66667% !important;
  }
}

.columns .column.col12 {
  width: 100%;
}

@media screen and (max-width: 999px) {
  .columns .column.col-sp12 {
    width: 100% !important;
  }
}

.columns.narrow-gutter {
  margin-right: -3px;
  margin-left: -2px;
}

.columns.narrow-gutter .column {
  padding: 2px 3px 3px 2px;
}

/* pager */
.pager {
  margin: 40px 0;
  text-align: center;
}

.pager li {
  display: inline-block;
  margin: 0 6px;
}

@media screen and (max-width: 999px) {
  .pager li {
    margin: 0 2px;
  }
}

.pager li a:not(.prev):not(.next) {
  display: block;
  padding: 5px 10px;
  line-height: 1;
  font-size: 104.16666%;
  border-radius: 3px;
  transition: all 0.2s ease;
  color: inherit;
}

.pager li a:not(.prev):not(.next):hover {
  background-color: #f0f0f0;
}

.pager li a:not(.prev):not(.next).active {
  background-color: #077F83;
  color: #fff;
  pointer-events: none;
}

.pager li a.prev, .pager li a.next {
  position: relative;
  display: block;
  text-indent: -9999px;
  width: 32px;
}

@media screen and (max-width: 999px) {
  .pager li a.prev, .pager li a.next {
    width: 25px;
  }
}

.pager li a.prev::after, .pager li a.next::after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 8px;
  height: 8px;
  border-top: 2px solid #333;
  border-right: 2px solid #333;
  transform: rotate(45deg);
  transition: all 0.2s ease;
}

.pager li a.prev::after {
  transform: rotate(-135deg);
}

/* 申込系ボタン非活性 */
.apply-disabled {
  background-color: #ccc;
  color: #eee;
  pointer-events: none;
}

/*ページ内リンク*/
.p-nav {
  border: 1px solid #e0e0e0;
  font-size: 111.11111%;
  font-weight: bold;
  padding: 16px 14px 12px;
  margin: 20px 0;
  text-align: center;
}

.p-nav a {
  color: inherit;
  position: relative;
}

.p-nav a:not(:last-child) {
  margin-right: 102px;
}

.p-nav a::after {
  content: "";
  display: block;
  position: absolute;
  top: -4px;
  right: -22px;
  bottom: 0;
  margin: auto;
  width: 5px;
  height: 5px;
  border-top: 2px solid #333;
  border-right: 2px solid #333;
  transform: rotate(135deg);
  transition: all 0.2s ease;
}

.p-nav.p-nav-voice {
  margin: 22px 0 -17px;
}

@media print {
  #header, #main-image, #side-nav, .bg-dark {
    display: none;
  }
}

.wrapper {
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
}

@media screen and (max-width: 999px) {
  .wrapper {
    width: auto;
  }
}

.wrapper::after, .cf::after, .row::after, .box::after {
  display: block;
  clear: both;
  content: '';
}

/***** header *****/
#header {
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 999px) {
  #header {
    position: fixed;
    top: 0;
    width: 100%;
    background: #fff;
    z-index: 200;
    height: 50px;
  }
}

.header-logos {
  max-width: 465px;
  margin: 0 460px 0 0;
}

@media screen and (max-width: 999px) {
  .header-logos {
    max-width: 80%;
    margin: 0;
  }
  .header-logos > img {
    max-height: 50px;
    margin-left: 5px;
  }
}

#main-image {
  text-align: center;
  position: relative;
  top: -40px;
  margin-bottom: -40px;
}

@media screen and (max-width: 999px) {
  #main-image {
    top: 50px;
    margin-bottom: 50px;
  }
}

#main-image > img {
  max-height: 315px;
}

#top #main-image > img {
  max-height: 580px;
}

#breadcrumbs-wrapper {
  width: 100%;
  position: absolute;
  top: 40px;
}

#top #breadcrumbs-wrapper {
  top: 0;
}

#breadcrumbs {
  text-align: left;
  list-style: none;
  margin: 1em 0;
  padding: 0;
  font-size: 85%;
}

@media screen and (max-width: 999px) {
  #breadcrumbs {
    display: none;
  }
}

#breadcrumbs li {
  display: inline;
  margin: 0;
}

#breadcrumbs li::before {
  content: ' / ';
}

#breadcrumbs li:first-child::before {
  display: none;
}

#breadcrumbs li a {
  color: #333;
}

/***** footer *****/
#footer {
  position: relative;
}

#top-anchor {
  display: block;
  position: absolute;
  top: -80px;
  right: 20px;
  width: 55px;
  height: 55px;
  background: rgba(0, 0, 0, 0.5) url(../images/icon/arrow_top.png) 50% 50%/23.5px 13.5px no-repeat;
  border-radius: 5px;
}

.bg-dark {
  background: #333;
  color: #fff;
}

.bg-dark a {
  color: #fff !important;
}

.bg-black {
  background: #000;
  color: #fff;
}

.bg-black a {
  color: #fff !important;
}

#links {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  padding: 30px 0 0 0;
}

@media screen and (max-width: 999px) {
  #links {
    display: none;
  }
}

#links h3 {
  font-size: 100%;
}

#links > div {
  -ms-flex: auto;
      flex: auto;
  margin-right: 30px;
}

#links ul {
  margin: 0 0 2em 0;
}

#links ul > li {
  margin: 10px 0;
  font-size: 90%;
}

#links ul > li > a {
  position: relative;
  display: inline-block;
  padding-left: 15px;
}

#links ul > li > a::before {
  content: '';
  width: 4px;
  height: 4px;
  border: 0px;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(45deg);
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -4px;
}

.sns-list {
  padding: 0 1em 30px;
  text-align: right;
}

@media screen and (max-width: 999px) {
  .sns-list {
    padding: 0 13px 1em;
  }
}

.sns-list .sns-liststyle {
  display: inline-block;
  vertical-align: middle;
}

.sns-list .sns-liststyle:nth-of-type(n + 2) {
  margin-left: 20px;
}

.sns-list .sns-liststyle:hover {
  opacity: 0.7;
}

.sns-list .sns-liststyle .sns-btn {
  display: block;
  width: 44px;
  height: 44px;
}

#sp-links .banner_wrapper p {
  float: left;
}

#sp-links .banner_wrapper p:not(:last-child) {
  margin-right: 10px;
}

#sp-links {
  overflow: hidden;
  padding: 0 13px;
}

@media screen and (min-width: 1000px) {
  #sp-links {
    display: none;
  }
}

#sp-links > ul {
  margin: 1em 0 2em;
}

#sp-links > ul > li {
  display: inline;
}

#sp-links > ul > li::before {
  content: ' | ';
}

#sp-links > ul > li:first-child::before {
  display: none;
}

#copyright {
  padding: 30px 0;
  overflow: hidden;
}

@media screen and (max-width: 999px) {
  #copyright {
    padding: 0 13px;
  }
}

#copyright .copyright-image {
  float: left;
}

@media screen and (max-width: 999px) {
  #copyright .copyright-image {
    display: none;
  }
}

#copyright .copyright-text {
  margin-left: 165px;
  font-size: 80%;
}

@media screen and (max-width: 999px) {
  #copyright .copyright-text {
    margin-left: 0;
  }
}

/***** content *****/
.content {
  padding: 20px 0;
}

@media screen and (max-width: 999px) {
  .content {
    width: auto;
    padding: 10px 13px;
  }
}

.content-2column {
  max-width: 727px;
  padding: 20px 0;
  float: right;
  width: 100%;
}

@media screen and (max-width: 999px) {
  .content-2column {
    width: auto;
    max-width: none;
    padding: 10px 13px;
    float: none;
  }
}

#side-nav {
  width: 224px;
  box-sizing: border-box;
  position: relative;
  top: -30px;
  z-index: 0;
}

@media screen and (max-width: 999px) {
  #side-nav {
    display: none;
  }
}

#side-nav h2 {
  font-size: 110%;
  color: #fff;
  padding: 20px 15px;
  background: #077f83;
  margin: 0;
}

#side-nav h3 {
  margin: 0;
  font-size: 100%;
  padding: 15px 25px 15px 15px;
  background-color: #089499;
  color: #fff;
}

#side-nav ul {
  margin: 0;
  border-left: 3px solid #e0e0e0;
  border-right: 3px solid #e0e0e0;
}

#side-nav ul > li {
  font-size: 100%;
  border-bottom: 1px solid #e0e0e0;
  font-weight: bold;
  padding: 0 14px;
}

#side-nav ul > li.speaking_blue {
  background: #fbeac6;
}

#side-nav ul > li.speaking_red {
  background: #fddbdc;
}

#side-nav ul > li:last-child {
  border-bottom: none;
}

#side-nav ul > li a {
  position: relative;
  display: block;
  padding: 15px 15px 15px 0;
  color: #333;
  box-sizing: border-box;
  vertical-align: middle;
  text-decoration: none;
}

#side-nav ul > li a::after {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  right: 5px;
  width: 6px;
  height: 6px;
  margin: -4px 0 0 0;
  border-top: solid 2px #c0bdbc;
  border-right: solid 2px #c0bdbc;
  transform: rotate(45deg);
}

#side-nav ul > li a.active, #side-nav ul > li a:hover {
  color: #ef7000;
}

#side-nav ul > li a.active::after, #side-nav ul > li a:hover::after {
  border-top: solid 2px #ef7000;
  border-right: solid 2px #ef7000;
}

#side-nav ul:last-child {
  border-bottom: 3px solid #e0e0e0;
}

#side-nav ul.lower > li > a {
  padding-left: 15px;
}

/* search */
#searchform {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
}

#searchform #s {
  border: 0;
  background-color: #fff;
  border-radius: 0;
  padding: 8px 10px;
  max-width: 535px;
  width: 100%;
  font-family: inherit;
  cursor: auto;
  line-height: 1;
}

#searchform #searchsubmit {
  padding: 8px 15px;
  border: 0;
  background-color: #09295e;
  color: #fff;
  font-family: inherit;
  line-height: 1;
}

#navi-wrapper #searchbox {
  padding: 20px 20px 20px 30px;
  background-color: #f8f8f8;
  border-bottom: 1px solid #ddd;
  display: block;
}

#navi-wrapper #searchform #s {
  padding: 15px 10px;
  border: 1px solid #ddd;
  border-right-width: 0;
}

#navi-wrapper #searchform #searchsubmit {
  padding: 15px 15px;
}

#toc h1 {
  display: none;
}

#misc-wrapper {
  position: absolute;
  top: 0;
  width: 100%;
}

#misc-wrapper > div {
  margin: 0 auto;
  max-width: 1000px;
  position: relative;
}

#misc {
  position: absolute;
  top: 22px;
  right: 0;
}

#misc > ul {
  float: left;
}

#misc > ul > li {
  float: left;
  height: 40px;
  line-height: 40px;
  margin: 0 10px;
}

#misc > ul > li > a {
  color: #000;
  display: block;
  text-align: center;
}

.search {
  width: 30px;
  height: 30px;
}

.login-link {
  float: left;
  height: 40px;
  line-height: 40px;
  margin: 0 0 0 10px;
}

.login-link > a {
  display: block;
  text-align: center;
  width: 108px;
  border-radius: 5px;
  color: #fff !important;
  background: #f7b524;
}

.login-link > a::before {
  content: "";
  display: inline-block;
  width: 9.5px;
  height: 12px;
  background: url(../images/icon/login.png) no-repeat;
  background-size: contain;
  vertical-align: middle;
  margin: -2px 5px 0 0;
}

#navi-wrapper {
  max-width: 1470px;
  margin: 0 auto;
}

#navi-wrapper > div {
  margin: 0 35px;
  background-color: #077F83;
}

#navi {
  font-size: 110%;
  max-width: 1000px;
  margin: 0 auto;
  color: #fff;
}

#navi .navi-link, #navi .navi-toggle {
  display: block;
  color: inherit;
}

#navi > li {
  display: block;
  width: 16.6666666666%;
  float: left;
}

#navi > li > .navi-toggle {
  padding: 19px 0;
  text-align: center;
  position: relative;
  cursor: pointer;
}

#navi > li > .navi-toggle.oneline {
  padding: 30px 0;
}

#navi > li > .navi-toggle:hover::after, #navi > li > .navi-toggle.active::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 14px;
  left: 0;
  width: 100%;
  height: 1px;
  background: #fff;
}

#navi .navi-pate {
  display: none;
}

.hamburger {
  display: none;
}

@media screen and (max-width: 999px) {
  #header-menu-box {
    position: fixed;
    left: 100%;
    top: 0;
    width: 100%;
    height: 100%;
    padding: 0;
    z-index: 200;
    transition: left 0.1s;
    overflow: scroll;
    margin-top: 50px;
    border-top: #09295e solid 2px;
    background-color: rgba(0, 0, 0, 0.5);
  }
  #hamburger-check:checked ~ #header-menu-box {
    left: 0;
  }
  .hamburger {
    position: absolute;
    display: block;
    /*
    right: 5%;
    top: 20px;
    width: 44px;
    height: 44px;
    */
    right: 0;
    top: 0;
    width: 70px;
    height: 70px;
    line-height: 70px;
    text-align: center;
    vertical-align: middle;
    cursor: pointer;
    z-index: 1000;
    zoom: .5;
    transition-property: opacity,filter,background-color;
    -moz-transform: scale(0.5, 0.5) translate(50px, -50px);
  }
  .hamburger:hover {
    opacity: 1;
  }
  .hamburger-inner, .hamburger-inner:after, .hamburger-inner:before {
    width: 44px;
    height: 6px;
  }
  .hamburger-inner:before {
    top: -16px;
  }
  .hamburger-inner:after {
    bottom: -16px;
  }
  #hamburger-check:checked ~ .hamburger {
    background-color: #09295e;
  }
  #hamburger-check:checked ~ .hamburger .hamburger-inner {
    transition-delay: .12s;
    transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: rotate(45deg);
  }
  #hamburger-check:checked ~ .hamburger .hamburger-inner, #hamburger-check:checked ~ .hamburger .hamburger-inner::before, #hamburger-check:checked ~ .hamburger .hamburger-inner::after {
    background-color: #fff;
  }
  #hamburger-check:checked ~ .hamburger .hamburger-inner::before {
    top: 0;
    transition: top 75ms ease, opacity 75ms ease .12s;
    opacity: 0;
  }
  #hamburger-check:checked ~ .hamburger .hamburger-inner::after {
    bottom: 0;
    transition: bottom 75ms ease, transform 75ms cubic-bezier(0.215, 0.61, 0.355, 1) 0.12s;
    transform: rotate(-90deg);
  }
  #navi-wrapper > div {
    margin: 0;
    background-color: transparent;
  }
  #navi {
    max-width: none;
    color: inherit;
  }
  #navi > li {
    float: none;
    width: auto;
    font-weight: bold;
    border-bottom: #ddd solid 1px;
    background: #f8f8f8;
  }
  #navi > li > a {
    color: inherit;
    padding: 15px 40px 15px 15px;
    text-align: left;
  }
  #toc {
    background: #fff;
    padding: 0 0 20px 0;
    margin: 0 0 40px 0;
    overflow: hidden;
  }
  #toc .navi-pate {
    display: block;
  }
  #toc .navi-toggle, #toc .navi-link {
    display: block;
    cursor: pointer;
    position: relative;
  }
  #toc .navi-toggle::after, #toc .navi-link::after {
    display: none !important;
  }
  #toc .navi-toggle::before, #toc .navi-link::before {
    display: block;
    position: absolute;
    right: 15px;
    top: 50%;
    margin: -0.5em 0 0 0;
    background: none;
    line-height: 1;
    font-weight: bold;
    font-size: 1.3rem;
    color: #ccc;
    width: 1.3rem;
    height: auto;
    text-align: center;
  }
  #toc .navi-toggle::before {
    content: '+';
  }
  #toc .navi-toggle.oneline {
    padding: 15px 40px 15px 30px !important;
  }
  #toc .navi-link::before {
    content: '\203A';
    font-size: 1.7rem;
  }
  #toc .open > .navi-toggle::before {
    content: '-';
  }
  .navi-sub, .navi-sub2 {
    display: none;
    background-color: #fff;
    border-top: #ddd solid 1px;
    font-weight: normal;
  }
  .navi-sub > li, .navi-sub2 > li {
    display: block;
    border-bottom: #ddd solid 1px;
  }
  .navi-sub > li:last-child, .navi-sub2 > li:last-child {
    border-bottom: none;
  }
  #navi > li > .navi-link, #navi > li > .navi-toggle, .navi-sub > li > .navi-link, .navi-sub > li > .navi-toggle {
    text-align: left;
    padding: 15px 40px 15px 30px;
  }
  .navi-sub2 > li {
    font-size: 92%;
  }
  .navi-sub2 > li > .navi-link, .navi-sub2 > li > .navi-toggle {
    padding: 10px 40px 10px 50px;
  }
  .navi-sub2 > li > .sp-indent {
    padding-left: 70px !important;
  }
  .navi-sub li.speaking_blue {
    background: #d3def2;
  }
  .navi-sub li.speaking_red {
    background: #fddbdc;
  }
  .navi-sub .navi-sub2 > li.exceptional {
    margin-top: 0 !important;
  }
  .navi-sub .navi-sub2 > li.singular {
    padding-top: 0;
  }
  #misc-wrapper {
    position: static;
    width: auto;
  }
  #misc {
    position: static;
    margin-right: -1px;
  }
  #misc > ul {
    float: none;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  #misc > ul > li {
    float: none;
    width: calc((100% - 2px) / 2);
    height: auto;
    margin: 0;
    padding: 0;
    border: #ddd solid;
    border-width: 0 1px 1px 0;
    line-height: 1.4;
  }
  #misc > ul > li > a {
    text-align: left;
    padding: 10px;
  }
  #misc > ul > li > a::before {
    right: 8px !important;
  }
  .login-link {
    float: none;
    margin: 20px 20%;
    text-align: center;
    height: auto;
    line-height: 1.4;
  }
  .login-link > a {
    position: relative;
    width: auto;
    background: none;
    color: inherit !important;
    border: #ddd solid 1px;
    border-radius: 5px;
    padding: 10px;
    font-weight: bold;
  }

}

@media screen and (min-width: 1000px) {
  br.pc-none {
    display: none;
  }
  #navi > li > .navi-sub {
    position: absolute;
    display: none;
    background-color: #089499;
    padding: 1em 2em;
    min-width: 200px;
    box-sizing: border-box;
    z-index: 100000;
  }
  #navi > li:hover > .navi-sub {
    display: block;
  }
  .navi-sub .navi-link, .navi-sub .navi-toggle {
    display: inline-block !important;
  }
  .navi-sub .navi-link {
    position: relative;
    padding-right: 1em;
  }
  .navi-sub .navi-link:hover {
    text-decoration: underline;
  }
  .navi-sub .navi-link::after {
    position: absolute;
    right: 0;
    top: 50%;
    display: block;
    width: 6px;
    height: 6px;
    border: #fff solid;
    border-width: 0 1px 1px 0;
    margin-top: -5px;
    content: '';
    transform: rotate(-45deg);
  }
  .navi-sub > li {
    border-top: #fff 1px solid;
    padding: 1em 0;
  }
  .navi-sub > li:first-child {
    border: none;
    padding-top: 0;
  }
  .navi-sub2 {
    margin-top: 1em;
    font-size: 90%;
  }
  .navi-sub2 > li {
    display: inline-block;
    padding-left: 2em;
  }
  .navi-sub2 > li:first-child {
    padding-left: 0;
  }
}

[data-fancybox] {
  cursor: pointer;
}

.descriptor-popup {
  width: 720px;
  max-width: 90vw;
  background-color: #ddd;
  padding: 2em;
}

.descriptor-popup h1 {
  margin: 0 0 2em 0;
  text-align: center;
  font-size: 160%;
}

.descriptor-meta > dt {
  display: block;
  float: left;
  background-color: #008;
  color: white;
  width: 5em;
  text-align: center;
  padding: 0.2em;
}

.descriptor-meta > dd {
  margin: 1em 0 1em 7em;
  padding: 0.2em 0;
}

.descriptor-meta .stars > img, .descriptor-meta .medals > img {
  width: 13px;
}

/***** content *****/
.bg-lightblue {
  background: #eff6fc;
  overflow: hidden;
}

.news-pickup {
  border-top: solid 3px #077F83;
  border-bottom: solid 3px #077F83;
  padding: 12px;
  margin: 48px 0;
}

@media screen and (max-width: 999px) {
  .news-pickup {
    margin: 24px 0;
  }
}

.news-pickup > .news-pikup-box {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

@media screen and (max-width: 999px) {
  .news-pickup > .news-pikup-box {
    display: block;
  }
}

.news-pickup > .news-pikup-box > h3.ttl {
  color: #077F83;
  font-size: 150%;
  font-weight: bold;
  padding-right: 14px;
  margin: 0;
}

@media screen and (max-width: 999px) {
  .news-pickup > .news-pikup-box > h3.ttl {
    padding-bottom: 1em;
  }
}

.news-pickup > .news-pikup-box > .right-content {
  border-left: solid 1px #077F83;
  padding-left: 14px;
}

@media screen and (max-width: 999px) {
  .news-pickup > .news-pikup-box > .right-content {
    border: none;
    padding-left: 0;
  }
}

.news-pickup > .news-pikup-box > .right-content > span {
  background-color: #1c9ebe;
  min-width: 6em;
  text-align: center;
  border-radius: 3px;
  padding: 5px 11px 4px;
}

@media screen and (max-width: 999px) {
  .news-pickup > .news-pikup-box > .right-content > span {
    margin-top: 5px;
  }
}

.news-pickup > .news-pikup-box > .right-content > a {
  color: #333;
  padding-left: 20px;
}

@media screen and (max-width: 999px) {
  .news-pickup > .news-pikup-box > .right-content > a {
    padding-left: 10px;
  }
}

.news-pickup > .news-pikup-box > .right-content > p {
  line-height: 1.4;
  margin: 10px 0 0;
}

.news-pickup > .news-pikup-box > .right-content > p > a {
  color: #333;
  margin: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 0 0 0 16px;
}

.news-category {
  margin: 2em 0;
  border-bottom: 3px solid #e1e1e1;
}

@media screen and (max-width: 999px) {
  .news-category {
    margin-top: 1em;
  }
}

.news-category > li {
  float: left;
  width: 110px;
  box-sizing: border-box;
  position: relative;
  margin-bottom: -3px;
}

@media screen and (max-width: 999px) {
  .news-category > li {
    width: auto;
  }
}

.news-category > li > a {
  display: block;
  color: #333;
  padding: 12px 0;
  text-align: center;
}

@media screen and (max-width: 999px) {
  .news-category > li > a {
    padding: 12px 8px;
    font-size: 80%;
  }
}

.news-category > li > a:hover, .news-category > li > a.active {
  color: #077f83;
  border-bottom: #077f83 solid 3px;
}

.news-category .news-category-more {
  float: right;
}

@media screen and (max-width: 999px) {
  .news-category .news-category-more {
    display: none;
  }
}

.news-category .news-category-more > a {
  text-align: left;
  padding-left: 16px;
}

.news-category .news-category-more > a:hover, .news-category .news-category-more > a.active {
  color: #1d9ebe;
  border-bottom: none;
}

.news-category-more-sp {
  display: block;
  padding: 10px 0;
  text-align: center;
  border-radius: 5px;
  background: #077F83;
  color: #fff;
}

.news-category-more-sp .round-arrow::before {
  background: #fff;
}

.news-category-more-sp .round-arrow::after {
  border-top: 1px solid #077F83;
  border-right: 1px solid #077F83;
}

.news-list {
  border-bottom: solid 1px #ccc;
  margin: 2em 0 4em 0;
  padding: 0 0 1em 0;
}

@media screen and (max-width: 999px) {
  .news-list {
    border-bottom: none;
    margin-bottom: 0;
  }
}

.news-list > li {
  margin: 1em 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

@media screen and (max-width: 999px) {
  .news-list > li {
    overflow: visible;
    white-space: normal;
    text-overflow: clip;
  }
}

.news-list > li > div {
  display: inline-block;
}

@media screen and (max-width: 999px) {
  .news-list > li > div {
    display: block;
    margin-bottom: 0.5em;
  }
}

.news-list > li .cat-tip {
  display: inline-block;
  border-radius: 5px;
  min-width: 6em;
  text-align: center;
  color: #fff;
  paddiing: 5px 11px 4px;
  margin-right: 25px;
}

.news-list > li .cat-news {
  background: #077F83;
}

.news-list > li .cat-other {
  background: #6e6e6e;
}

.news-list > li .cat-case {
  background: #48b3df;
}

.news-list > li .cat-report {
  background: #1c9ebe;
}

.news-list > li time {
  margin-right: 25px;
}

@media screen and (max-width: 999px) {
  .news-list > li time {
    margin-right: 0;
  }
}

.news-list > li a {
  color: #333;
}

.title {
  text-align: center;
  font-size: 180%;
  font-weight: normal;
  margin: 0.5em 0;
}

.row {
  margin: 0 0 30px 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

@media screen and (max-width: 999px) {
  .row {
    display: block;
  }
}

.top-border-box {
  border-top: #cfd5da solid 2px;
  margin-left: 3%;
}

@media screen and (max-width: 999px) {
  .top-border-box {
    margin-left: 0;
  }
}

.top-border-box:first-child {
  margin-left: 0;
}

.top-border-box.noborder {
  border-top-width: 0;
}

.top-border-box.noborder .title {
  border-bottom: #cfd5da solid 2px;
  margin-bottom: 0;
  padding-bottom: 0.5em;
}

.column2 {
  width: calc((100% - 3%) / 2);
}

.column3 {
  width: calc((100% - 3% * 2) / 3);
}

.column4 {
  width: calc((100% - 3% * 3) / 4);
}

@media screen and (max-width: 999px) {
  .column2, .column3, .column4 {
    width: auto;
  }
}

.support-text-image {
  float: left;
  margin-right: 25px;
}

.support-text-text {
  margin: 40px 0 0 0;
}

#banners h2 {
  display: none;
}

#banners ul {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  margin: 60px auto;
}

@media screen and (max-width: 999px) {
  #banners ul {
    display: block;
  }
}

#banners ul li {
  margin: 0 15px;
}

@media screen and (max-width: 999px) {
  #banners ul li {
    text-align: center;
    margin: 1em 15px;
  }
}

.top-banner {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

@media screen and (max-width: 999px) {
  .top-banner {
    display: block;
    text-align: center;
    max-width: 100%;
  }
}

/*slick*/
#main-image-slider {
  max-width: 1440px;
  width: 100%;
  margin: auto;
  top: -40px;
  margin-bottom: -40px;
}

#main-image-slider_sp {
  width: 100%;
  margin: auto;
  top: 50px;
  margin-bottom: 50px;
}

#main-image-slider_sp .slick-arrow {
  top: 0;
  bottom: 0;
}

.slick-slider {
  position: relative;
}

.slick-prev {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 10px;
  margin: auto;
  z-index: 1;
}

.slick-prev::after {
  left: 15px;
  border-bottom: 4px solid #48b3df;
  border-left: 4px solid #48b3df;
  border-top: 0;
  border-right: 0;
}

.slick-next {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 10px;
  margin: auto;
  z-index: 1;
}

.slick-next::after {
  right: 15px;
  border-top: 4px solid #48b3df;
  border-right: 4px solid #48b3df;
  border-bottom: 0;
  border-left: 0;
}

.slick-arrow {
  outline: 0;
  text-indent: -9999px;
  width: 50px;
  height: 50px;
  padding: 0;
  background-color: transparent;
  transition: all 0.3s ease;
}

.slick-arrow:hover {
  cursor: pointer;
  opacity: 0.7;
}

.slick-arrow::after {
  content: "";
  position: absolute;
  display: block;
  top: 0;
  bottom: 0;
  margin: auto;
  width: 25px;
  height: 25px;
  transform: rotate(45deg);
  transition: all 0.2s ease;
}

/***************************************
 * Contact
 ***************************************/
input, select, label {
  cursor: pointer;
}

input[type="text"],
input[type="email"],
textarea,
select {
  background-color: #f1f1f1;
  padding: 9px 0;
  border: solid 1px #bcbcbc;
  border-radius: 4px;
  color: #343434;
  font-size: 100%;
}

@media screen and (max-width: 999px) {
  input[type="text"],
  input[type="email"],
  textarea,
  select {
    width: 100%;
  }
}

input[size="1"] {
  width: 0.5em;
}

input[size="2"] {
  width: 1.0em;
}

input[size="3"] {
  width: 1.5em;
}

input[size="4"] {
  width: 2.0em;
}

input[size="5"] {
  width: 2.5em;
}

input[size="6"] {
  width: 3.0em;
}

input[size="7"] {
  width: 3.5em;
}

input[size="8"] {
  width: 4.0em;
}

input[size="9"] {
  width: 4.5em;
}

input[size="10"] {
  width: 5.0em;
}

input[size="11"] {
  width: 5.5em;
}

input[size="12"] {
  width: 6.0em;
}

input[size="13"] {
  width: 6.5em;
}

input[size="14"] {
  width: 7.0em;
}

input[size="15"] {
  width: 7.5em;
}

input[size="16"] {
  width: 8.0em;
}

input[size="17"] {
  width: 8.5em;
}

input[size="18"] {
  width: 9.0em;
}

input[size="19"] {
  width: 9.5em;
}

input[size="20"] {
  width: 10.0em;
}

input[size="21"] {
  width: 10.5em;
}

input[size="22"] {
  width: 11.0em;
}

input[size="23"] {
  width: 11.5em;
}

input[size="24"] {
  width: 12.0em;
}

input[size="25"] {
  width: 12.5em;
}

input[size="26"] {
  width: 13.0em;
}

input[size="27"] {
  width: 13.5em;
}

input[size="28"] {
  width: 14.0em;
}

input[size="29"] {
  width: 14.5em;
}

input[size="30"] {
  width: 15.0em;
}

input[size="31"] {
  width: 15.5em;
}

input[size="32"] {
  width: 16.0em;
}

input[size="33"] {
  width: 16.5em;
}

input[size="34"] {
  width: 17.0em;
}

input[size="35"] {
  width: 17.5em;
}

input[size="36"] {
  width: 18.0em;
}

input[size="37"] {
  width: 18.5em;
}

input[size="38"] {
  width: 19.0em;
}

input[size="39"] {
  width: 19.5em;
}

input[size="40"] {
  width: 20.0em;
}

input[size="41"] {
  width: 20.5em;
}

input[size="42"] {
  width: 21.0em;
}

input[size="43"] {
  width: 21.5em;
}

input[size="44"] {
  width: 22.0em;
}

input[size="45"] {
  width: 22.5em;
}

input[size="46"] {
  width: 23.0em;
}

input[size="47"] {
  width: 23.5em;
}

input[size="48"] {
  width: 24.0em;
}

input[size="49"] {
  width: 24.5em;
}

input[size="50"] {
  width: 25.0em;
}

@media screen and (max-width: 999px) {
  input[size="31"] {
    width: 100%;
  }
}

#content-wrapper {
  padding: 35px;
}

@media screen and (max-width: 999px) {
  #content-wrapper {
    padding: 2em 0;
  }
}

#contact-form {
  width: 100%;
  border-collapse: collapse;
  font-size: 15px;
}

#contact-form > tbody > tr {
  border-top: solid 1px #e0e0e0;
  border-bottom: solid 1px #e0e0e0;
}

@media screen and (max-width: 999px) {
  #contact-form > tbody > tr {
    display: block;
  }
}

#contact-form > tbody > tr > th {
  text-align: left;
  padding: 24px 21px;
  width: 313px;
}

@media screen and (max-width: 999px) {
  #contact-form > tbody > tr > th {
    padding: 1em 0;
    display: block;
    width: auto;
  }
}

#contact-form > tbody > tr > th.optional {
  padding-left: 101px;
  width: 220px;
}

@media screen and (max-width: 999px) {
  #contact-form > tbody > tr > th.optional {
    padding-left: 0;
    width: auto;
  }
}

#contact-form > tbody > tr > th.multiline {
  vertical-align: top;
}

#contact-form > tbody > tr > th > div {
  display: inline-block;
  width: 80px;
}

#contact-form > tbody > tr > th > div > span {
  display: inline-block;
  padding: 4px 11px;
  font-size: 13px;
  color: #fff;
  background: #ffcc00;
  border-radius: 2px;
  font-weight: normal;
}

#contact-form > tbody > tr > td {
  padding: 25px 0;
}

@media screen and (max-width: 999px) {
  #contact-form > tbody > tr > td {
    display: block;
    width: auto;
    padding: 1em 0;
  }
}

#contact-form > tbody > tr > td > ul > li:not(:first-child) {
  margin-top: 12px;
}

#contact-form > tbody > tr > td .field-name {
  display: inline-block;
  width: 2em;
  padding-right: .5em;
  text-align: center;
}

.checkboxes {
  margin: 45px 180px;
  font-weight: bold;
}

@media screen and (max-width: 999px) {
  .checkboxes {
    margin: 45px 0;
  }
  .checkboxes > li {
    margin: 1em 0;
  }
}

.checkboxes > li:not(:first-child) {
  margin-top: 20px;
}

.buttons {
  text-align: center;
}

button {
  font-size: 24px;
  padding: 18px 112px;
  background: #911017;
  border: none;
  color: #fff;
}

@media screen and (max-width: 999px) {
  button {
    padding: 18px 0;
    width: 100%;
  }
}

.split-spaces > *:not(:first-child) {
  margin-left: 50px;
}

@media screen and (min-width: 1000px) {
  .pc-inline {
    display: inline-block;
  }
}

@media screen and (max-width: 999px) {
  .pc-inline {
    display: block;
    margin: 1em 0;
  }
}

/***************************************
 * Policy
 ***************************************/
.policy h1 {
  font-size: 200%;
}

.policy h2 {
  font-size: 120%;
  margin: 3em 0 0 0;
}

.policy h3 {
  font-size: 100%;
  margin: 3em 0 0 0;
}

.policy h4 {
  font-size: 100%;
  margin: 2em 0 1em 0;
  font-weight: normal;
}

.policy .change-log {
  margin-top: 3em;
  text-align: right;
}

/***************************************
 * Company
 ***************************************/
.company-info-table {
  border-collapse: collapse;
  width: 100%;
  border: solid 1px #e0e0e0;
  margin: 2em 0;
}

@media screen and (max-width: 999px) {
  .company-info-table {
    border: none;
  }
}

.company-info-table th, .company-info-table td {
  border: solid 1px #e0e0e0;
  padding: 1em;
}

@media screen and (max-width: 999px) {
  .company-info-table th, .company-info-table td {
    border: none;
    display: block;
  }
}

.company-info-table th {
  text-align: center;
  background: #f5f5f5;
  font-weight: normal;
  width: 25%;
}

@media screen and (max-width: 999px) {
  .company-info-table th {
    text-align: left;
    width: auto;
    background: transparent;
    color: #787878;
    padding: 0.5em 0;
  }
}

.company-info-table td {
  vertical-align: top;
}

@media screen and (max-width: 999px) {
  .company-info-table td {
    border-bottom: solid 1px #e0e0e0;
    padding: 0 0 0.5em 0;
  }
}

/***************************************
 * Login
 ***************************************/
.login-box {
  width: 45%;
  border: solid 4px #e0e0e0;
  padding: 0 0 30px 0;
}

@media screen and (max-width: 999px) {
  .login-box {
    width: auto;
    margin: 2em 0;
  }
}

.login-box h2 {
  background: #ececec;
  padding: 30px 0;
  margin: 0 0 50px 0;
}

.login-box h2 > span {
  display: inline-block;
  padding: 10px;
}

.login-box a {
  display: block;
  padding: 15px 0;
  width: 80%;
  margin: 25px auto;
  text-align: center;
  color: #fff;
  font-size: 120%;
  border-radius: 3px;
}

@media screen and (max-width: 999px) {
  .login-box a {
    width: auto;
    margin: 25px 10px;
  }
}

.login-box a:hover {
  opacity: 0.7;
}

.login-heve-id {
  background: url(../images/icon/have_id.png) 40px 50% no-repeat;
  background-size: 30px 30px;
}

@media screen and (max-width: 999px) {
  .login-heve-id {
    background-position: 10px 50%;
  }
}

.login-first-time {
  background: url(../images/icon/first_time.png) 40px 50% no-repeat;
  background-size: 30px 30px;
}

@media screen and (max-width: 999px) {
  .login-first-time {
    background-position: 10px 50%;
  }
}

.individual {
  float: left;
}

@media screen and (max-width: 999px) {
  .individual {
    float: none;
  }
}

.individual h2 > span {
  border-left: solid 6px #077f83;
}

.individual a {
  background-color: #ef7000;
}

.group {
  float: right;
}

@media screen and (max-width: 999px) {
  .group {
    float: none;
  }
}

.group h2 > span {
  border-left: solid 6px #077f83;
}

.group a {
  background-color: #077f83;
}

/***************************************
 * FAQ
 ***************************************/
.faq-section {
  margin: 4em 0;
}

.faq-block {
  border: #e0e0e0 solid 3px;
  padding: 0 35px;
}

@media screen and (max-width: 999px) {
  .faq-block {
    padding: 0 10px;
  }
}

.faq {
  margin: 0 0 30px 0;
  border-bottom: #eee solid 1px;
}

.faq > dt {
  position: relative;
  color: #008;
  border-top: #eee solid 1px;
  margin: 0 0 30px 0;
  padding: 30px 80px 0 44px;
  font-size: 120%;
}

@media screen and (max-width: 999px) {
  .faq > dt {
    padding: 30px 20px 0 44px;
  }
}

.faq > dt::first-child {
  border: none;
}

.faq > dt::after {
  content: '';
  position: absolute;
  top: 38px;
  right: 70px;
  width: 4px;
  height: 4px;
  border: #000 solid 2px;
  border-color: transparent #000 #000 transparent;
  transform: rotate(45deg);
  transform-origin: 75% 75% 0;
  transition: transform 300ms;
}

@media screen and (max-width: 999px) {
  .faq > dt::after {
    right: 10px;
  }
}

.faq > dt.open::after {
  transform: rotate(-135deg);
}

.faq > dt > a {
  color: inherit;
  text-decoration: none;
}

.faq > dd {
  line-height: 2;
  position: relative;
  margin: 30px 0;
  padding: 0 44px 0 44px;
  display: none;
}

.faq > dd a {
  text-decoration: underline;
}

.faq-q, .faq-a {
  position: absolute;
  left: 8px;
  top: -6px;
  font-size: 150%;
  font-weight: normal;
}

.faq-q {
  font-size: 125%;
  top: 26px;
}

/***************************************
 * Toefl
 ***************************************/
.comment {
  background: #f9f9f9;
  padding: 2px 15px;
  margin: 2em 0;
}

/***************************************
 * Toefl Primary
 ***************************************/
.chara {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.chara-box {
  border: 2px solid #e0e0e0;
  box-sizing: border-box;
  width: 48%;
  margin: 0 0 4% 0;
  padding: 12px;
}

.chara-box > header {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  text-align: center;
}

.chara-box > header > h3 {
  -ms-flex-positive: 1;
      flex-grow: 1;
}

@media screen and (max-width: 999px) {
  .chara-box {
    width: 100%;
  }
}

.levels {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.levels-box {
  border: 2px solid #e0e0e0;
  box-sizing: border-box;
  width: 48%;
  margin: 0 0 4% 0;
  padding: 12px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
}

.levels-box > header {
  -ms-flex-positive: 1;
      flex-grow: 1;
}

.levels-box > header > h3 {
  text-align: center;
  margin: 0.5em auto 0;
}

.levels-box > header > h3 > span {
  background: #077F83;
  color: #fff;
  padding: 0.2em 2em;
}

.levels-box > header > p {
  font-weight: bold;
}

.levels-box > ul > li {
  border-top: 1px solid #d6d6d6;
  padding: 0.5em 0;
}

@media screen and (max-width: 999px) {
  .levels-box {
    width: 100%;
  }
}

/***************************************
 * Toefl Primary Test
 ***************************************/
.test-config-table {
  width: 100%;
  border-collapse: collapse;
  border: solid 3px #e0e0e0;
  margin-bottom: 35px;
}

.test-config-table td {
  border: solid 1px #e0e0e0;
  padding: 15px;
  text-align: center;
  font-weight: bold;
}

.test-config-table td > span {
  display: inline-block;
  color: #fff;
  background: #077F83;
  padding: 0 0.5em;
  margin-right: 0.5em;
}

.test-config-table tr.section-cell td {
  background: #f7f8fc;
}

.test-config-table tr.total td {
  background: #fdf6f7;
}

.title-step {
  color: #fff;
  padding: 0.35em 1em;
  background-color: #077F83;
}

.step-contents-box {
  border: solid 3px #e0e0e0;
  padding: 30px 15px;
  margin: 30px 0;
}

.step-contents-box > header {
  text-align: center;
}

.step-contents-box > header > h2 {
  font-size: 120%;
  display: inline-block;
  margin: 0 auto 2em;
  text-align: center;
  color: #09295e;
  background: #f9f9f9;
  height: 42px;
  padding: 0 40px 0 60px;
  line-height: 42px;
  border-radius: 21px;
}

.step-contents-box > header .icon-listening {
  background: #f9f9f9 url(../images/icon/listening.png) 15px 50% no-repeat;
  background-size: 40px 40px;
}

.step-contents-box > header .icon-reading {
  background: #f9f9f9 url(../images/icon/reading.png) 15px 50% no-repeat;
  background-size: 40px 40px;
}

.step-contents-box .step-contents {
  display: -ms-flexbox;
  display: flex;
}

.step-contents-box .step-contents > div > h3 {
  text-align: center;
  margin: 0 auto 2em;
}

.step-contents-box .step-contents > div > h3 > span {
  display: inline-block;
  box-sizing: border-box;
  background: #077F83;
  color: #fff;
  padding: 0.2em 1em;
  min-width: 150px;
}

@media screen and (max-width: 999px) {
  .step-contents-box .step-contents {
    display: block;
  }
  .step-contents-box .step-contents > div {
    width: auto;
    border: none;
    border-bottom: #e0e0e0 solid 1px;
    padding: 0;
    margin: 0 0 2em 0;
  }
  .step-contents-box .step-contents > div:last-child {
    border-bottom: none;
    margin: 0;
  }
}

.step-contents-box .measure {
  width: 63%;
  box-sizing: border-box;
  padding: 0 15px 0 0;
  border-right: solid 1px #e0e0e0;
}

.step-contents-box .content-subject {
  width: 37%;
  box-sizing: border-box;
  padding: 0 0 0 15px;
}

/***************************************
 * Toefl Primary Sample
 ***************************************/
.download {
  display: block;
  max-width: 280px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 15px 1em;
  border-radius: 3px;
  background: #ef7000 url(../images/icon/download.png) 35px 50% no-repeat;
  background-size: 30px 30px;
  color: #fff;
  text-align: center;
  font-size: 120%;
  font-weight: bold;
}

.sample-box {
  margin: 4em 0 6em 0;
  display: -ms-flexbox;
  display: flex;
}

.sample-box .sample-image {
  text-align: center;
  width: 30%;
}

.sample-box .sample-content {
  width: 70%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
}

.sample-box .sample-content > .sample-content-text {
  -ms-flex-positive: 1;
      flex-grow: 1;
}

.sample-box .sample-content > .sample-content-text > h2 {
  margin: 0 0 1em 0;
  font-size: 100%;
  border-bottom: solid 3px #e0e0e0;
  padding: 0 0 12px 0;
}

.sample-box .sample-content > .button {
  text-align: center;
}

@media screen and (max-width: 999px) {
  .sample-box {
    display: block;
    margin: 0 0 4em 0;
  }
  .sample-box .sample-image, .sample-box .sample-content {
    width: auto;
  }
  .sample-box .sample-image {
    margin: 2em 0;
  }
}

/***************************************
 * Toefl Primary Recult
 ***************************************/
.primary-results {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

@media screen and (max-width: 999px) {
  .primary-results {
    display: block;
  }
}

.primary-result-box {
  border: 2px solid #e0e0e0;
  box-sizing: border-box;
  width: 48%;
  margin: 0 0 4% 0;
  padding: 12px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
}

.primary-result-box > header > h3 {
  text-align: center;
  margin: 0.5em auto 0;
}

.primary-result-box > header > h3 > span {
  background: #077F83;
  color: #fff;
  padding: 0.2em 2em;
}

.primary-result-box > header > p {
  font-weight: bold;
}

.primary-result-box > ul {
  -ms-flex-positive: 1;
      flex-grow: 1;
}

.primary-result-box > ul > li {
  margin: 20px 0;
}

.primary-result-box > .primary-result-image {
  text-align: center;
}

.primary-result-box > .primary-result-image > img {
  width: 276px;
}

.primary-result-box > .primary-result-image .button {
  margin: 1em 0;
}

.primary-result-box > .primary-result-image .button .enlarge {
  display: block;
  max-width: 125px;
  margin: 0 auto;
  padding: 0 30px;
  box-sizing: border-box;
  border-radius: 3px;
  background: #a1a2a2 url(../images/icon/enlarge.png) 5px 50% no-repeat;
  background-size: 30px 30px;
  color: #fff;
  text-align: center;
}

@media screen and (max-width: 999px) {
  .primary-result-box {
    width: auto;
  }
}

.reissue-score-report {
  padding: 30px 20px;
  background: #f9f9f9;
}

.reissue-score-report > h3 {
  margin: 0;
  line-height: 2em;
}

.reissue-score-report > p {
  margin: 0;
}

.reissue-score-report > p > a {
  display: inline-block;
  position: relative;
  padding-left: 1em;
  text-decoration: underline;
}

.reissue-score-report > p > a:before {
  content: "";
  display: inline-block;
  border: 4px solid transparent;
  border-left-color: #09295e;
  position: absolute;
  top: 50%;
  left: 0;
  margin-top: -4px;
}

.score-level-table {
  width: 100%;
  border-collapse: collapse;
  border: solid 3px #e0e0e0;
  margin-bottom: 35px;
}

.score-level-table > thead > tr > th,
.score-level-table > thead > tr > td {
  background: #f7f8fc;
}

.score-level-table > thead > tr > th,
.score-level-table > thead > tr > td,
.score-level-table > tbody > tr > th,
.score-level-table > tbody > tr > td {
  border: solid 1px #e0e0e0;
  padding: 10px 0;
}

.score-level-table > thead > tr {
  font-size: 14px;
  white-space: nowrap;
}

.score-level-table > thead > tr:nth-child(3) {
  font-size: 11px;
}

.score-level-table > thead > tr > th {
  width: 80px;
}

.score-level-table > thead > tr > th:first-child {
  width: 65px;
}

.score-level-table > thead > tr:first-child > th:not(:first-child) > span {
  background: #09295e;
  color: #fff;
  padding: 0.2em 2em;
}

.score-level-table > tbody > tr > td {
  font-size: 15px;
  font-weight: bold;
  vertical-align: middle;
  text-align: center;
}

.score-level-table > tbody > tr > td.disabled-cell {
  background: #eaeaea;
  color: #7e7e7e;
}

.score-level-table > tbody > tr > td > img {
  width: 13px;
}

.score-level-table .separate-cell {
  border-right: solid 3px #e0e0e0;
}

.descriptor-downloads {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.descriptor-downloads a {
  display: block;
  padding: 15px 15px 15px 50px;
  background: #ef7000 url(../images/icon/download.png) 10px 50% no-repeat;
  background-size: 30px 30px;
  color: #fff;
  font-weight: bold;
  font-size: 18px;
  border-radius: 2px;
  line-height: 30px;
}

@media screen and (max-width: 999px) {
  .descriptor-downloads {
    display: block;
  }
  .descriptor-downloads a {
    margin: 1em 0;
  }
}

/***************************************
 * Toefl Primary Voice
 ***************************************/
.voice-list {
  margin: 0 0 4em 0;
  padding: 0;
}

.voice-list > li {
  display: -ms-flexbox;
  display: flex;
  border-bottom: solid 2px #e0e0e0;
  padding: 30px 15px 30px 0;
  -ms-flex-align: center;
      align-items: center;
}

.voice-list > li:first-child {
  padding-top: 0;
}

.voice-list > li .voice-user {
  min-width: 25%;
  text-align: center;
}

@media screen and (max-width: 999px) {
  .voice-list > li .voice-user {
    min-width: 35%;
    font-size: 90%;
  }
}

.voice-list > li p {
  margin: 0;
}

/***************************************
 * Junior Primary Test
 ***************************************/
.test-config.test-junior {
  width: 60%;
}

.test-config.test-junior td {
  width: 33%;
}

@media screen and (max-width: 999px) {
  .test-config.test-junior {
    width: 100%;
  }
}

.step-contents-box > header .icon-grammar {
  background: #f9f9f9 url(../images/icon/grammar.png) 15px 50% no-repeat;
  background-size: 40px 40px;
}

/***************************************
 * Junior Primary Sample
 ***************************************/
.external-link {
  display: block;
  max-width: 280px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 15px 1em 15px 3em;
  border-radius: 3px;
  background: #ef7000 url(../images/icon/external_link.png) 20px 50% no-repeat;
  background-size: 30px 30px;
  color: #fff;
  text-align: center;
  font-size: 120%;
  font-weight: bold;
}

/***************************************
 * Junior Primary Recult
 ***************************************/
#total-score-level-table {
  margin: 4em 0 2em;
  width: 100%;
  border-collapse: collapse;
  border: solid 3px #e0e0e0;
}

#total-score-level-table thead th {
  background: #a3a3a3;
  color: #fff;
  white-space: nowrap;
  padding: 5px 10px;
  border: solid 1px #e0e0e0;
}

@media screen and (max-width: 999px) {
  #total-score-level-table thead th {
    white-space: normal;
  }
}

#total-score-level-table tbody tr:nth-child(even) {
  background: #f8f8f8;
}

#total-score-level-table tbody td {
  padding: 10px 5px;
  border: solid 1px #e0e0e0;
}

#total-score-level-table tbody td:nth-child(1), #total-score-level-table tbody td:nth-child(2), #total-score-level-table tbody td:nth-child(5) {
  white-space: nowrap;
  text-align: center;
}

@media screen and (max-width: 999px) {
  #total-score-level-table tbody td:nth-child(1), #total-score-level-table tbody td:nth-child(2), #total-score-level-table tbody td:nth-child(5) {
    white-space: normal;
  }
}

/***************************************
 * Person Test
 ***************************************/
.person-test-info {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

@media screen and (max-width: 999px) {
  .person-test-info {
    display: block;
  }
}

.person-test-info-inbox {
  border: 3px solid #e0e0e0;
  box-sizing: border-box;
  width: 356px;
  margin: 0 0 4% 0;
  padding: 12px;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
}

@media screen and (max-width: 999px) {
  .person-test-info-inbox {
    width: auto;
    display: block;
  }
}

.person-test-info-inbox:first-child {
  margin-right: 15px;
}

@media screen and (max-width: 999px) {
  .person-test-info-inbox:first-child {
    margin-right: 0;
  }
}

.person-test-info-inbox > header > h3 {
  text-align: center;
  margin: 0.5em auto 0;
}

.person-test-info-inbox > header > h3 > span {
  background: #077F83;
  color: #fff;
  padding: 0.2em 2em;
}

.person-test-info-inbox > .border-separate {
  margin: 0;
}

.person-test-info-inbox > .border-separate > li {
  padding: 20px 0;
}

.person-test-info-inbox > .border-separate > li > table {
  width: 100%;
  font-size: 15px;
}

.person-test-info-inbox > .border-separate > li > table > tbody > tr > th {
  text-align: center;
  padding: 0 20px 0 10px;
}

.person-test-info-inbox > .border-separate > li:not(:first-child) {
  border-top: 1px solid #d6d6d6;
}

.person-test-info-inbox > .border-separate > li:last-child {
  padding-bottom: 0;
}

.person-test-info-inbox > .bullet {
  margin: 20px 0;
}

.person-test-info-inbox > .bullet > li {
  margin: 5px 0;
}

.person-test-flow > section {
  padding: 20px;
}

.person-test-flow > section:nth-child(even) {
  background: #fcf5e7;
}

.person-test-flow > section > h3 {
  font-size: 18px;
  margin: 0 0 10px;
  color: #fff;
  padding: 0.35em 1em;
  background-color: #077f83;
}

@media screen and (max-width: 999px) {
  .person-test-flow {
    margin: 0 -13px;
  }
  .person-test-flow > section {
    padding: 20px 13px;
  }
}

.person-test-flow-body {
  padding: 0 20px;
}

.person-test-flow-body a {
  text-decoration: underline;
}

.person-test-flow-body :first-child {
  margin-top: 0;
}

.person-test-flow-body :last-child {
  margin-bottom: 0;
}

.person-test-entry-buttons {
  line-height: 1.2;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: center;
      justify-content: center;
}

.person-test-entry-buttons > a {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-align: center;
      align-items: center;
  -ms-flex-pack: center;
      justify-content: center;
  width: 235px;
  box-sizing: border-box;
  padding: 10px 10px 10px 30px;
  border-radius: 3px;
  background: #ef7000 url(../images/icon/arrow_right.png) 15px 50% no-repeat;
  background-size: 10px 15px;
  color: #fff;
  font-size: 18px;
  font-weight: bold;
  text-decoration: none;
}

.person-test-entry-buttons > a > span {
  font-size: 15px;
}

.person-test-entry-buttons > a:first-child {
  margin-right: 30px;
}

.person-test-entry-buttons > a:hover {
  color: #ff0966;
}

@media screen and (max-width: 999px) {
  .person-test-entry-buttons {
    display: block;
    margin: 0 -20px;
    padding: 0;
  }
  .person-test-entry-buttons > a {
    width: auto;
    margin: 1em 0 0 0 !important;
  }
}

.cheap-link {
  display: inline-block;
  padding-left: 1em;
  position: relative;
  background: url("../images/icon/arrow_right_cheap.png") 0 50% no-repeat;
  background-size: 6px 10px;
  text-decoration: underline;
}

@media screen and (max-width: 999px) {
  .cheap-link {
    display: block;
  }
}

.cheap-link:not(:last-child) {
  margin-right: 20px;
}

#need-consider {
  margin: 30px 0;
}

#need-consider > h2 {
  font-size: 18px;
}

/***************************************
 * Toefl Primary List
 ***************************************/
.primary-list-header {
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 999px) {
  .primary-list-header {
    display: block;
  }
}

.primary-list-header .primary-list-header-text {
  -ms-flex: 1;
      flex: 1;
  margin-right: 25px;
}

@media screen and (max-width: 999px) {
  .primary-list-header .primary-list-header-text {
    margin-right: 0;
  }
}

.primary-list-header .primary-list-header-image {
  width: 284px;
}

@media screen and (max-width: 999px) {
  .primary-list-header .primary-list-header-image {
    width: auto;
  }
  .primary-list-header .primary-list-header-image > img {
    width: 100%;
    height: auto;
  }
}

.test-detail-table {
  margin: 2em 0;
  width: 100%;
  border-collapse: collapse;
  border: solid 3px #e0e0e0;
}

.test-detail-table thead th {
  background: #09295e;
  color: #fff;
  padding: 15px 7px 15px 20px;
  text-align: left;
}

@media screen and (max-width: 999px) {
  .test-detail-table thead th {
    padding: 15px;
  }
}

.test-detail-table thead th > div:first-child {
  float: left;
  line-height: 40px;
}

@media screen and (max-width: 999px) {
  .test-detail-table thead th > div:first-child {
    display: block;
    line-height: 1.4;
    margin: 0 0 1em 0;
  }
}

.test-detail-table thead th > div:last-child {
  text-align: right;
}

.test-detail-table tbody th, .test-detail-table tbody td {
  padding: 15px 10px;
  vertical-align: top;
  border: solid 1px #e0e0e0;
}

.test-detail-table tbody th {
  background: #f7f8fc;
  text-align: center;
  white-space: nowrap;
  width: 140px;
}

@media screen and (max-width: 999px) {
  .test-detail-table tbody th {
    width: auto;
  }
}

.test-detail-table tbody td {
  padding: 15px 15px 15px 35px;
}

@media screen and (max-width: 999px) {
  .test-detail-table tbody td {
    padding: 15px;
  }
}

.test-detail-table tbody td .period span {
  margin-left: 2em;
}

@media screen and (max-width: 999px) {
  .test-detail-table tbody td .period span {
    margin-left: 0;
    display: block;
  }
}

.test-detail-table tbody td .period span:first-child {
  margin-left: 0;
}

.test-detail-table em {
  color: #b66064;
  font-style: normal;
}

.test-detail-link {
  display: inline-block;
  text-align: center;
  background: #fff;
  color: #09295e;
  padding: 10px 10px 10px 20px;
  position: relative;
  width: 135px;
  box-sizing: border-box;
  border-radius: 3px;
}

@media screen and (max-width: 999px) {
  .test-detail-link {
    width: 100%;
  }
}

.test-detail-link::before {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 15px;
  width: 6px;
  height: 6px;
  margin: -4px 0 0 0;
  border-top: solid 2px #09295e;
  border-right: solid 2px #09295e;
  transform: rotate(45deg);
}

.test-detail-link.disabled {
  opacity: 0.5;
}

.test-application {
  display: inline-block;
  text-align: center;
  background: #ef7000;
  color: #fff;
  padding: 10px 20px 10px 35px;
  position: relative;
  box-sizing: border-box;
  border-radius: 3px;
  font-weight: bold;
}

.test-application::before {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 15px;
  width: 6px;
  height: 6px;
  margin: -4px 0 0 0;
  border-top: solid 2px #fff;
  border-right: solid 2px #fff;
  transform: rotate(45deg);
}

.primary-list-info {
  margin: 4em 0;
}

.primary-list-info h5 {
  text-align: center;
  font-weight: bold;
  font-size: 100%;
}

.primary-list-info p {
  text-align: center;
}

/***************************************
 * Toefl Primary Detail
 ***************************************/
@media screen and (max-width: 999px) {
  .detail-entry-buttons .person-test-entry-buttons {
    margin: 2em 0;
  }
}

@media screen and (max-width: 999px) {
  .recommend-face > img {
    width: 88px;
    height: 88px;
  }
}

.recommend-name {
  margin-bottom: 0.3em;
  font-size: 1.2em;
  font-weight: bold;
}

.recommend-title {
  color: #888;
}

.recommend-list {
  border-top: 2px solid #e0e0e0;
  margin: 1em 0;
  line-height: 1.6;
}

.recommend-list-item {
  position: relative;
  padding: 2em 0 2em 192px;
  border-bottom: 2px solid #e0e0e0;
  min-height: 175px;
}

.recommend-list-item > h1 {
  margin: 0 0 1em 0;
  min-height: 2.8em;
  font-size: 1.5em;
}

@media screen and (max-width: 999px) {
  .recommend-list-item {
    min-height: 88px;
    padding-left: 96px;
  }
  .recommend-list-item > h1 {
    min-height: 0;
  }
}

.recommend-list-item .recommend-face {
  position: absolute;
  left: 0;
  top: 2em;
}

.recommend-list-content {
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 999px) {
  .recommend-list-content {
    display: block;
  }
}

.recommend-list-meta {
  -ms-flex-positive: 1;
      flex-grow: 1;
}

.recommend-list-more {
  padding-top: 2em;
}

.recommend-content {
  border-top: 3px solid #e0e0e0;
}

.recommend-content > h1 {
  margin-top: 1.5em;
}

.recommend-content-meta {
  text-align: right;
  margin-bottom: 4em;
}

@media screen and (max-width: 999px) {
  .recommend-content-meta {
    text-align: left;
    margin-bottom: 2em;
  }
}

.recommend-content-meta > * {
  display: inline-block;
  margin-bottom: 0;
}

.recommend-content-meta .recommend-name {
  margin-left: 2em;
}

@media screen and (max-width: 999px) {
  .recommend-content-meta .recommend-name {
    display: block;
    margin-left: 0;
  }
}

.recommend-content-body .recommend-face {
  float: right;
  margin: -1.8em 0 2em 2em;
}

.administered {
  margin: 2em 0;
  border-top: #e0e0e0 solid 1px;
  padding: 2em 0 0 0;
}

.administered > dt {
  float: left;
  width: 6em;
  background: #077F83;
  padding: 0.2em 1em;
  color: #fff;
  font-weight: bold;
  text-align: center;
}

.administered > dd {
  margin: 0 0 2em 0;
  padding: 0.2em 0 2em 9.5em;
  border-bottom: #e0e0e0 solid 1px;
}

.administered > dd > :first-child {
  margin-top: 0;
}

.administered h3 {
  margin: 2em 0 1em 0;
  color: #09295e;
}

.administered li {
  margin: 0.5em 0 0 0;
}

.administered li:first-child {
  margin-top: 0;
}

@media screen and (max-width: 999px) {
  .administered {
    padding-top: 1em;
  }
  .administered > dt {
    display: inline-block;
    float: none;
  }
  .administered > dd {
    margin: 1em 0;
    padding: 0 1em 1em 1em;
  }
  .administered h3 {
    margin: 1em 0;
  }
}

.administered-flow-icon {
  position: relative;
}

.administered-flow-icon::after {
  position: absolute;
  background: url(../images/icon/calendar.png) center center/50px 50px no-repeat;
  width: 50px;
  height: 50px;
  z-index: 1;
  top: -25px;
  left: 40px;
  content: '';
}

@media screen and (max-width: 999px) {
  .administered-flow-icon::after {
    left: 20px;
  }
}

.administered-flow {
  border-collapse: collapse;
  border: #e0e0e0 solid 3px;
  width: 100%;
  counter-reset: administered-flow;
}

.administered-flow tr {
  border-bottom: #e0e0e0 solid 1px;
}

.administered-flow th {
  background: #f9f9f9 url(../images/icon/arrow_administered.png) center 85%/28.5px 13.5px no-repeat;
  text-align: center;
  font-size: 130%;
  font-weight: normal;
  width: 8em;
  color: #09295e;
  padding: 16px 0;
}

.administered-flow td {
  padding: 12px 20px;
}

.administered-flow tr:last-child > th {
  background-image: none;
}

.administered-flow h3 {
  margin: 1em 0;
  color: #808080;
  counter-increment: administered-flow;
}

.administered-flow h3::before {
  content: counter(administered-flow) ". ";
}

@media screen and (max-width: 999px) {
  .administered-flow th {
    width: 5em;
  }
  .administered-flow h3, .administered-flow p {
    margin: 0.5em 0;
  }
}

.case-example {
  position: relative;
  border: #e0e0e0 solid 3px;
  padding: 0 2em;
  margin: 2em 0 8em 0;
}

.case-example > h3 {
  font-size: 130%;
}

.case-example .test-application {
  padding-top: 3px;
  padding-bottom: 3px;
}

@media screen and (max-width: 999px) {
  .case-example {
    margin-bottom: 6em;
    padding: 0 1em;
  }
}

.case-example-items > dt {
  color: #808080;
}

.case-example-items > dd {
  margin: 1em 0 1.5em 0;
  padding: 0 0 1.3em;
  border-bottom: #e0e0e0 solid 1px;
  line-height: 2;
}

.case-example-items > dd:last-child {
  border: none;
  padding-bottom: 0;
}

.case-example-more {
  position: absolute;
  bottom: -3.7em;
  right: -3px;
  margin: 0;
}

/***************************************
 * Support
 ***************************************/
.materials-list {
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 4em;
}

@media screen and (max-width: 999px) {
  .materials-list {
    display: block;
  }
}

.materials-list .materials-image {
  width: 150px;
  margin-right: 35px;
}

@media screen and (max-width: 999px) {
  .materials-list .materials-image {
    width: auto;
    margin: 0 auto 15px;
    text-align: center;
  }
}

.materials-list .materials-image > li {
  margin-bottom: 15px;
}

@media screen and (max-width: 999px) {
  .materials-list .materials-image > li {
    text-align: center;
    display: inline-block;
    margin: 0 5px;
  }
}

.materials-list > div {
  -ms-flex: 1;
      flex: 1;
}

.materials-list > div > h3 {
  margin-top: 0;
  border-bottom: solid 2px #e0e0e0;
  padding: 0.2em 0;
  line-height: 2;
}

.materials-list > div .materials-description {
  background: #f9f9f9;
  padding: 15px;
  margin: 2em 0;
}

.materials-list > div .materials-buy-link {
  display: block;
  margin: 15px auto;
  box-sizing: border-box;
  border-radius: 3px;
  padding: 15px 1em 15px 3em;
  background: #ef7000 url(../images/icon/external_link.png) 20px 50% no-repeat;
  background-size: 30px 30px;
  color: #fff;
  text-align: center;
  font-weight: bold;
}

.lexile-header {
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 999px) {
  .lexile-header {
    display: block;
  }
}

.lexile-header .lexile-header-text {
  -ms-flex: 1;
      flex: 1;
  margin-right: 25px;
}

@media screen and (max-width: 999px) {
  .lexile-header .lexile-header-text {
    margin-right: 0;
  }
}

.lexile-header .lexile-header-image {
  width: 284px;
}

@media screen and (max-width: 999px) {
  .lexile-header .lexile-header-image {
    width: auto;
  }
  .lexile-header .lexile-header-image > img {
    width: 100%;
    height: auto;
  }
}

.lexile-genre {
  border: solid 2px #e0e0e0;
  box-sizing: boder-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.lexile-genre > li {
  text-align: center;
  width: calc(25% - 2px);
  box-sizing: boder-box;
  border: solid 1px #e0e0e0;
  padding: 10px 0;
}

@media screen and (max-width: 999px) {
  .lexile-genre > li {
    width: calc(50% - 2px);
  }
}

.lexile-style-wrapper {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

@media screen and (max-width: 999px) {
  .lexile-style-wrapper {
    display: block;
  }
}

.lexile-style-wrapper .lexile-style-box {
  border: solid 2px #e0e0e0;
  box-sizing: boder-box;
  width: 48%;
  margin: 0 0 4% 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
}

@media screen and (max-width: 999px) {
  .lexile-style-wrapper .lexile-style-box {
    width: auto;
  }
}

.lexile-style-wrapper .lexile-style-box > p {
  text-align: center;
  font-weight: bold;
  -ms-flex-positive: 1;
      flex-grow: 1;
}

.lexile-index-box {
  border: solid 2px #e0e0e0;
  box-sizing: boder-box;
  padding: 10px 35px;
  margin: 2em 0;
}

.lexile-index-box > h3 {
  font-weight: bold;
  font-size: 100%;
}

.lexile-index {
  margin: 0;
  padding: 0;
}

.lexile-index li {
  padding-left: 1em;
  text-indent: -1em;
  list-style-position: inside;
  margin: 1em 0;
}

.btn-tag-reset {
  margin-top: 12px;
  font-size: 90%;
  font-weight: bold;
  background-color: #09295e;
  color: #fff;
  padding: 9px 20px;
  display: inline-block;
  transition: all 0.3s ease;
}

.btn-tag-reset:hover {
  color: #fff;
  opacity: 0.75;
}

.tab.news-tab {
  margin-top: 40px;
  margin-bottom: 30px;
}

.tab.news-tab .tab-nav {
  font-size: 111.11111%;
  font-weight: bold;
  border-bottom: 4px solid #d6d6d6;
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 999px) {
  .tab.news-tab .tab-nav {
    font-size: 80%;
  }
}

.tab.news-tab .tab-nav li {
  margin-right: 42px;
}

@media screen and (max-width: 999px) {
  .tab.news-tab .tab-nav li {
    margin-right: 0;
  }
}

.tab.news-tab .tab-nav li a {
  color: inherit;
  display: inline-block;
  padding: 5px 22px 10px;
  position: relative;
}

@media screen and (max-width: 999px) {
  .tab.news-tab .tab-nav li a {
    padding: 5px 8px 10px;
  }
}

.tab.news-tab .tab-nav li a::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -4px;
  left: 0;
  right: 0;
  height: 4px;
  background-color: #d6d6d6;
  width: 100%;
  transition: all 0.3s ease;
  opacity: 0;
}

.tab.news-tab .tab-nav li.active a {
  color: #1c9ebe;
}

.tab.news-tab .tab-nav li.active a::after {
  background-color: #1c9ebe;
  opacity: 1;
}

.tab.news-tab .tab-nav li:hover:not(.active) a::after {
  background-color: #aaa;
  opacity: 1;
}

.tab.news-tab .tab-box {
  padding: 14px 0 24px;
  border-bottom: 1px solid #d6d6d6;
}

.tab.news-tab .tab-box > div:not(.active) {
  display: none;
}

.tab.news-tab .tab-box dl {
  display: -ms-flexbox;
  display: flex;
}

@media screen and (max-width: 999px) {
  .tab.news-tab .tab-box dl {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.tab.news-tab .tab-box dl dt {
  white-space: nowrap;
}

.tab.news-tab .tab-box dl dt .cat-tip {
  box-sizing: border-box;
  width: 96px;
}

.tab.news-tab .tab-box dl dd:nth-child(2) {
  margin: 0 20px 0 27px;
  white-space: nowrap;
}

.tab.news-tab .tab-box dl dd:nth-child(3) {
  margin: 0;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.tab.news-tab .tab-box dl dd:nth-child(3) a {
  color: inherit;
}

@media screen and (max-width: 999px) {
  .tab.news-tab .tab-box dl dd:nth-child(3) {
    padding: 7px 0 0 0;
    width: 100%;
  }
}

.tab.news-tab .tab-box dl + dl {
  margin: 13px 0 0;
}

.tab.news-tab .tab-box .tags {
  margin-top: 6px;
}

.news-table th, .news-table td {
  vertical-align: top;
  padding-bottom: 15px;
}

.news-table th {
  text-align: left;
  white-space: nowrap;
}

.news-table td p {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}

.news-table th + td {
  white-space: nowrap;
  padding-right: 10px;
  padding-left: 20px;
}

.news-tags .tags {
  padding-left: 35px;
  position: relative;
}

.news-tags .tags::after {
  content: "";
  display: block;
  position: absolute;
  top: 3px;
  left: 2px;
  width: 16px;
  height: 16px;
  background: url(../images/icon/tag.svg) center center no-repeat;
  background-size: 16px 16px;
}

.news-detail-info {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-align: end;
      align-items: flex-end;
}

.news-detail-info > * {
  margin-left: auto;
}

.news-detail-info .cat-tip {
  margin-right: 10px;
}

.news-detail-info .tags {
  margin-top: 10px;
  padding-left: 35px;
  position: relative;
}

.news-detail-info .tags li {
  margin-right: 0;
}

.news-detail-info .tags::after {
  content: "";
  display: block;
  position: absolute;
  top: 3px;
  left: 2px;
  width: 16px;
  height: 16px;
  background: url(../images/icon/tag.svg) center center no-repeat;
  background-size: 16px 16px;
}

.news-detail-entry {
  margin-bottom: 60px;
}

.news-detail-entry p + p {
  margin: 3em 0 0;
}

.news-detail-entry img.left {
  float: left;
  margin: 7px 50px 40px 0;
}

@media screen and (max-width: 999px) {
  .news-detail-entry img.left {
    margin: 7px 30px 20px 0;
  }
}

.news-detail-entry img.right {
  float: right;
  margin: 7px 0 40px 50px;
}

@media screen and (max-width: 999px) {
  .news-detail-entry img.right {
    margin: 7px 0 20px 30px;
  }
}

.news-detail-entry * + h2 {
  margin-top: 2em;
}

.news-detail-entry * + h3 {
  margin-top: 2em;
}

.news-detail-entry * + h4 {
  margin-top: 2em;
}

.news-detail-entry * + h5 {
  margin-top: 2em;
}

.news-detail-entry * + h6 {
  margin-top: 2em;
}
