#contents .article-lead p {
  font-family: mrs-eaves, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: auto;
  font-weight: normal;
  font-weight: 600;
  font-style: normal;
  letter-spacing: 0;
  font-variant-numeric: lining-nums;
  -moz-font-feature-settings: "lnum";
  -webkit-font-feature-settings: "lnum";
  font-feature-settings: "lnum"; }
  .ua-desktop-windows #contents .article-lead p, #contents .article-lead .ua-desktop-windows p {
    -ms-transform: rotate(0.001deg);
    transform: rotate(0.001deg); }

.index .toc-item a, .index .toc-item > span {
  font-family: "Gothic MB101 Heavy", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: auto;
  font-weight: normal; }
  .ua-desktop-windows .index .toc-item a, .ua-desktop-windows .index .toc-item > span {
    -ms-transform: rotate(0.001deg);
    transform: rotate(0.001deg); }

.index .toc-item.off .toc-item__title i {
  background-color: #eee; }

.index .toc-item__title {
  display: flex;
  align-items: center; }
  .index .toc-item__title i {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-right: 0.5em;
    background: #66a2ff; }
  .device-sp .index .toc-item__title i {
    font-size: 100%;
    line-height: 32px;
    width: 32px;
    height: 32px;
    border-radius: 16px; }
  .device-pc .index .toc-item__title {
    font-size: 320%; }
    .device-pc .index .toc-item__title i {
      font-size: 100%;
      line-height: 48px;
      width: 48px;
      height: 48px;
      border-radius: 24px; }

#contents > header {
  padding-bottom: 16px; }

#contents .btn-permeate {
  color: #408bff; }

#contents .btn-profile {
  margin-top: 32px; }

#contents .article-title {
  background: url(../images/main_title_sp.jpg) no-repeat center top;
  background-size: contain;
  padding-top: 200%; }
  #contents .article-title__text {
    width: 100%; }
  @media (min-width: 480px) {
    #contents .article-title {
      background-image: url(../images/main_title_pc.jpg);
      padding-top: 56.25%; } }

#contents .article-lead {
  display: flex; }
  #contents .article-lead::before {
    content: "";
    display: block;
    width: 4px;
    border-radius: 2px;
    background-color: #66a2ff; }
  #contents .article-lead p {
    font-size: 15px;
    font-weight: normal;
    line-height: 1.4; }
  #contents .article-lead .note {
    font-size: 120%;
    line-height: 1.5; }
  #contents .article-lead__text {
    width: calc(100% - 16px);
    margin-left: 12px; }

#contents section > h3 {
  text-align: center;
  display: flex;
  align-items: center;
  font-family: "Gothic MB101 Heavy", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: auto;
  font-weight: normal; }
  .ua-desktop-windows #contents section > h3 {
    -ms-transform: rotate(0.001deg);
    transform: rotate(0.001deg); }
  #contents section > h3 small {
    display: block;
    margin-right: 0.5em;
    background: #66a2ff; }

#contents .photo img {
  width: 100%; }

#contents .continue {
  font-size: 160%; }

.device-sp #contents {
  padding: 0 16px; }
  .device-sp #contents .article-lead a.btn-modal {
    display: table; }
  .device-sp #contents section > h3 {
    font-size: 200%;
    justify-content: center; }
    .device-sp #contents section > h3 small {
      line-height: 32px;
      width: 32px;
      height: 32px;
      border-radius: 16px; }

.device-pc #contents {
  width: 96em;
  margin: 0 auto; }
  .device-pc #contents > header {
    padding-bottom: 0; }
  .device-pc #contents .article-title {
    background-image: url(../images/main_title_pc.jpg);
    padding-top: 56.25%; }
  .device-pc #contents .article-lead {
    max-width: 560px; }
    .device-pc #contents .article-lead a.btn-modal {
      max-width: 320px; }
    .device-pc #contents .article-lead p {
      font-size: 20px;
      line-height: 1.5; }
    .device-pc #contents .article-lead__text {
      width: calc(100% - 40px);
      margin-left: 36px; }
  .device-pc #contents .article-navi + footer {
    padding-top: 0; }
  .device-pc #contents section > h3 {
    max-width: 560px;
    margin: auto;
    font-size: 240%; }
    .device-pc #contents section > h3 small {
      line-height: 40px;
      width: 40px;
      height: 40px;
      border-radius: 20px; }

.article #techo-slide {
  position: relative;
  overflow: hidden;
  max-width: 960px;
  padding-top: 15%; }
  .article #techo-slide a {
    display: block;
    max-width: 193px;
    width: calc(20% + 1px);
    position: absolute;
    padding-top: 15%;
    top: 0;
    border-left: 1px solid white; }
    .article #techo-slide a img {
      position: absolute;
      width: 100%;
      height: 100%;
      top: 0;
      left: 0; }
    .article #techo-slide a::after {
      position: absolute;
      content: "\F415";
      color: #408bff;
      font-family: "Material Design Icons";
      right: 0;
      bottom: 0;
      font-size: 200%;
      line-height: 1; }
    .article #techo-slide a:nth-child(1) {
      left: 0%; }
    .article #techo-slide a:nth-child(2) {
      left: 20%; }
    .article #techo-slide a:nth-child(3) {
      left: 40%; }
    .article #techo-slide a:nth-child(4) {
      left: 60%; }
    .article #techo-slide a:nth-child(5) {
      left: 80%; }
    .article #techo-slide a:nth-child(6) {
      left: 100%; }
    .article #techo-slide a:nth-child(7) {
      left: 120%; }
    .article #techo-slide a:nth-child(8) {
      left: 140%; }
    .article #techo-slide a:nth-child(9) {
      left: 160%; }
    .article #techo-slide a:nth-child(10) {
      left: 180%; }
  .article #techo-slide.play a {
    animation: loop 50s linear infinite; }

.device-sp #slide-container {
  width: 300%;
  max-width: 960px;
  margin-left: -16px; }

@keyframes loop {
  0% {
    transform: translate(0, 0); }
  100% {
    transform: translate(-500%, 0); } }

.conv {
  margin: 0 auto 16px; }
  .conv::before {
    content: "\F1E7";
    font-family: "Material Design Icons", sans-serif;
    font-size: 16px;
    text-align: center;
    color: #66a2ff;
    display: block;
    line-height: 1;
    margin: 32px 0; }
  .conv p {
    display: flex;
    font-size: 160%;
    margin-bottom: 1.75em; }
    .conv p.ta > b {
      color: #408bff; }
    .conv p:not(.ta) > b {
      letter-spacing: -0.075em;
      color: #808080; }
    .conv p > b {
      width: 60px; }
      .conv p > b > img {
        vertical-align: bottom; }
    .conv p > span {
      width: calc(100% - 60px);
      padding-left: 20px;
      display: flex;
      align-items: center;
      letter-spacing: 0.05em; }
  .conv + p {
    text-align: center; }
  .conv .photo {
    margin: 2em 0; }
    .conv .photo p {
      font-size: 140%;
      display: block; }
  .device-sp .conv p {
    flex-direction: column; }
    .device-sp .conv p > b {
      font-size: 87.5%;
      width: auto; }
    .device-sp .conv p > span {
      width: auto;
      padding-left: 0; }
  .device-sp .conv br:not(.sp) {
    display: none; }
  .device-pc .conv {
    max-width: 560px; }
    .device-pc .conv::before {
      font-size: 24px;
      margin-bottom: 40px; }
    .device-pc .conv .photo {
      margin: 40px 0; }
