@charset "UTF-8";
figure {
  margin: 1em 0;
}

.features-h1 {
  font-size: 2.5em;
  font-weight: bold;
  margin: 0.5em 0 0;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.features-h1 img {
  vertical-align: bottom;
}

.features-h1-gothic {
  font-size: 2.5em;
  font-weight: bold;
  margin: 0.5em 0 0;
}
.features-h1-gothic img {
  vertical-align: bottom;
}

.fukidashi-h2 {
  /*
  旧：画像を使う方法
  color: #0096E0;
  text-align: left;
  border-bottom: 2px solid #0096E0;
  font-weight: bold;
  position: relative;
  margin: 1em 0 1em;
  line-height: 1.2;
  display:table;
  // font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; 
  font-size:1.4em;
  &::after {
    content: url(../img/features/fukidashi.png);
    display: block;
    position: absolute;
    top: 1.02em;
    left:1.5em;
    @media(max-width:680px){
      top:auto;
      bottom:-0.98em;
    }
  }
  */
  position: relative;
  display: inline-block;
  margin-bottom: 20px;
  margin: 1em 0 0.5em;
  padding: 0;
  padding-bottom: 0.2em;
  border-bottom: 2px solid #0096E0;
  background-color: #FFF;
  font-size: 1.4em;
  font-weight: bold;
  line-height: 1.2;
  color: #0096E0;
}
.fukidashi-h2::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 20%;
  border-style: solid;
  border-width: 20px 16px 0 0;
  border-color: #0096E0 transparent transparent;
  translate: -50% 100%;
  transform: skew(0deg);
  transform-origin: top;
}
.fukidashi-h2::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 20%;
  border-style: solid;
  border-width: 14.3px 11.4px 0 0;
  border-color: #FFF transparent transparent;
  translate: calc(-50% - 0.4px) 100%;
  transform: skew(0deg);
  transform-origin: top;
}

.fukidashi-h2-utb, .ai-title, .sake-title {
  /*
  旧：画像を使う方法
  color: $color-UTokyo-Blue;
  text-align: left;
  border-bottom: 2px solid $color-UTokyo-Blue;
  font-weight: bold;
  position: relative;
  margin: 1em 0 1em;
  line-height: 1.2;
  display:table;
  // font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; 
  font-size:1.4em;
  &::after {
    content: url(../img/features/fukidashi_utb.png);
    display: block;
    position: absolute;
    top: 1.02em;
    left:1.5em;
    @media(max-width:680px){
      top:auto;
      bottom:-0.98em;
    }
  }
  */
  position: relative;
  display: inline-block;
  margin-bottom: 20px;
  margin: 1em 0 0.5em;
  padding: 0;
  padding-bottom: 0.2em;
  border-bottom: 2px solid #0095dc;
  background-color: #FFF;
  font-size: 1.4em;
  font-weight: bold;
  line-height: 1.2;
  color: #0095dc;
}
.fukidashi-h2-utb::before, .ai-title::before, .sake-title::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 20%;
  border-style: solid;
  border-width: 20px 16px 0 0;
  border-color: #0095dc transparent transparent;
  translate: -50% 100%;
  transform: skew(0deg);
  transform-origin: top;
}
.fukidashi-h2-utb::after, .ai-title::after, .sake-title::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 20%;
  border-style: solid;
  border-width: 14.3px 11.4px 0 0;
  border-color: #FFF transparent transparent;
  translate: calc(-50% - 0.4px) 100%;
  transform: skew(0deg);
  transform-origin: top;
}

