@charset "utf-8";
/* CSS Document */
/* ------------------------------------------------------------- */
/* layout / parts                                                */
/* ------------------------------------------------------------- */
html.wf-loading {
  opacity: 0;
  transition: all .0s ease;
}
html.wf-active {
  opacity: 1;
}
.pc {
  display: block !important;
}
.sp {
  display: none !important;
}
body {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 16px;
  color: #000;
  background: #fff;
  line-height: 2;
  letter-spacing: 0;
  line-height: 1.2;
}
body.lock {
  overflow: hidden;
}
.outer {
  width: 100%;
}
.inner {
  margin: 0 auto;
}
.clearfix::after {
  content: "";
  display: block;
  clear: both;
}
/*h4 {
	position:relative;
	font-size:1.2rem;
	font-weight:bold;
}
h4:before{
	content:"";
	position:absolute;
	display:inline-block;
	height:2px;
	width:16px;
	top:50%;
	left:-30px;
	transform:translateY(-50%);
    background: #00aad4;
}*/
/*-----------------font--------------------*/
.serif {
  font-family: 'Noto Serif JP', serif;
}
/*-----------------画像--------------------*/
img.fit-cover {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;'
}
img.fit-contain {
  width: 100%;
  height: 100%;
  object-fit: contain;
  font-family: 'object-fit: contain;'
}
figure img {
  width: 100%;
}
/*-----------------flex--------------------*/
.flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.flex.nowrap {
  flex-wrap: nowrap;
}
.flex.right {
  justify-content: flex-end;
}
.flex.center {
  justify-content: center;
}
.flex.left {
  justify-content: flex-start;
}
.flex.vertical {
  flex-direction: column;
  align-items: flex-start;
}
.flex.al-center {
  align-items: center;
}
.v-center {
  display: flex;
  justify-content: center;
  align-items: center;
}
/*-----------------Link--------------------*/
a {
  text-decoration: none;
  transition: all .3s ease;
}
li > a {
  display: block;
}
a.more {
  font-weight: bold;
  color: #19195e;
}
a.more:hover {
  opacity: 0.7;
}
a.more::after {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  background-image: url(../img/icon-n-arrow.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  margin-left: 1em;
}
.btn {
  display: block;
  height: 70px;
  width: 370px;
  border-radius: 35px;
  line-height: 70px;
  background-repeat: no-repeat;
  background-size: 10px 17px;
  background-position: right 20px center;
  transition: all .3s ease;
  text-align: center;
}
.btn.white {
  background-image: url(../img/icon-n-arrow.png);
  background-color: #fff;
  color: #222222;
}
.btn.navy {
  background-image: url(../img/icon-w-arrow.png);
  background-color: #19195e;
  color: #ffffff;
}
.btn.transparent {
  background-image: url(../img/icon-w-arrow.png);
  background-color: transparent;
  color: #ffffff;
  border: 1px solid #fff;
}
.btn.noarrow {
  background-image: none;
}
.btn:hover {
  opacity: 0.7;
}
.btn.small {
  font-size: 14px;
  font-weight: 500;
  height: 40px;
  line-height: 40px;
}
.btn.grad {
  position: relative;
  color: #fff;
  background: #12437f;
  background: -moz-linear-gradient(left, #0b699f 0%, #19195e 100%);
  background: -webkit-linear-gradient(left, #0b699f 0%, #19195e 100%);
  background: linear-gradient(to right, #0b699f 0%, #19195e 100%);
}
.btn.grad::after {
  content: "";
  display: block;
  height: 100%;
  width: 8px;
  position: absolute;
  top: 0;
  right: 20px;
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
  background-image: url(../img/icon-w-arrow.png);
}
.link-arrow {
  position: relative;
  display: flex;
  align-items: center;
  font-size: 15px;
  line-height: 1.33;
  letter-spacing: 0.05em;
  background-position: 295px center;
  background-repeat: no-repeat;
  background-size: 9px 15px;
  background-image: url(../img/icon-n-arrow.png);
  color: #0c629a;
  border: 1px solid #0c629a;
  padding: 0 15px;
  margin-top: 12px;
  background-color: #ebf3f7;
}
.new .link-arrow {
  width: 375px;
  background-position: 343px center;
}
.case-list .link-arrow {
  /*display:none;*/
}
/*-----------------background--------------------*/
.bg-grad {
  background: #12437f;
  background: -moz-linear-gradient(left, #12437f 0%, #181d62 100%);
  background: -webkit-linear-gradient(left, #12437f 0%, #181d62 100%);
  background: linear-gradient(to right, #12437f 0%, #181d62 100%);
}
/*-----------------decoration--------------------*/
.under-line {
  background: linear-gradient(transparent 96%, #00aad4 96%);
  padding-bottom: 5px;
}
.input-any, .input-require {
  display: inline-block;
  padding: 3px 5px;
  font-size: 12px;
  color: #fff;
  border-radius: 2px;
}
.input-any {
  background-color: #19195e
}
.input-require {
  background-color: #d23333;
}
/*-----------------input--------------------*/
input, textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  outline: none;
  box-sizing: border-box;
  border: 1px solid #6A6A6A;
  font-family: 'Noto Sans JP', sans-serif, "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  border-radius: 2px;
  background-color: #fff;
}
input[type="radio"] {
  display: none;
}
.radio-label, .mktoRadioList label {
  position: relative;
  cursor: pointer;
  margin-right: 30px;
  padding-top: 1px;
  padding-left: 30px;
  font-size: 15px;
}
.radio-label::before, .mktoRadioList label::before {
  content: "";
  position: absolute;
  top: 1px;
  left: 0;
  display: block;
  width: 18px;
  height: 18px;
  border-radius: 10px;
  border: 1px solid #6A6A6A;
  background-color: #fff;
}
.radio-label::after, .mktoRadioList label::after {
  content: "";
  position: absolute;
  top: 7px;
  left: 6px;
  display: block;
  width: 8px;
  height: 8px;
  border-radius: 4px;
}
input[type="radio"]:checked + .radio-label::before, input[type="radio"]:checked + label::before {
  border-color: #19195e;
}
input[type="radio"]:checked + .radio-label::after, input[type="radio"]:checked + label::after {
  background-color: #19195e;
}
.mktoForm .mktoRadioList > label, .mktoForm .mktoCheckboxList > label {
  line-height: 1.5em !important;
  margin-bottom: 0.5em !important;
}
textarea, input[type="text"], input[type="tel"], input[type="email"], input[type="uRL"], input[type="number"] {
  padding: 8px 12px !important;
  font-size: 15px !important;
}
input::placeholder {
  color: #666666;
}
input:-ms-input-placeholder {
  color: #666666;
} /* IE */
input::-ms-input-placeholder {
  color: #666666;
} /* Edge */
select {
  border-radius: 2px !important;
  border: 1px solid #6a6a6a !important;
  padding: 10px 12px !important;
}
/*-----------------heading--------------------*/
/* 日本語＋小サイズ英語 */
.h-under-txt {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  letter-spacing: 0.16em;
}
.h-under-txt span {
  font-size: 40px;
  margin-bottom: 20px;
}
.h-under-txt small {
  font-size: 12px;
  color: #6d85c3;
  font-weight: 300;
}
/* 日本語＋背景に大サイズ英語 */
.h-overlay {
  position: relative;
  text-align: center;
  height: 60px;
  padding-bottom: 25px;
  margin-bottom: 25px;
}
.h-overlay::after {
  content: "";
  background-color: #19195e;
  display: block;
  height: 2px;
  width: 57px;
  position: absolute;
  bottom: -25px;
  left: 50%;
  transform: translateX(-50%);
}
.h-overlay small {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 71px;
  color: #19195e;
  font-weight: 300;
  line-height: 60px;
  letter-spacing: 0.08em;
  opacity: 0.04;
  white-space: nowrap;
}
.h-overlay span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -40%);
  font-size: 32px;
  line-height: 60px;
  letter-spacing: 0.16em;
  text-shadow: 0px 0px 5px #ffffff;
  white-space: nowrap;
}
/* 下線 */
.h-underline {
  position: relative;
  text-align: center;
  padding-bottom: 25px;
  font-size: 30px;
}
.h-underline::after {
  content: "";
  background-color: #19195e;
  display: block;
  height: 2px;
  width: 57px;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
.h-underline.small {
  padding-bottom: 15px;
  font-size: 20px;
}
/*-----------------list--------------------*/
li.recommend, li.new {
  position: relative;
}
li.recommend::after, li.new::after {
  content: "";
  display: block;
  width: 67px;
  height: 67px;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: 1px;
  right: 1px;
}
li.recommend::after {
  background-image: url(../img/icon-recommend.png);
}
li.new::after {
  background-image: url(../img/icon-new.png);
}
.grad-list {
  /*background: #0b699f;
	background: -moz-linear-gradient(left,  #0b699f 0%, #19195e 100%);
	background: -webkit-linear-gradient(left,  #0b699f 0%,#19195e 100%);
	background: linear-gradient(to right,  #0b699f 0%,#19195e 100%);*/
}
.grad-list li {
  position: relative;
  width: 270px;
}
.grad-list li::after {
  content: "";
  position: absolute;
  top: 0;
  right: -30px;
  display: block;
  width: 30px;
  height: 100%;
  background-color: #e8e8e8;
}
.grad-list figure {
  width: 100%;
  overflow: hidden;
}
.grad-list figure img {
  position: relative;
  z-index: 0;
  height: 170px;
  display: block;
  background-color: #fff;
}
.grad-list figcaption {
  height: 35px;
  line-height: 35px;
  color: #fff;
  text-align: center;
  position: relative;
  top: -3px;
  z-index: 1;
  background: #0b699f;
  background: -moz-linear-gradient(left, #0b699f 0%, #19195e 100%);
  background: -webkit-linear-gradient(left, #0b699f 0%, #19195e 100%);
  background: linear-gradient(to right, #0b699f 0%, #19195e 100%);
}
.grad-list P {
  background-color: #e8e8e8;
  color: #000;
  padding-top: 15px;
  padding-bottom: 45px;
}
.grad-list img, .grad-list figcaption, .grad-list P {
  transition: all .3s ease;
}
.grad-list a:hover img {
  opacity: 0.7;
}
.grad-list a:hover P {
  color: rgba(0, 0, 0, 0.7);
}
.grad-list a:hover figcaption {
  color: rgba(255, 255, 255, 0.7);
}
.case-list-wrap {
  position: relative;
  overflow: hidden;
  padding-bottom: 80px;
}
.case-list-wrap::before {
  content: "";
  position: absolute;
  top: 80px;
  left: 0;
  display: block;
  width: 100vw;
  height: 110%;
  background: #0b699f;
  background: -moz-linear-gradient(left, #0b699f 0%, #19195e 100%);
  background: -webkit-linear-gradient(left, #0b699f 0%, #19195e 100%);
  background: linear-gradient(to right, #0b699f 0%, #19195e 100%);
  z-index: 0;
}
.case-list li {
  width: 360px;
  position: relative;
  background-color: #fff;
}
.case-list li a {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.case-list li a:hover {
  opacity: 0.7;
}
.case-list figure {
  width: 100%;
  height: 230px;
  position: relative;
}
.case-list .txt {
  /*display: flex;
	flex-direction: column;
	justify-content: space-between;
	flex-grow: 1;*/
  padding: 20px;
  color: #000;
  background-color: #fff;
}
.case-list .txt strong {
  display: block;
  /*flex-grow: 1;*/
  font-size: 20px;
  line-height: 1.5;
  height: 100px;
  font-weight: bold;
}
.case-list .txt small {
  flex-grow: 0;
  color: #666666;
  font-size: 15px;
  margin-top: 10px;
  letter-spacing: 0.05em;
  line-height: 1.6em;
  margin-top: 0;
  display: block;
  border-top: 1px solid #ddd;
  padding-top: 12px;
}
.case-list .txt hr {
  height: 1px;
  width: 100%;
  border: none;
  background-color: #cdcdcb;
  margin: 30px 0;
}
.case-list .txt span {
  flex-grow: 0;
  /*	min-height: 38px;*/
  font-size: 15px;
  font-weight: bold;
  line-height: 2.3;
}
.case-list .tags {
  display: flex;
  position: absolute;
  bottom: 15px;
  left: 20px;
}
@media screen and (max-width:767px) {
  .case-list .txt strong {
    height: auto;
    padding-bottom: 20px;
    font-size: 18px;
  }
  .case-list .tags {
    bottom: 18px;
  }
  .case-list figure {
    height: auto;
  }
  .case-list .txt small {
    font-size: 13px;
  }
  .case-list .txt span {
    font-size: 4vw;
  }
}
.case-list .tags li {
  background-color: #19195e;
  color: #fff;
  font-size: 12px;
  padding: 3px 10px;
  width: auto;
  border-radius: 3px;
  margin-right: 3px;
  margin-bottom: 0;
}
.case-list-wrap .btn {
  margin: 55px auto 0;
  position: relative;
  z-index: 1;
}
@media (min-width: 1260px) {
  .case-list li.new {
    width: 100%;
    position: relative;
  }
  .case-list .new a {
    flex-direction: row;
  }
  .case-list .new figure {
    width: 360px;
    min-width: 360px;
    height: 230px;
    border-right: none;
  }
  .case-list .new .txt {
    padding: 10px 20px;
    background-color: transparent;
  }
  .case-list .new .txt strong {
    font-size: 28px;
    display: inline;
    flex-grow: 0;
    color: #19195e;
    display: block;
    padding-bottom: 10px;
    height: auto;
  }
  .case-list .new .txt hr {
    margin: 10px 0;
  }
}
.stick-out-list > li {
  position: relative;
  width: 100%;
  padding-top: 10px;
  padding-left: 20px;
  margin-bottom: 20px;
}
.stick-out-list figure {
  position: absolute;
  top: 0;
  left: 0;
  width: 113px;
  height: 160px;
  display: flex;
  flex-direction: column;
  z-index: 1;
}
.stick-out-list figcaption {
  position: relative;
  background: #0b699f;
  background: -moz-linear-gradient(left, #0b699f 0%, #19195e 100%);
  background: -webkit-linear-gradient(left, #0b699f 0%, #19195e 100%);
  background: linear-gradient(to right, #0b699f 0%, #19195e 100%);
  flex-grow: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #fff;
  font-size: 15px;
  padding: 8px;
  margin-top: -5px;
}
.stick-out-list figcaption::after {
  content: "";
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 20px 12px 0;
  border-color: transparent #050521 transparent transparent;
  position: absolute;
  left: 0;
  bottom: -12px;
}
.stick-out-list .txt {
  padding: 20px 45px 20px 120px;
  display: flex;
  flex-direction: column;
  min-height: 200px;
  background-color: #fff;
}
.stick-out-list strong {
  color: #000000;
  font-size: 22px;
  line-height: 1.4;
  margin-bottom: 10px;
  letter-spacing: 0.05em;
  font-weight: bold;
}
.stick-out-list p {
  color: #666666;
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: 0.1em;
  margin-bottom: 10px;
  border-top: 1px solid #ddd;
  padding-top: 10px;
}
.stick-out-list a {
  display: block;
}
.stick-out-list a:hover {
  color: #19195e;
  opacity: 0.7;
}
.stick-out-list .new strong {
  font-size: 28px;
}
.stick-out-list .new p {
  font-size: 16px;
}
.stick-out-list .new .btn {
  margin-top: 30px;
  width: 250px;
}
.stick-out-list li.new::after {
  top: 10px;
}
.stick-out-list figure {
  height: 125px;
}
.tag-list {
  color: #222222;
  font-size: 15px;
  line-height: 1;
}
.tag-list li {
  position: relative;
  margin-right: 15px;
}
.tag-list li::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 100%;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  background-image: url(../img/icon-lb-tag.png);
  position: relative;
  top: 2px;
  margin-right: 2px;
}
.consul-list li {
  width: 210px;
}
.consul-list a {
  display: block;
}
.consul-list a:hover {
  opacity: 0.7;
}
.consul-list figure {
  width: 100%;
  /*height: 170px;*/
}
.consul-list .txt {
  margin-top: 10px;
  text-align: center;
}
.consul-list span {
  display: block;
  font-size: 14px;
  color: #000;
  margin-bottom: 5px;
}
.consul-list strong {
  display: block;
  font-weight: bold;
  font-size: 18px;
  color: #19195e;
}
.seminar-list li {
  margin-bottom: 10px;
  transition: all .3s ease;
  position: relative;
}
.seminar-list a {
  position: relative;
}
.seminar-list a::after {
  content: "";
  display: block;
  height: 100%;
  width: 10px;
  position: absolute;
  top: 0;
  right: 30px;
  background-image: url(../img/icon-n-arrow.png);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
.seminar-list li:hover {
  opacity: 0.7;
}
.seminar-list .seminar-item {
  flex-wrap: nowrap;
  background-color: #fff;
  padding: 15px 60px 15px 25px;
}
.seminar-list .seminar-item .date {
  width: 110px;
  margin-right: 20px;
  flex-shrink: 0;
  color: #19195e;
  font-weight: 500;
  position: relative;
}
.seminar-list .seminar-item .date::after {
  content: "";
  display: block;
  width: 60px;
  height: 1px;
  background-color: #19195e;
  position: absolute;
  top: 84px;
  left: 14px;
  transform: rotate(-45deg);
}
.seminar-list .seminar-item .date * {
  position: absolute;
}
.seminar-list .seminar-item .year {
  font-size: 16px;
  left: 0;
  top: 37px;
}
.seminar-list .seminar-item .month {
  font-size: 33px;
  left: 0;
  top: 52px;
}
.seminar-list .seminar-item .day {
  font-size: 46px;
  right: 0;
  top: 62px;
}
.seminar-list .seminar-item .wday {
  font-size: 13px;
  left: 50%;
  bottom: 35px;
  transform: translateX(-50%);
}
.seminar-list .seminar-item figure {
  width: 280px;
  height: 170px;
  margin-right: 30px;
  flex-shrink: 0;
}
.seminar-list .seminar-item .txt {
  flex-shrink: 1;
}
.seminar-list .seminar-item strong {
  display: block;
  font-weight: 500;
  font-size: 24px;
  /*background-image: url(../img/icon-live.png);*/
  background-size: 98px 28px;
  background-repeat: no-repeat;
  background-position: 0 center;
  padding-left: 110px;
  margin-bottom: 25px;
  margin-top: 10px;
  color: #000;
  font-weight: bold;
}
.seminar-list .seminar-item p {
  font-size: 14px;
  line-height: 1.7;
  letter-spacing: 0.05em;
  color: #222222;
}
.document-list li {
  width: 270px;
  transition: all .3s ease;
}
.document-list li:hover {
  opacity: 0.7;
}
.document-list figure {
  height: 170px;
  width: 100%;
  position: relative;
}
.document-list figcaption {
  display: inline-block;
  min-width: 80px;
  height: 33px;
  line-height: 33px;
  position: absolute;
  top: 0;
  left: 0;
  color: #fff;
  text-align: center;
  font-size: 13px;
}
.document-list p {
  font-size: 18px;
  color: #000;
  font-weight: 700;
  margin-top: 20px;
  letter-spacing: 0.05em;
  line-height: 1.4;
}
.regexp-list {
  margin: 40px auto;
}
.regexp-list li {
  font-size: 14px;
  height: 40px;
  line-height: 40px;
  border-radius: 20px;
  background-color: #e7eaef;
  text-align: center;
  width: 15%;
}
.regexp-list li a {
  color: #19195e;
}
.regexp-list li.active {
  background: #19195e;
  background: -moz-linear-gradient(left, #0c629a 0%, #19195e 100%);
  background: -webkit-linear-gradient(left, #0c629a 0%, #19195e 100%);
  background: linear-gradient(to right, #0c629a 0%, #19195e 100%);
}
.regexp-list li.active a {
  color: #fff;
}
.regexp-list a:hover {
  opacity: 0.7;
}
/* ------------------------------------------------------------- */
/* header                                                        */
/* ------------------------------------------------------------- */
header {
  background-color: #fff;
}
header .hd-ttl {
  font-size: 12px;
  color: #000;
  letter-spacing: 0.1em;
}
header .hd-logo {
  margin-top: 8px;
  height: 33px;
}
header .header-nav a {
  display: block;
  margin-right: 15px;
  color: #000;
}
header .header-nav a:hover {
  opacity: 0.7;
}
header .hd-btn {
  position: relative;
  height: 60px;
  width: 152px;
  margin-right: 0;
  padding-top: 35px;
  text-align: center;
  border-radius: 30px;
  font-size: 13px;
  background-color: #00aad4;
  background-image: url(../img/icon-w-mail.png);
  background-repeat: no-repeat;
  background-size: 27px 19px;
  background-position: center top 10px;
  letter-spacing: 0.1em;
}
header .header-nav a.hd-btn {
  color: #fff;
}
/* ------------------------------------------------------------- */
/* mv                                                            */
/* ------------------------------------------------------------- */
.mv {
  padding: 0;
}
.mv-wrap {
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  width: 100%
}
.page .mv-wrap {
  height: 450px;
}
.detail .mv-wrap {
  height: 450px;
}
.list .mv-wrap {
  height: 350px;
}
.list.detail .mv-wrap {
  height: 450px;
}
.download.detail .mv-wrap {
  height: 350px;
}
.mv-front {
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
}
.mv-front span, .mv-front strong {
  display: block;
}
.page .mv-front span {
  font-size: 20px;
  margin-bottom: 15px;
  letter-spacing: 0.05em;
}
.page .mv-front strong {
  font-size: 46px;
  line-height: 1.2;
  color: #19195e;
  margin-bottom: 15px;
  letter-spacing: 0.1em;
}
.page .mv-front h1 + p {
  font-size: 15px;
  margin-bottom: 30px;
  line-height: 1.9;
}
.page .mv-front h1 + p.sub-ttl {
  margin-top: 20px;
  font-size: 32px;
  color: #19195e;
}
.list .mv-front, .detail .mv-front {
  color: #fff;
}
.detail .mv-front .category {
  margin-bottom: 15px;
}
.detail .mv-front .category span {
  background-color: rgba(255, 255, 255, 0.8);
  display: inline-block;
  padding: 0 10px;
  height: 22px;
  line-height: 22px;
  color: #153272;
}
.list .mv-front strong, .detail .mv-front strong {
  font-size: 40px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  display: inline;
}
.list .mv-front p, .detail .mv-front p {
  margin-top: 15px;
  font-size: 14px;
  line-height: 1.7;
}
.detail .mv-front .name {
  display: inline;
  font-size: 28px;
  margin-top: 10px;
  padding: 6px 22px;
  background: #fff;
  color: #0c629a;
  border: 1px solid #0c629a;
  background-color: #ebf3f7;
  letter-spacing: 0.05em;
  font-weight: bold;
}
/*
.list .mv-front strong {
	font-size: 40px;
	line-height: 1.5;
	letter-spacing: 0.05em;
	display: inline;
} */
@media screen and (max-width:767px) {
  .detail .mv-front .name {
    font-size: 17px;
  }
}
/*-----------------subnav--------------------*/
.sub-nav li {
  height: 80px;
  line-height: 80px;
  text-align: center;
}
.sub-nav a {
  color: #fff;
  display: block;
}
.sub-nav a:hover {
  opacity: 0.7;
}
.sub-nav.top {
  background: #182063;
  background: -moz-linear-gradient(left, #0c629a 0%, #182063 100%);
  background: -webkit-linear-gradient(left, #0c629a 0%, #182063 100%);
  background: linear-gradient(to right, #0c629a 0%, #182063 100%);
}
.sub-nav.top li {
  border-right: 1px solid rgba(255, 255, 255, 0.3);
}
.sub-nav.top a {
  color: #fff;
}
.sub-nav.bottom {
  background-color: #f2f2f2;
}
.sub-nav.bottom li {
  border-right: 1px solid rgba(23, 35, 102, 0.15);
}
.sub-nav.bottom a {
  color: #19195e;
}
.sub-nav li:first-of-type {
  border-left: 1px solid rgba(255, 255, 255, 0.3);
}
.sub-nav.bottom li:first-of-type {
  border-left: 1px solid rgba(23, 35, 102, 0.15);
}
.current {
  background: -webkit-linear-gradient(left, #83c5e7 0%, #4eabdc 100%);
  background: -o-linear-gradient(left, #83c5e7 0%, #4eabdc 100%);
  background: linear-gradient(to right, #83c5e7 0%, #4eabdc 100%);
  position: relative;
  box-sizing: border-box;
  border-bottom: 2px solid #1c92d2;
  border-right: none !important;
  border-left: none !important;
  pointer-events: none;
}
.current:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 3px;
}
.current a {
  color: #fff !important;
}
.company-top .sub-nav ul li.company_ {
  background: -webkit-linear-gradient(left, #83c5e7 0%, #4eabdc 100%);
  background: -o-linear-gradient(left, #83c5e7 0%, #4eabdc 100%);
  background: linear-gradient(to right, #83c5e7 0%, #4eabdc 100%);
  position: relative;
  box-sizing: border-box;
  border-bottom: 2px solid #1c92d2;
  border-right: none !important;
  border-left: none !important;
  pointer-events: none;
}
.company-top .sub-nav ul li.company_:after {
  content: "";
  position: absolute;
  width: 100%;
  height: 3px;
}
.company-top .sub-nav ul li.company_ {
  color: #fff !important;
}
/*-----------------breadcrumb--------------------*/
.breadcrumb {
  margin-top: 15px;
}
.breadcrumb li {
  font-size: 14px;
}
.breadcrumb a {
  color: #000;
}
.breadcrumb span {
  color: #19195e;
  font-weight: bold;
}
.breadcrumb a::after {
  content: "＞";
  display: inline-block;
  margin: 0 1em;
}
/* ------------------------------------------------------------- */
/* footer                                                        */
/* ------------------------------------------------------------- */
.footer-about {
  padding: 90px 0 0;
  color: #fff;
  text-align: center;
}
.footer-about h2 {
  margin-bottom: 50px;
}
.footer-about .parenthesis {
  position: relative;
  display: inline-block;
  font-size: 26px;
  font-weight: bold;
  margin-bottom: 40px;
}
.footer-about .parenthesis::before, .footer-about .parenthesis::after {
  position: absolute;
  font-size: 50px;
  font-weight: 300;
}
.footer-about .parenthesis::before {
  content: "「";
  top: -14px;
  left: -1em;
}
.footer-about .parenthesis::after {
  content: "」";
  bottom: -14px;
  right: -1em;
}
.footer-about .parenthesis + p {
  letter-spacing: 0.08em;
  line-height: 2;
}
.footer-about .inner a {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-top: 35px;
}
.footer-about .cv {
  margin-top: 100px;
}
.footer-about .cv a {
  width: 50%;
  height: 290px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: #fff;
  background-repeat: no-repeat;
  background-size: cover;
}
.footer-about .cv a:nth-of-type(1) {
  background-image: url(../img/footer-img-01.png);
}
.footer-about .cv a:nth-of-type(2) {
  background-image: url(../img/footer-img-02.png);
}
.footer-about .cv small {
  display: inline-block;
  letter-spacing: 0.06em;
  line-height: 35px;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  margin-bottom: 20px;
}
.footer-about .cv strong {
  letter-spacing: 0.08em;
  font-size: 30px;
  margin-bottom: 35px;
}
.footer {
  background-color: #fff;
  padding: 40px 40px 25px;
}
.footer .footer-left img {
  height: 25px;
}
.footer .footer-right li {
  padding: 6px 22px;
  border-right: 1px solid #aaaaaa;
}
.footer .footer-right li:last-of-type {
  padding-right: 0;
  border-right: 0;
}
.footer .footer-right a {
  font-size: 14px;
  color: #000;
}
.footer .footer-right a:hover {
  opacity: 0.7;
}
.footer .footer-bottom {
  text-align: center;
  width: 100%;
  font-size: 10px;
  margin-top: 25px;
  letter-spacing: 0.16em;
}
/* ------------------------------------------------------------- */
/* aside                                                         */
/* ------------------------------------------------------------- */
aside {
  background-color: #fff;
  padding: 0 25px;
  align-self: flex-start;
}
.aside-list-wrap {
  padding: 40px 0;
  text-align: right;
  /*border-bottom: 1px solid #bbb;*/
}
.aside-list-wrap:first-of-type {
  padding-top: 25px;
}
.aside-list-wrap:last-of-type {
  border: none;
}
.aside-list-wrap > strong {
  display: block;
  text-align: center;
  font-size: 17px;
  font-weight: 500;
  color: #fff;
  position: relative;
  padding: 15px 0;
  margin-bottom: 30px;
  background: #19195e;
  letter-spacing: 0.05em;
}
.aside-list-wrap > strong::after {
  content: "";
  width: 57px;
  height: 2px;
  background-color: #19195e;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
}
.aside-list {
  margin-bottom: 15px;
}
.aside-list > li {
  margin-top: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #dcdcdc;
  text-align-last: left;
  width: 100%;
}
.aside-list > li:first-of-type {
  margin-top: 0;
}
.aside-list a {
  display: flex;
  flex-wrap: nowrap;
  color: #000;
}
.aside-list figure {
  width: 90px;
  height: 90px;
}
.aside-list .txt {
  margin-left: 10px;
  width: calc(100% - 100px);
  text-align: left;
}
.aside-list strong {
  display: block;
  font-size: 15px;
  font-weight: 500;
}
.aside-list .tag {
  display: inline-block;
  background-color: #19195e;
  color: #fff;
  font-size: 12px;
  margin-bottom: 7px;
  padding: 4px 10px 5px;
  border-radius: 4px;
}
.aside-list .date {
  display: block;
  margin-bottom: 5px;
  font-size: 12px;
  color: #666666;
}
.aside-list .tag-list {
  margin-top: 7px;
}
.aside-list .tag-list li {
  font-size: 13px;
  margin-bottom: 3px;
  margin-right: 10px;
}
.aside-list .tag-list li::before {
  width: 13px;
}
.aside-list + a.more {
  font-size: 15px;
  font-weight: 300;
}
.aside-list + a.more::after {
  width: 0.8em;
  height: 0.8em;
}
.aside-list.eye > li {
  padding-left: 10px;
  padding-bottom: 0;
}
.aside-list.eye a {
  background-color: #fff;
  padding: 15px 10px 15px 0;
  position: relative;
  min-height: 125px;
}
.aside-list.eye figure {
  position: absolute;
  top: -10px;
  left: -10px;
}
.aside-list.eye figcaption {
  position: relative;
  top: -3px;
  color: #fff;
  text-align: center;
  font-size: 14px;
  width: 100%;
  height: 35px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #12437f;
  background: -moz-linear-gradient(left, #0b699f 0%, #19195e 100%);
  background: -webkit-linear-gradient(left, #0b699f 0%, #19195e 100%);
  background: linear-gradient(to right, #0b699f 0%, #19195e 100%);
}
.aside-list.eye .txt {
  margin-left: 0;
  padding-left: 90px;
  text-align: left;
  width: 100%;
}
.aside-list.service figure {
  height: 60px;
}
.aside-list.service .txt {
  display: flex;
  align-items: center;
}
/* ------------------------------------------------------------- */
/* page                                                          */
/* ------------------------------------------------------------- */
/* ------------------------------------------------------------- */
/* archive                                                       */
/* ------------------------------------------------------------- */
/* ------------------------------------------------------------- */
/* detail                                                        */
/* ------------------------------------------------------------- */
.border-box {
  border: 1px solid #ddd;
  padding: 20px 29px;
}
.opening-read {
  content: "前書き";
  color: #333;
  font-weight: bold;
  display: inline-block;
  font-size: 1.1rem;
  position: relative;
}
.opening-read:after {
  content: "";
  position: absolute;
  top: 50%;
  right: -45px;
  width: 40px;
  height: 1px;
  background: #333;
}
@media screen and (max-width:767px) {
  .border-box {
    padding: 10px 19px;
  }
}
.detail .main .tag-list {
  margin-bottom: 20px;
}
.detail .main .block {
  padding: 0 0 50px;
}
.detail .main .block.eye-lead li, .detail .main .block.case-lead li {
  margin-right: 5px;
}
.detail .main .block.eye-lead .info-tag .detail .main .block.case-lead .info-tag {
  font-size: 12px;
}
.detail .main .block:nth-of-type(1) {
  padding-top: 0;
}
.detail .main .block.stick-out-bg {
  position: relative;
  padding: 40px 0;
}
.detail .main .block.stick-out-bg::before, .detail .main .block.stick-out-bg.stick-out-bottom::after {
  content: "";
  display: block;
  position: absolute;
}
.detail .main .block.stick-out-bg::before {
  width: 100vw;
  height: 104%;
  top: -95px;
  right: -183px;
  background-color: #fbfcff;
  z-index: -2;
}
.detail .main .block.stick-out-bg.stick-out-bottom::after {
  width: 100vw;
  height: 150px;
  bottom: 0;
  right: 140px;
  background-color: #fff;
  z-index: -1;
}
.detail .block p {
  line-height: 2;
}
.detail .block p + p {
  margin-top: 40px;
}
.detail .block img {
  display: block;
  margin: 40px auto 0;
  max-width: 100%;
}
.detail .block h2 {
  font-size: 28px;
  line-height: 1.8;
  color: #19195e;
  margin-bottom: 30px;
  font-weight: bold;
  letter-spacing: 0.03em;
}
.detail .block h3 {
  font-size: 20px;
  line-height: 1.6;
  font-weight: bold;
  margin-bottom: 30px;
}
.detail .block .col-2 {
  display: flex;
  justify-content: space-between;
  margin-bottom: 80px;
}
.detail .block .col-2:last-of-type {
  margin-bottom: 0;
}
.detail .block .col-2 p {
  width: calc(100% - 383px);
}
.detail .block .col-2 figure {
  width: 343px;
  height: auto;
}
.detail .block .lead-panel {
  margin-top: 20px;
  font-size: 18px;
  line-height: 1.9;
  padding: 30px 25px;
  color: #fff;
  background-repeat: no-repeat;
  background-size: cover;
}
.detail .block .lead-panel.parentheses {
  position: relative;
  text-align: center;
  font-size: 26px;
}
.detail .block .lead-panel.parentheses::before, .detail .block .lead-panel.parentheses::after {
  position: absolute;
  font-size: 50px;
  color: #fff;
  font-weight: 300;
}
.detail .block .lead-panel.parentheses::before {
  content: "「";
  top: 0;
  left: 30px;
}
.detail .block .lead-panel.parentheses::after {
  content: "」";
  bottom: 0;
  right: 30px;
}
.information {
  padding-top: 80px;
}
.information {
  margin-bottom: 70px;
}
.information a {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: nowrap;
}
.information .info-ttl {
  text-align: center;
  margin-bottom: 45px;
}
.information .info-tag {
  margin-right: 15px;
  width: 100px;
  text-align: center;
}
.information p {
  color: #000000;
}
@media all and (-ms-high-contrast:none) {
  .information p {
    width: calc(100% - 110px);
  }
}
.info-tag {
  display: inline-block;
  background-color: #19195e;
  color: #fff;
  font-size: 14px;
  margin-bottom: 7px;
  padding: 4px 10px 5px;
  border-radius: 4px;
}
.consul-panel {
  border: 1px solid #ddd;
  padding: 30px;
  margin-bottom: 70px;
}
.consul-panel .consul-ttl {
  text-align: center;
  margin-bottom: 40px;
  color: #19195e;
}
.consul-panel .consul-left {
  width: 165px;
}
.consul-panel .consul-left figure {
  width: 165px;
  height: 165px;
}
.consul-panel .consul-left .btn {
  width: 100%;
  margin-top: 20px;
}
.consul-panel .consul-right {
  width: calc(100% - 195px);
  display: flex;
  flex-direction: column;
}
.consul-panel .consul-right .position {
  font-size: 13px;
}
.consul-panel .consul-right .name {
  font-size: 26px;
  margin-top: 10px;
}
.consul-panel .consul-right .prof {
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: 0.05em;
  margin-top: 25px;
}
.consul-panel .consul-right .performance {
  font-size: 13px;
  font-weight: bold;
  margin-top: 25px;
}
.consul-panel .consul-right ul {
  border-top: 1px solid #e1e1e1;
  margin-top: 8px;
  padding: 8px;
}
.consul-panel .consul-right li {
  font-size: 13px;
  color: #666666;
}
.service-link-panel {
  background-repeat: no-repeat;
  background-size: cover;
  background-image: url(../img/subject/service-link-bg.jpg);
  padding: 40px 50px;
  color: #fff;
}
.service-link-panel .ttl {
  font-size: 26px;
  line-height: 1.5;
  letter-spacing: 0.1em;
  margin-bottom: 25px;
  text-align: center;
}
.service-link-panel p {
  line-height: 1.5;
  font-size: 15px;
  letter-spacing: 0.05em;
  margin-bottom: 35px;
}
.service-link-panel .btn.small {
  width: 300px;
  margin: 0 auto;
  height: 50px;
  line-height: 50px;
}
.service-link-panel .btn.small.wide {
  width: 370px;
}
.detail .main .block.case-lead {
  padding-bottom: 15px;
}
.detail .main .block.case-summary {
  padding: 0 0 50px;
}
.detail .main .block.case-summary .lead-panel {
  margin-top: 0;
}
.detail .main .block:first-of-type {
  padding-top: 0;
}
.detail .main .block.interview {
  padding-top: 0;
}
.detail .main .block p {
  position: relative;
  line-height: 2;
  color: #333;
  letter-spacing: 0.15em;
  font-size: 15px;
}
.detail .main .block.interview p {
  padding-left: 3.5em;
  position: relative;
  line-height: 2;
}
.detail .main .block.interview p.caption-box {
  padding-left: 0;
}
@media screen and (max-width:767px) {
  .detail .main .block p {
    font-size: 13px;
  }
}
.detail .main .block.interview .name {
  position: absolute;
  left: 0;
  font-weight: bold;
  color: #19195e;
}
.detail .main .block.interview img {
  margin: 1em;
  margin-top: 0;
  width: 343px;
}
.detail .main .block img {
  margin: 1em;
  margin-top: 0;
  width: 343px;
}
.detail .main .block img.dl_img {
  margin: 0;
  margin-top: 0;
  width: 100%;
}
.detail .main .block.interview .img-left .name {
  left: calc(343px + 1em);
}
.detail .main .block .img-left img {
  margin-right: 2em;
}
.detail .main .block .img-right img {
  margin-left: 2em;
  margin-right: 0;
}
.detail .main .block.interview .img-left img {
  position: relative;
  left: -4.5em;
  margin-right: 0;
}
.detail .main .block .img-center span.caption-container {
  float: left;
  max-width: 48%;
  min-width: 300px;
  margin-right: 2em;
}
.detail .main .block .img-left span.caption-container {
  float: left;
  display: block;
  max-width: 343px;
  min-width: 300px;
  margin-right: 2em;
}
.detail .main .block .img-right span.caption-container {
  float: right;
  display: block;
  max-width: 343px;
  min-width: 300px;
  margin-left: 2em;
}
.detail .main .block span.caption-container img {
  float: none;
  margin: 0 auto;
  width: auto;
}
.detail .main .block .caption-container.flex {
  margin-bottom: 30px;
}
.detail .main .block .caption-container.flex .caption-container__item {
  display: block;
  width: 48%;
}
.detail .main .block .caption-container.flex .caption-container__item span {
  display: block;
  text-align: center;
  margin: 0 auto;
  line-height: 1.7;
  color: #777;
  letter-spacing: 0.05em;
  font-size: 14px;
  margin-top: 10px;
}
.detail .main .block span.caption-container .caption-text {
  font-size: 14px;
  color: #666;
  letter-spacing: 0.05em;
  display: block;
  width: 89%;
  text-align: center;
  margin: 10px auto 0;
  line-height: 1.7;
}
.detail .main .block span.caption-container .caption-text__large {
  font-size: 14px;
  line-height: 1.8;
  display: block;
  letter-spacing: 0.1em;
  background: #f7f7f7;
  padding: 21px;
  margin-top: 12px;
  color: #444 !important;
  text-align: left !important;
}
.detail .main .block .caption-container.flex span img {
  display: block;
  margin: 0 auto;
}
.special-head {
  font-size: 28px;
}
.img-left img {
  float: left;
}
.img-right img {
  float: right;
}
.detail .main div.profile {
  border: 1px solid #19195e;
  padding: 30px 45px;
}
@media screen and (max-width:767px) {
  .detail .main .block .img-right img, .detail .main .block .img-left img {
    margin: 0 auto;
    width: 100%;
  }
}
.detail .main .profile-ttl {
  text-align: center;
  margin-bottom: 40px;
  color: #19195e;
}
.detail .main div.profile dt, .detail .main div.profile dd {
  line-height: 2;
  margin-bottom: 10px;
}
.detail .main div.profile dt {
  width: 80px;
  margin-right: 10px;
  font-weight: bold;
}
.detail .main div.profile dd {
  width: calc(100% - 90px);
}
.detail .main div.profile a {
  color: #00aad4;
  text-decoration: underline;
}
.detail .main div.profile a:hover {
  text-decoration: none;
}
.grid {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-between;
}
.cell.is-empty {
  height: 0;
  padding-top: 0;
  padding-bottom: 0;
  margin-top: 0;
  margin-bottom: 0;
}
.all, .system .system, .academy .academy, .juniorboard .juniorboard, .recruitment .recruitment, .other .other {
  background: #19195e;
  background: -moz-linear-gradient(left, #0c629a 0%, #19195e 100%);
  background: -webkit-linear-gradient(left, #0c629a 0%, #19195e 100%);
  background: linear-gradient(to right, #0c629a 0%, #19195e 100%);
}
.system .all, .academy .all, .juniorboard .all, .recruitment .all, .other .all {
  background: #e7eaef;
}
.regexp-list li.all a, .system .system a, .academy .academy a, .juniorboard .juniorboard a, .recruitment .recruitment a, .other .other a {
  color: #fff;
}
.regexp-list.system .all a, .regexp-list.academy .all a, .regexp-list.juniorboard .all a, .regexp-list.recruitment .all a, .regexp-list.other .all a {
  color: #19195e;
}
@media all and (-ms-high-contrast:none) {}
@media (min-width: 1400px) {
  header .header-nav a {
    margin-right: 35px;
  }
}
@media (min-width: 769px) {
  /* ------------------------------------------------------------- */
  /* layout / parts                                                */
  /* ------------------------------------------------------------- */
  body {
    min-width: 1170px;
  }
  .inner {
    width: 1170px;
  }
  .main {
    width: 755px;
  }
  .contents {
    padding-top: 40px;
    padding-bottom: 80px;
  }
  aside {
    width: 350px;
    box-shadow: 4px 4px 18px #ddd;
  }
  section {
    padding: 80px 0;
  }
  /* ------------------------------------------------------------- */
  /* header                                                        */
  /* ------------------------------------------------------------- */
  header, .header-left a, .header-right ul {
    height: 80px;
  }
  header {
    min-width: 1280px;
    padding: 0 30px;
  }
  header .header-left a {
    justify-content: center;
  }
  #js-clone-nav {
    position: absolute;
    width: 100%;
    z-index: 10;
  }
  #js-clone-nav.clone-nav {
    position: fixed;
    top: -100px;
    left: 0;
    transition: all 1s;
    background-color: #fff;
    box-shadow: 0 2px 2px rgba(0, 0, 0, .2);
  }
  #js-clone-nav.clone-nav.is-fixed-nav {
    top: 0;
  }
}
@media (max-width: 768px) {
  /* ------------------------------------------------------------- */
  /* layout / parts                                                */
  /* ------------------------------------------------------------- */
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
  body {
    min-width: auto;
    font-size: 14px;
  }
  .inner {
    width: 90%;
  }
  .main {
    width: 100%;
  }
  .contents {
    padding-top: 20px;
    padding-bottom: 40px;
  }
  aside {
    width: 100%;
    padding: 0 5vw;
  }
  section {
    padding: 40px 0;
    overflow: hidden;
  }
  /*-----------------header--------------------*/
  #js-clone-nav {
    display: none;
  }
  /*-----------------Link--------------------*/
  .btn {
    height: 60px;
    line-height: 60px;
    width: 80%;
  }
  /*-----------------scroll --------------------*/
  .custom-scroll::-webkit-scrollbar {
    height: 3px;
  }
  .custom-scroll::-webkit-scrollbar-track {
    background-color: #CCCCCC;
    height: 3px;
  }
  .custom-scroll::-webkit-scrollbar-thumb {
    background-color: #182063;
  }
  /*-----------------heading--------------------*/
  .h-under-txt span {
    font-size: 28px;
  }
  .h-overlay::after {
    bottom: -10px;
  }
  .h-overlay small {
    font-size: 40px;
  }
  .h-overlay span {
    font-size: 22px;
    transform: translate(-50%, -45%);
  }
  .h-underline {
    font-size: 22px;
  }
  .h-underline::after {
    bottom: -15px;
  }
  /*-----------------list--------------------*/
  .link-arrow {
    background-position: 280px center;
  }
  li.recommend::after, li.new::after {
    top: 0;
    right: 0;
    width: 45px;
    height: 45px;
  }
  .grad-list li {
    width: 100%;
  }
  .grad-list li::after {
    content: none;
  }
  .case-list-wrap {
    padding-bottom: 40px;
  }
  .case-list-wrap::before {
    height: 200%;
  }
  .case-list li {
    width: 49%;
    margin-bottom: 20px;
  }
  .case-list-wrap .btn {
    margin-top: 30px;
  }
  .case-list .tags {
    bottom: 26px;
  }
  .case-list .txt strong {
    font-size: 2.3vw;
  }
  .stick-out-list .txt {
    min-height: auto;
    padding: 20px;
    padding-left: 118px;
  }
  .hint-wrap .stick-out-list .txt {
    min-height: auto;
    padding: 20px;
    padding-left: 20px;
  }
  .stick-out-list p {
    padding-left: 0;
    font-size: 14px;
  }
  .stick-out-list .new strong {
    font-size: 20px;
  }
  .stick-out-list .new p {
    font-size: 14px;
  }
  .stick-out-list .new .btn {
    margin: 30px auto 0;
    width: 80%;
  }
  .hint-wrap .stick-out-list figure {
    position: static;
    width: 100%;
    height: auto;
  }
  .hint-wrap .stick-out-list strong {
    font-size: 15px;
  }
  .hint-wrap .stick-out-list p {
    padding-left: 0;
  }
  .eye-wrap .stick-out-list .txt {
    padding: 5vw 5vw 5vw 79px;
  }
  .stick-out-list .new .txt::after {
    width: 45px;
    height: 45px;
  }
  .eye-wrap .stick-out-list figure {
    width: 80px;
    height: auto;
  }
  .eye-wrap .stick-out-list figcaption {
    font-size: 3vw;
    padding: 5px;
  }
  .eye-wrap .stick-out-list strong {
    font-size: 15px;
  }
  .tag-list li {
    font-size: 12px;
  }
  .consul-list li {
    width: 48%;
  }
  .consul-list figure {
    height: auto;
  }
  .consul-list .txt {
    margin-bottom: 20px;
  }
  .consul-list span {
    font-size: 12px;
  }
  .consul-list strong {
    font-size: 16px;
  }
  .seminar-list a::after {
    content: none;
  }
  .seminar-list .seminar-item {
    padding: 15px 5vw;
    flex-wrap: wrap;
  }
  .seminar-list .seminar-item .date {
    margin-right: 0;
    order: 1;
  }
  .seminar-list .seminar-item figure {
    width: calc(100% - 130px);
    margin-right: 20px;
    order: 0;
  }
  .seminar-list .seminar-item .txt {
    width: 100%;
    order: 2;
  }
  .seminar-list .seminar-item strong {
    padding-left: 0;
    padding-top: 35px;
    background-position: left top;
    line-height: 1.5;
    font-size: 22px;
    margin-bottom: 10px;
  }
  .document-list li {
    width: 48%;
    margin-bottom: 20px;
  }
  .document-list figure {
    height: 30vw;
  }
  .document-list p {
    margin-top: 10px;
  }
  .regexp-list li {
    width: 49%;
    margin-bottom: 10px;
  }
  /* ------------------------------------------------------------- */
  /* header                                                        */
  /* ------------------------------------------------------------- */
  header, .header-left a {
    height: 50px;
    width: 234px;
  }
  header {
    padding: 0 5%;
  }
  header .header-right {
    display: none;
  }
  header .hd-ttl {
    font-size: 10px;
  }
  header .hd-logo {
    height: auto;
    margin-top: 2px;
    width: 220px;
  }
  header .hd-btn {
    height: 70px;
    border-radius: 35px;
  }
  header .flex {
    display: block;
  }
  /* ----- SP Menu ----- */
  .btn-menu {
    width: 50px;
    height: 50px;
    position: fixed;
    right: 0;
    top: 0;
    transition: .3s;
    z-index: 11;
    background-color: #19195e;
  }
  .menu-trigger, .menu-trigger span {
    display: inline-block;
    transition: all .4s;
  }
  .menu-trigger span {
    position: absolute;
    left: 23%;
    width: 55%;
    height: 3px;
    background-color: #fff;
    ;
  }
  .menu-trigger span:nth-of-type(1) {
    top: 13px;
  }
  .menu-trigger span:nth-of-type(2) {
    top: 23px;
  }
  .menu-trigger span:nth-of-type(3) {
    bottom: 13px;
  }
  .menu-trigger.active span:nth-of-type(1) {
    transform: translateY(11px) rotate(-315deg);
  }
  .menu-trigger.active span:nth-of-type(2) {
    opacity: 0;
  }
  .menu-trigger.active span:nth-of-type(3) {
    transform: translateY(-9px) rotate(315deg);
  }
  .sp-nav-wrap nav {
    transition: all .3s ease;
    transform: translateX(100%);
  }
  .sp-nav-wrap nav.active {
    transform: translateX(0);
  }
  .sp-nav-wrap nav {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10;
    width: 100vw;
    height: 100vh;
    padding: 50px 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  .sp-nav-wrap .sp-nav {
    width: 100%;
    margin: 0 auto;
  }
  .sp-nav-wrap nav a {
    display: block;
    color: #fff;
    width: 80%;
    margin-left: auto;
    margin-right: auto;
    font-size: 18px;
    padding: 20px 0;
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
    position: relative;
  }
  .sp-nav-wrap nav a:after {
    content: "";
    display: block;
    width: 29px;
    height: 100%;
    position: absolute;
    top: 0;
    right: 0;
    background-repeat: no-repeat;
    background-image: url(../img/icon-sp-nav.png);
    background-position: center;
    background-size: contain;
  }
  .sp-nav-wrap nav .hd-btn {
    margin-top: 40px;
    margin-bottom: 0;
    background-image: none;
    line-height: 1;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  .sp-nav-wrap nav .hd-btn::before {
    content: "";
    display: inline-block;
    width: 38px;
    height: 26px;
    position: static;
    margin-right: 20px;
    background-image: url(../img/icon-w-mail.png);
    background-repeat: no-repeat;
    background-size: contain;
  }
  .sp-nav-wrap nav .hd-btn::after {
    content: none;
  }
  /* ------------------------------------------------------------- */
  /* mv                                                            */
  /* ------------------------------------------------------------- */
  .list .mv-wrap {
    height: 50vw;
  }
  .page .mv-front span {
    font-size: 14px;
    text-shadow: 0px 0px 3px #ffffff;
  }
  .page .mv-front strong {
    font-size: 8vw;
    text-shadow: 0px 0px 3px #ffffff;
  }
  .page .mv-front h1 + p {
    margin-bottom: 20px;
    font-size: 13px;
    text-shadow: 0px 0px 3px #ffffff;
  }
  .page .mv-front h1 + p.sub-ttl {
    font-size: 22px;
  }
  .detail .mv-front .category {
    margin-bottom: 5px;
  }
  .list .mv-front strong, .detail .mv-front strong {
    font-size: 22px;
  }
  /*-----------------subnav--------------------*/
  .sub-nav {
    overflow: hidden;
  }
  .sub-nav li {
    height: 40px;
    line-height: 40px;
  }
  /*-----------------breadcrumb--------------------*/
  .breadcrumb li {
    font-size: 10px;
    margin-bottom: 5px;
  }
  /* ------------------------------------------------------------- */
  /* footer                                                        */
  /* ------------------------------------------------------------- */
  .footer-about {
    padding-top: 40px;
  }
  .footer-about .cv {
    margin-top: 60px;
  }
  .footer-about .parenthesis {
    width: 80%;
    font-size: 22px;
  }
  .footer-about .cv a {
    width: 100%;
  }
  .footer-about .cv small {
    font-size: 12px;
  }
  .footer-about .cv strong {
    font-size: 24px;
  }
  .footer {
    padding: 25px 5vw 25px;
  }
  .footer .footer-left {
    width: 100%;
  }
  .footer .footer-left a {
    width: 100%;
    text-align: center;
    display: block;
  }
  .footer .footer-right {
    margin-top: 20px;
    width: 100%;
  }
  .footer .footer-right li {
    padding: 3px 12px;
  }
  .footer .footer-link {
    justify-content: center;
  }
  .footer .footer-right a {
    font-size: 12px;
  }
  /* ------------------------------------------------------------- */
  /* detail                                                        */
  /* ------------------------------------------------------------- */
  .btn.grad {
    display: block;
    margin: 0 auto;
  }
  .detail .main .tag-list {
    margin-bottom: 1px;
  }
  .detail .main .block {
    padding: 30px 0;
  }
  .detail .main .block.stick-out-bg::before {
    right: 20vw;
  }
  .detail .main .block.stick-out-bg::after {
    right: 20vw;
    height: 10vw;
  }
  .detail .block p + p {
    margin-top: 20px;
  }
  .detail .block img {
    margin-top: 20px;
  }
  .detail .block img:last-child {
    margin-bottom: 20px;
  }
  .detail .block h2 {
    font-size: 20px;
    line-height: 1.8;
  }
  .detail .block h3 {
    font-size: 16px;
  }
  .detail .block .col-2 {
    flex-direction: column;
    margin-bottom: 40px;
  }
  .detail .block .col-2 p {
    width: 100%;
  }
  .detail .block .col-2 figure {
    width: 100%;
  }
  .detail .block .lead-panel.parentheses {
    position: relative;
    text-align: center;
    font-size: 20px;
  }
  .detail .block .lead-panel.parentheses::before, .detail .block .lead-panel.parentheses::after {
    font-size: 30px;
  }
  .detail .block .lead-panel.parentheses::before {
    content: "「";
    left: -10px;
  }
  .detail .block .lead-panel.parentheses::after {
    right: -10px;
  }
  .information {
    padding-top: 40px;
  }
  .information {
    margin-bottom: 40px;
  }
  .information .info-ttl {
    margin-bottom: 45px;
  }
  .information li {
    margin-bottom: 10px;
  }
  .information .info-tag {
    margin-right: 10px;
    width: 100px;
    font-size: 12px;
  }
  .information p {
    width: calc(100% - 110px);
  }
  .consul-panel {
    padding: 5vw;
    margin-bottom: 40px;
  }
  .consul-panel .consul-ttl .h-underline.small {
    font-size: 16px;
  }
  .h-underline::after {
    bottom: 0;
  }
  .consul-panel .consul-left {
    width: 100%;
    order: 2;
  }
  .consul-panel .consul-left figure {
    margin: 0 auto;
    height: auto;
  }
  .consul-panel .consul-right {
    order: 1;
    width: 100%;
    margin-bottom: 20px;
  }
  .consul-panel .consul-right .prof {
    margin-top: 15px;
    font-size: 14px;
  }
  .service-link-panel {
    padding: 15px;
    margin-bottom: 40px;
  }
  .service-link-panel .ttl {
    font-size: 20px;
  }
  .service-link-panel .btn.small, .service-link-panel .btn.small.wide {
    width: 100%;
  }
  .service-link-panel .btn.small.wide {
    letter-spacing: -1px;
  }
  .detail .main .block.interview img {
    width: 100%;
    margin: 0 auto;
    margin-bottom: 20px;
  }
  .detail .main .block.interview .img-left .name {
    left: 0;
  }
  .detail .main .block.interview .img-left img {
    position: static;
  }
  .img-left img {
    float: none;
  }
  .img-right img {
    float: none;
  }
  .detail .main div.profile {
    padding: 20px 5vw;
  }
}
@media screen and (max-width:400px) {
  .case-list li {
    width: 100%;
    margin-bottom: 20px;
  }
  .link-arrow {
    background-position: 72vw center;
  }
  .case-list .tags {
    bottom: 18px;
  }
  .case-list .txt strong {
    font-size: 16px;
  }
}
.mktoFormRow {
  margin-bottom: 25px !important;
  padding-bottom: 15px !important;
  border-bottom: 1px dotted #aaa;
}
.mktoFormRow:nth-of-type(2) {
  border-bottom: none;
  margin-bottom: 0 !important;
}
.mktoFormRow:nth-of-type(1), .mktoFormRow:nth-of-type(5) {
  margin-top: 60px !important;
}
.mktoFormRow:nth-last-of-type(2) {
  border-bottom: none;
}
.mktoFormRow .mktoHtmlText h3 {
  font-size: 20px;
  font-weight: bold;
}
aside .mktoFormRow {
  margin-bottom: 20px !important;
  padding-bottom: 0 !important;
  border-bottom: none;
}
aside .mktoFormRow:nth-of-type(odd) {
  margin-bottom: 0 !important;
}
aside .mktoFormRow:nth-of-type(1), aside .mktoFormRow:nth-of-type(5) {
  margin-top: 0 !important;
}
aside .mktoFormRow:nth-of-type(2) {
  margin-bottom: 20px !important;
}
.mktoButtonRow {
  width: 100%;
}
.mktoButtonRow .mktoButton {
  font-size: 16px;
  font-weight: 500;
  height: 70px;
  line-height: 40px;
  background-color: #19195e;
  color: #ffffff;
  display: block;
  border-radius: 35px;
  line-height: 70px;
  background-image: url(../img/icon-w-arrow.png);
  background-repeat: no-repeat;
  background-size: 10px 17px;
  background-position: right 20px center;
  transition: all .3s ease;
  text-align: center;
  margin: 40px auto 0 !important;
  width: 370px;
}
aside .mktoButtonRow .mktoButton {
  font-size: 14px;
  width: 200px;
  height: 40px;
  line-height: 40px;
  background-position: right 10px center;
}
.mktoForm .mktoRadioList > label, .mktoForm .mktoCheckboxList > label {
  margin-left: 0 !important;
  padding-left: 25px !important;
}
@media (max-width: 768px) {
  .mktoButtonRow .mktoButton {
    width: 100%;
    line-height: 50px;
  }
  aside .mktoButtonRow .mktoButton {
    line-height: 20px;
  }
}
.thanks_msg {
  margin-top: 40px;
}
.thanks_msg p {
  text-align: center;
  line-height: 1.8;
}
.thanks_msg a {
  margin: 40px auto 0;
}
.pdf-box {
  background-image: url(../img/download/mv-download.jpg);
  padding: 20px 30px;
  position: relative;
}
.pdf-box__ttl {
  width: 388px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.pdf-box__ttl p {
  font-size: 29px;
  line-height: 1.7;
  margin-bottom: 20px;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.05em;
}
.pdf-box__ttl p.no-span {
  line-height: 1.4;
  margin-top: 20px;
}
.pdf-box__ttl span {
  display: block;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: #fff;
}
.pdf-box__tag {
  background: #19195e;
  position: absolute;
  left: 0;
  top: 0;
  padding: 5px 20px;
  text-align: center;
  color: #fff;
  display: block;
}
.pdf-box__img {
  width: 300px;
}
.pdf-box_type2 {
  padding: 40px 30px;
}
.pdf-box_type2 .pdf-box__ttl {
  width: 100%;
  display: block;
  text-align: center;
}
.pdf-box_type2 .pdf-box__ttl p {
  line-height: 1.5;
  font-size: 33px;
}
.pdf-box_type2 .pdf-box__ttl span {
  font-size: 21px;
}
.pdf-box_type2 .pdf-box__tag {
  font-size: 20px;
  padding: 11px 20px;
}
.pdf-box_type2 .pdf-box__text {
  background: rgba(0, 90, 139, 0.7);
  padding: 20px 25px;
  color: #fff;
  line-height: 1.4;
  letter-spacing: 0.05em;
  margin-bottom: 20px;
}
.pdf-box_type2 .pdf-box__img {
  width: 100%;
  text-align: center;
}
.pdf-box_type2 .pdf-box__info {
  background: rgba(255, 255, 255, 0.8);
  padding: 20px 25px;
  margin-bottom: 35px;
  letter-spacing: 0.05em;
}
.pdf-box_type2 .pdf-box__info strong {
  font-weight: bold;
  font-size: 17px;
  margin-bottom: 6px;
  display: block;
}
.pdf-box_type2 .pdf-box__info ul li {
  line-height: 1.4;
  letter-spacing: 0.05em;
}
.pdf-box_type2 .btn {
  margin: 0 auto;
}
.pdf-box_type1.service {
  width: 755px;
  margin: 90px auto 0;
  background: #fff;
  border: 2px solid #19195e;
  overflow: hidden;
}
.pdf-box_type1.service .wrap-link {
  display: flex;
}
.pdf-box_type1.service .wrap-link:hover {
  opacity: 0.8;
}
.service-consul .pdf-box_type1.service .btn {
  margin: 24px 0 0 0;
  width: 100%;
}
.pdf-box_type1.service .pdf-box__ttl {
  position: relative;
  z-index: 1;
}
.pdf-box_type1.service .pdf-box__ttl p {
  margin-top: 26px;
  line-height: 1.4;
  margin-bottom: 0;
  color: #333;
}
.pdf-box_type1.service .pdf-box__ttl p span {
  display: block;
  margin-top: 20px;
  color: #333;
  text-shadow: 0 0 4px #fff, 0 0 3px #fff;
}
.pdf-box_type1.service .pdf-box__ttl span.btn:hover {
  opacity: 1;
}
.pdf-box_type1.service .pdf-box__img {
  position: relative;
}
.pdf-box_type1.service .pdf-box__img img {
  width: 164% !important;
  position: absolute;
  right: -140px;
  transform: rotate(-7deg);
  top: -20px;
}
.download-document .btn {
  margin: 50px auto 0;
}
.download-document h2 {
  margin-bottom: 75px;
}
.download-document .document-list li {
  width: auto;
}
.download-document .slick-initialized .slick-slide {
  padding: 0 8px;
}
.download-document .slick-dots li button:before {
  margin-top: 10px;
  height: 10px;
  content: "";
  background: #222;
}
@media screen and (max-width:767px) {
  .pdf-box {
    padding: 15px 21px;
  }
  .pdf-box__tag {
    padding: 5px 13px;
  }
  .pdf-box__ttl p {
    font-size: 20px;
  }
  .pdf-box__ttl span {
    font-size: 13px;
  }
  .pdf-box__ttl .btn {
    width: 100%;
  }
  .pdf-box__img {
    width: 100%;
    margin-top: 20px;
  }
  .pdf-box__img img {
    width: 100%;
  }
  .pdf-box_type2 {
    padding: 40px 12px;
  }
  .pdf-box_type2 .pdf-box__tag {
    padding: 7px 11px;
  }
  .pdf-box_type2 .pdf-box__ttl p {
    font-size: 21px;
  }
  .pdf-box_type2 .pdf-box__ttl span {
    font-size: 13px;
  }
  .pdf-box_type2 .pdf-box__text {
    padding: 14px 18px;
    font-size: 13px;
    line-height: 1.6;
  }
  .pdf-box_type2 .pdf-box__info {
    padding: 15px 18px;
  }
  .pdf-box_type2 .pdf-box__info strong {
    font-size: 15px;
  }
  .pdf-box_type2 .pdf-box__info ul li {
    line-height: 1.6;
    font-size: 13px;
  }
  .pdf-box_type2 .pdf-box__img {
    margin-bottom: 12px;
  }
  .pdf-box_type1.service {
    width: 100%;
  }
  .pdf-box_type1.service .pdf-box__img img {
    position: static;
    transform: none;
    width: 100% !important;
  }
  .pdf-box_type1.service .wrap-link {
    display: block;
  }
  .pdf-box_type1.service .pdf-box__ttl {
    width: 100%;
  }
}
.aside-bnr, .aside-bnr img {
  width: 100%;
}
.aside-bnr {
  display: block;
  padding-top: 25px;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
.aside-bnr:hover {
  opacity: 0.7;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}
.pdf-box__ttl--text {
  font-size: 29px !important;
  line-height: 1.7 !important;
  margin-bottom: 20px;
  font-weight: bold;
  color: #fff !important;
  letter-spacing: 0.05em !important;
  padding-left: 0 !important;
}
.mt-50 {
  margin-top: 50px;
}
@media screen and (max-width:767px) {
  .pdf-box__ttl--text {
    font-size: 20px !important;
  }
}
.faq_content {
  margin-top: 90px;
}
.faq_content dl {
  border-bottom: 1px solid #CCC;
  margin-top: 0;
}
.faq_content dl + dl {}
.faq_content dl:first-child dt {
  border-top: 1px solid #CCC;
}
.faq_content dt {
  font-size: 18px;
  font-weight: bold;
  padding: 25px 15px 25px 80px;
  background: url("../img/faq_q.png") no-repeat 10px center;
  text-align: left;
  width: 100%;
  position: static;
  color: #333;
  border: none;
  cursor: pointer;
  font-weight: 500;
}
.faq_content dt:first-of-type {
  border-top: none;
}
.faq_content dd {
  padding: 25px 15px 25px 80px;
  font-size: 18px;
  background: url("../img/faq_a.png") no-repeat 20px 20px;
  text-align: left;
  width: 100%;
  display: block;
  border-top: 2px dotted #ccc !important;
  border-right: none;
  border-left: none;
  border-bottom: none;
}
.faq_content dd small {
  display: block;
  font-size: 15px;
}
@media screen and (max-width:767px) {
  .faq_content {
    margin-bottom: 15px;
    margin-top: 55px;
  }
  .faq_content dt {
    font-size: 16px;
  }
}
/*----------211004*/
.pdf-box.link_box_1004 {
  max-width: 755px;
	margin: 0 auto 80px;
  align-items: center;
  background-image: url("../img/link_box_1004_bg.jpg");
  padding: 10px 30px;
  justify-content: flex-start;
}
@media screen and (max-width: 767px) {
  .pdf-box.link_box_1004 {
    padding: 15px 21px;
  }
}
.pdf-box.link_box_1004 .pdf-box__img {
  width: 160px;
}
.pdf-box.link_box_1004 img {
  max-width: 100%;
  height: auto;
  display: block;
}
.detail .main .pdf-box.link_box_1004 img {
  margin: 0;
}
.pdf-box.link_box_1004 .pdf-box__ttl {
  width: inherit;
  margin-right: 10px;
}
.pdf-box.link_box_1004 .btn {
  height: 40px;
  line-height: 40px;
  position: absolute;
  right: 20px;
  width: 150px;
  bottom: 20px;
  background-position: right 13px center;
  background-size: 7px 13px;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 90, 139, 0.7);
}
.link_box_1004 .pdf-box__ttl p {
  font-size: 29px;
  line-height: 1.4;
  margin-bottom: 10px;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.05em;
}
.detail .main .block .link_box_1004 .pdf-box__ttl p {
  font-size: 29px;
  line-height: 1.4;
  margin-bottom: 10px;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.05em;
	padding-left:0;
}
@media screen and (max-width: 767px) {
  .detail .main .block .link_box_1004 .pdf-box__ttl p {
    font-size: 20px;
  }
}
.mt-50_imp {
	margin-top:50px !important;
}
.mb-0_imp {
	margin-bottom:0 !important;
}