.kumo-h2 {
  padding: 0.5em;
  display: table;
  color: #0095dc;
  text-align: center;
  font-weight: bold;
  margin: 1em 0 1em;
  line-height: 1.2;
  font-size: 1.4em;
  width: calc(330px - (0.5em * 2));
  max-width: calc(100% - (0.5em * 2));
  position: relative;
  z-index: 1;
}
@media (max-width: 580px) {
  .kumo-h2 {
    width: calc(320px - ((10px + 20px + 0.5em) * 2));
  }
}
.kumo-h2::before {
  content: '';
  display: inline-block;
  width: 330px;
  height: 59px;
  background-image: url(../img/features/kumo.png);
  background-repeat: no-repeat;
  background-size: 330px 59px;
  vertical-align: middle;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
@media (max-width: 580px) {
  .kumo-h2::before {
    width: calc(320px - ((10px + 20px) * 2));
    height: 84px;
    background-size: calc(320px - ((10px + 20px) * 2)) 84px;
  }
}
.kumo-h2-spbr {
  display: none;
}
@media (max-width: 580px) {
  .kumo-h2-spbr {
    display: block;
  }
}

.question {
  background-image: url(../img/features/q.png);
  background-repeat: no-repeat;
  background-position: left center;
  background-size: auto 2em;
  min-height: 2em;
  padding-left: 0.75em;
  margin-left: -0.75em;
  font-size: 1.3em;
}

.features-h2,
.features-h2-utb {
  font-size: 1.7em;
  font-weight: bold;
  margin: 1.4em 0 0.2em;
  color: #0096E0;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  position: relative;
  z-index: 10;
  line-height: 1.3;
}
.features-h2__num,
.features-h2-utb__num {
  color: #0096E0;
  font-size: 6em;
  position: absolute;
  line-height: 1;
  top: -30px;
  z-index: -20;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  opacity: 0.5;
}
.features-h2__text,
.features-h2-utb__text {
  position: relative;
  z-index: 20;
}
.features-h2 + p,
.features-h2-utb + p {
  position: relative;
  z-index: 20;
}

.features-h2-utb {
  color: #0095dc;
}
.features-h2-utb__num {
  color: #0095dc;
}

.features-h2-brown {
  font-size: 1.3em;
  font-weight: bold;
  margin: 1.4em 0 0.4em;
  position: relative;
  z-index: 10;
  color: #8E6539;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.features-h2-blue {
  font-size: 1.3em;
  font-weight: bold;
  margin: 1.4em 0 0.4em;
  position: relative;
  z-index: 10;
  color: #093488;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}

.features-h2-gothic-blue {
  font-size: 1.3em;
  font-weight: bold;
  margin: 1.4em 0 0.4em;
  position: relative;
  z-index: 10;
  color: #0096E0;
}

.features-h2-gothic {
  font-size: 1.3em;
  font-weight: bold;
  margin: 1.4em 0 0.4em;
  position: relative;
  z-index: 10;
}

.features-h2-number {
  margin-bottom: -1.5em;
}

.features-h2-number-deep {
  margin-bottom: -2em;
}

.features-h3 {
  line-height: 1.2;
  font-size: 1.2em;
  font-weight: bold;
  margin: 1em 0 0.4em;
  position: relative;
  z-index: 10;
  color: #000000;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}
.features-h3__inner {
  color: #093488;
  background: #EDEAE0;
}

.features-h3-utb {
  line-height: 1.2;
  font-size: 1.2em;
  font-weight: bold;
  margin: 1em 0 0.4em;
  position: relative;
  z-index: 10;
  color: #0095dc;
}

.circle_number {
  color: #fff;
  background-color: #00A0E9;
  border: 4px solid #00A0E9;
  border-radius: 50%;
  font-size: 0.7em;
  line-height: 1;
  padding-top: 0.1em;
  padding-left: 0.3em;
  padding-right: 0.3em;
  vertical-align: middle;
  display: inline-block;
  margin-bottom: 0.2em;
  margin-right: 0.5em;
}

.features-number {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.features-number__item {
  width: 290px;
  padding-bottom: 1em;
  position: relative;
}
.features-number__item-para {
  margin-top: 0;
  position: relative;
}
.features-number__item-para__inner {
  margin-top: 0;
  position: relative;
  display: block;
  width: 180px;
  float: left;
}
.features-number__label {
  color: #D2BFAB;
  font-size: 6em;
  font-weight: bold;
  position: absolute;
  left: 0.45em;
  top: 10px;
  z-index: 10;
  vertical-align: top;
  line-height: 1;
}
.features-number__label-last {
  color: #D2BFAB;
  font-size: 6em;
  font-weight: bold;
  position: absolute;
  right: 0.45em;
  top: 10px;
  z-index: 10;
  vertical-align: top;
  line-height: 1;
}
.features-number__text {
  position: relative;
  z-index: 20;
  display: block;
  font-size: 0.7em;
}
.features-number__text-right {
  position: relative;
  z-index: 20;
  display: table;
  font-size: 0.7em;
  padding-left: 5px;
}
.features-number__img {
  float: right;
  margin-left: 5px;
}
.features-number__img-last {
  float: left;
}

/* UTokyo推奨カラー */
.color-UTokyo-Yellow {
  color: #fdd000;
}

.color-UTokyo-Blue {
  color: #0095dc;
}

.color-White {
  color: white;
}

.color-Black {
  color: #888888;
}

.color-UTokyo-Green {
  color: #58b531;
}

.color-UTokyo-Red {
  color: #e6002d;
}

.color-UTokyo-Purple {
  color: #7f2289;
}

.color-UTokyo-Light-Blue {
  color: #68c9f2;
}

/* その他のカラー */
.color-light-blue {
  color: #00A1E9;
}

.color-dark-blue {
  color: #093488;
}

.color-blue {
  color: #0066A0;
}

.color-pink {
  color: #E4007F;
}

.color-brown {
  color: #8E6539;
}

.underbar-brown {
  border-bottom: 1px solid #8E643A;
}

.nowrap {
  white-space: nowrap;
}

.note {
  font-size: 0.8em;
  margin: 0 0 2em;
}
.note__marker {
  color: #E4007F;
}

.txt-inline {
  display: inline;
  line-height: 1.7;
}
.txt-inline-first {
  display: inline;
  line-height: 1.7;
  margin-left: 1em;
}

/* 1595 */
.csh-heading {
  position: relative;
}
.csh-heading img:first-of-type {
  position: absolute;
  top: 0.15em;
  left: 0;
}
.csh-heading span {
  display: block;
  position: absolute;
  bottom: 0;
  right: 0;
  margin: 0.5em;
  padding: 0.25em;
  width: calc(67.5% - (0.5em * 2) - (0.25em * 2));
  font-size: 28.44444%;
  font-weight: normal;
  background-color: rgba(254, 217, 0, 0.7);
  line-height: 1.2;
  border-radius: 4px;
}
@media (max-width: 580px) {
  .csh-heading span {
    position: static;
    padding: 0;
    width: auto;
  }
}
.csh-title {
  line-height: 1.2;
  font-size: 1.3em;
  font-weight: bold;
  margin: 1em 0;
  color: #0095dc;
}
.csh-side {
  margin: 1em 0;
}
.csh-side figure {
  margin: 0;
}
.csh-side figure figcaption {
  font-size: 0.8em;
}
.csh-noteonly {
  font-size: 0.8em;
}

.ai-heading {
  position: relative;
}
.ai-heading img:first-of-type {
  position: absolute;
  top: 0.15em;
  left: 0;
}
.ai-heading span {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  margin: 0.5em;
  padding: 0.25em;
  font-size: 28.44444%;
  font-weight: normal;
  color: #FFF;
  line-height: 1.2;
}
.ai-title {
  /* 継承 */
  /* ai用 ここから */
  padding-left: 0.25em;
  width: 15em;
  max-width: 100%;
  /* ai用 ここまで */
}
.ai-side {
  margin: 1em 0;
}
.ai-side figure {
  margin: 0;
}
.ai-side figure figcaption {
  font-size: 0.8em;
  color: #0095dc;
}
.ai-noteonly {
  font-size: 0.8em;
}

.sake-bk {
  background-image: url(../img/features/sake_back.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.sake-title {
  /* 継承 */
  /* sake用 ここから */
  padding-left: 0.25em;
  width: 15em;
  max-width: 100%;
  background-color: transparent;
  text-align: center;
  /* sake用 ここまで */
}
.sake-side {
  margin: 1em 0;
}
.sake-side figure {
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 3.5px;
  max-width: calc(370px + 3px);
}
.sake-side figure figcaption {
  font-size: 0.8em;
  color: #0095dc;
}
.sake-side div {
  margin-top: 0.4em;
  font-size: 0.8em;
  color: #0095dc;
}
.sake-noteonly {
  font-size: 0.8em;
}
