@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@500;600;700&family=Montserrat:wght@500;600;700&display=swap');

/* 基本情報 */
html,
body {
  height: 100%;
}
html {
  font-size: 62.5%;
  overflow-y: scroll;
}
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
address,
ul,
ol,
li,
dl,
dt,
dd,
table,
th,
td,
img,
figure,
form {
  font-style: normal;
  font-weight: normal;
  font-family:  "Noto Sans JP","游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  color: #262626;
  line-height: 100%;
  text-align: left;
  margin: 0;
  padding: 0;
  border: none;
  list-style-type: none;
}
input,
button,
textarea,
select {
  margin: 0;
  padding: 0;
  border: none;
  border-radius: 0;
  background: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  font-family: "Noto Sans JP","游ゴシック","游ゴシック", YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
  color: #262626;
}
textarea {
  resize: vertical;
}
select::-ms-expand {
  display: none;
}
::placeholder {
  color: #B5B4B4;
}

/*.ie11対策*/
input:-ms-input-placeholder {
  color: #B5B4B4;
}
select:invalid {
  color: #B5B4B4;
}

/*.ie11対策*/
[type="checkbox"],
/*
[type="radio"] {
  visibility: hidden;
  width: 1px;
  position: absolute;
}
*/
a {
  text-decoration: none;
  color: inherit;
  outline: none;
  transition: .3s;
}
img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
}
*,
*::after,
*::before {
  box-sizing: border-box;
}
.preload * {
  -webkit-transition: none !important;
  -moz-transition: none !important;
  -ms-transition: none !important;
  -o-transition: none !important;
  transition: none !important;
}

/* --------------------------------------------------------------------------------

responsive

-------------------------------------------------------------------------------- */
.tab {
  display: none !important;
}
.tab_sp {
  display: none !important;
}
@media screen and (min-width: 768px) and (max-width: 1000px) {
  .tab {
    display: block !important;
  }
}
@media screen and (min-width: 768px) {
  a:hover {
    opacity: .7;
  }
  .sp {
    display: none !important;
  }
}
@media screen and (max-width: 1000px) {
  .tab_sp {
    display: block !important;
  }
}
@media screen and (max-width: 767px) {
  a:active {
    opacity: .7;
  }
  .pc {
    display: none !important;
  }
}

/* --------------------------------------------------------------------------------

base

-------------------------------------------------------------------------------- */
p,
dt,
dd,
li,
th,
td,
input,
button,
textarea,
select {
  font-size: 1.6rem;
  line-height: 1;
}
body.fixed {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.wrap {
  margin: 0 auto;
  width: 100%;
  max-width: 1200px;
}
.aligncenter{
  display: block;
  margin: 0 auto;
}
.alignright{
  float: right;
}
.alignleft{
  float: left;
}
.ff_yu {
  font-family: YuGothic, 'Yu Gothic';
}
.ff_ms {
  font-family: 'Montserrat', sans-serif;
}
.ff_bc {
 font-family: "Inter", sans-serif;
}
.tac {
  text-align: center;
}
.tar {
  text-align: right;
}
.label_wrap {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
}
.label_wrap time.date_label {
  margin-left: auto;
}
.grad_label {
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 1.2rem;
  letter-spacing: .06em;
  text-indent: .06em;
  line-height: 1.25;
  color: #fff;
  text-align: center;
  display: inline-block;
  padding: 8.5px;
  min-width: 95px;
  background: linear-gradient(to right, #e07a31 0%, #dd2976 48.28%, #9e57db 100%);
}
.mint_green_label {
   font-family: "Inter", sans-serif;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.1875;
  letter-spacing: .1em;
  text-indent: .1em;
  color: #fff;
  text-align: center;
  display: inline-block;
  padding: 7px;
  min-width: 95px;
  background:#21AEDD;
}
.category_label {
  font-weight: 700;
  font-size: 1.2rem;
  line-height: 1.67;
  text-align: center;
  padding: 5px 13px;
  border: 1px solid #181818;
  background: #fff;
  position: relative;
  z-index: 4;
}
.ie11 .category_label {
  padding: 7px 13px 3px;
}
.grad_label + .category_label {
  margin-left: 7px;
}
.date_label {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 1.2rem;
  line-height: 1.25;
  color: #BFBEBE;
  position: relative;
  display: flex;
  align-items: center;
}
.date_label::before {
  content: "";
  display: block;
  margin-right: 7px;
  width: 15px;
  height: 15px;
  background: url(../../img/new/common/ico_clock.svg) center / cover no-repeat;
}
.member_label {
  display: inline-flex;
  align-items: center;
}
.member_link {
  display: inline-flex;
  align-items: center;
}
.member_img {
  margin-right: 15px;
  max-width: 40px;
}
.member_img img {
  width: 100%;
}
.member_name {
  font-weight: bold;
  font-size: 1.2rem;
  line-height: 1.67;
}
.page_top_btn {
  text-align: right;
}
.page_top_link {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  text-decoration: none;
  color: #1A2453;
  font-size: 18px;
   font-family: "Inter", sans-serif;
  font-weight: 600;
}

.page_top_link .icon {
  width: 30px;
  height: 30px;
  border: 2px solid #1A2453;
  border-radius: 50%;
  position: relative;
  margin-bottom: 12px;
}

.page_top_link .icon::before {
  content: '';
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 10px;
  height: 10px;
  border-left: 2px solid #1A2453;
  border-top: 2px solid #1A2453;
}
.page_top_link .icon::after {
  content: '';
  position: absolute;
  top: 7px;
  left: 12px;
  width: 2px;
  height: 12px;
  background-color: #1A2453;
}

.scroll_wrap {
  text-align: center;
  position: fixed;
  top: 0;
  bottom: 0;
  left: 3vw;
  z-index: 5;
  margin: auto;
  padding-top: 50px;
  width: 15px;
  height: 130px;
}
.scroll_txt {
  position: relative;
  display: inline-block;
  font-size: 1.3rem;
  font-weight: 500;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}
.scroll_bar {
  width: 12px;
  height: 40px;
  overflow: hidden;
  margin: 10px auto 0;
}
.scroll_bar_in {
  width: 1px;
  height: 100%;
  background-color: #333333;
  margin: 0 auto;
  position: relative;
}
.scroll_bar_in:before {
  content: "";
  border-radius: 50%;
  display: block;
  width: 10px;
  height: 10px;
  background: #21AEDD;
  position: absolute;
  top: 0%;
  left: -5px;
  z-index: 2;
}
.scroll_bar_in.is_animate::before {
  -webkit-animation-name: ScrollBar;
  animation-name: ScrollBar;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  -webkit-animation-timing-function: cubic-bezier(.645, .045, .355, 1);
  animation-timing-function: cubic-bezier(.645, .045, .355, 1);
  -webkit-animation-duration: 1.25s;
  animation-duration: 1.25s;
}

@-webkit-keyframes ScrollBar {
  0% {
    top: 0%;
  }
  100% {
    top: 100%;
  }
}
@keyframes ScrollBar {
  0% {
    top: 0%;
  }
  100% {
    top: 100%;
  }
}
.fixed_sns {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: fixed;
  top: 50%;
  right: 3vw;
  z-index: 5;
  transform: translateY(-50%);
}
.fixed_sns_txt {
  font-weight: 600;
  font-size: 1.4rem;
  letter-spacing: .06em;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  margin-bottom: 14px;
}
/*.fixed_sns_img:last-of-type {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.fixed_sns_img:last-of-type::before {
  content: "";
  display: block;
  width: 20px;
  height: 1px;
  background: #262626;
  margin: 26px 0 28px;
}*/
.fixed_sns_img + .fixed_sns_img {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.fixed_sns_img + .fixed_sns_img::before {
  content: "";
  display: block;
  width: 20px;
  height: 1px;
  background: #262626;
  margin: 18px 0 20px;
}
.fixed_sns_img.x img {
  width: 19px;
}
.fixed_sns_link {
  display: block;
  position: relative;
}
.fixed_sns_link .off {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  transition: .3s;
}
.fixed_btn_contact {
  position: fixed;
  bottom: 0;
  right: 0;
  z-index: 5;
}
.fixed_btn_contact_link {
  display: flex;
  align-items: center;
  padding: 21px 43px 20px 36px;
  border: 4px solid #28B52D;
  border-right: none;
  border-radius: 37px 0 0 0;
  background: rgba(255, 255, 255, .95);
}
.fixed_btn_contact_img {
  position: relative;
  width: 24px;
}
.fixed_btn_contact_img img {
  width: 100%;
}
.fixed_btn_contact_img .off {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  transition: .3s;
}
.fixed_btn_contact_txt {
  font-weight: 700;
  font-size: 1.6rem;
  color: #00BA00;
  margin-left: 13px;
  transition: .3s;
}

/* clearfix
---------------------------------------- */
.cf:after {
  content: ".";
  display: block;
  height: 0;
  font-size: 0;
  clear: both;
  visibility: hidden;
}
.cf {
  display: inline-block;
}

/* Hides from IE Mac */
* html .cf {
  height: 1%;
}
.cf {
  display: block;
}

/* End Hack */
@media screen and (min-width: 768px) {
  .page_top_link:hover {
    color: #21AEDD;
    opacity: 1;
  }
  .page_top_link:hover::after {
    border-top-color: #21AEDD;
    border-left-color: #21AEDD;
  }
  .fixed_sns_link:hover {
    opacity: 1;
  }
  .fixed_btn_contact_link:hover {
    background: #21AEDD;
    opacity: 1;
  }
  .fixed_sns_link:hover .off,
  .fixed_btn_contact_link:hover .off {
    opacity: 0;
  }
  .fixed_btn_contact_link:hover .fixed_btn_contact_txt {
    color: #fff;
  }
  .member_link:hover {
    opacity: .7;
  }
  /*
  .category_label:hover {
    color: #fff;
    background: #181818;
    opacity: 1;
  }
  */
}

@media screen and (max-width: 1089px) {
  .grad_label {
    font-size: 1rem;
    padding: 9px 8.5px 8px;
    min-width: auto;
  }
  .mint_green_label {
    min-width: auto;
  }
  .category_label {
    font-size: 1rem;
    padding: 5px;
  }
  .date_label {
    font-size: 1rem;
  }
  .date_label::before {
    margin-right: 3px;
    width: 12px;
    height: 12px;
  }
}

@media screen and (max-width: 767px) {
  body {
    -webkit-text-size-adjust: 100%;
  }
  p,
  dt,
  dd,
  li,
  th,
  td,
  input,
  button,
  textarea,
  select {
    font-size: 1.5rem;
    line-height: 1;
    /*    line-height: 2;*/
  }
  .wrap {
    width: 100%;
  }
  .member_label {
    width: 100%;
  }
  .grad_label {
    font-size: 1rem;
    line-height: 1;
    padding: 6px 5px 4px;
    min-width: auto;
  }
  .mint_green_label {
    font-size: 1rem;
    line-height: 1;
    padding: 5px 8px;
    min-width: auto;
  }
  .category_label {
    font-size: 1rem;
    line-height: 1.6;
    padding: 5px 11px;
  }
  .grad_label + .category_label {
    margin-left: 7px;
  }
  .date_label {
    font-size: 1rem;
    line-height: 1.6;
    white-space: nowrap;
  }
  .date_label::before {
    margin-right: 6px;
    width: 12px;
    height: 12px;
  }
  .member_label {
    display: inline-flex;
    align-items: center;
  }
  .member_img {
    margin-right: 12px;
    max-width: 30px;
  }
  .member_name {
    font-size: 1rem;
  }
  .page_top_btn {
    text-align: center;
  }
  .fixed_btn_contact {
    right: 0;
    width: 100%;
  }
  .fixed_btn_contact_link {
    justify-content: center;
    position: relative;
    padding: 17.5px 0;
    width: 100%;
    border: none;
    border-radius: 0;
    background:#21AEDD;
  }
  .fixed_btn_contact_link::after {
    content: "";
    display: block;
    margin: 0 2vw;
    width: 14px;
    height: 9px;
    background: url(../../img/new/common/ico_white_arrow.svg) center / cover no-repeat;
  }
  .fixed_btn_contact_txt {
    color: #fff;
    margin-left: 0;
  }
}

/* --------------------------------------------------------------------------------

header

-------------------------------------------------------------------------------- */
header .inner {
  padding: 0 45px 0 37px;
  background: #fff;
}
header .wrap {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  height: 114px;
  max-width: 100%;
  gap:0 20px;
}
header .logo_wrap {
  margin: 0 auto 0 0;
}
header .logo_wrap .link {
  display: flex;
  align-items: center;
  padding: 0;
}
header .logo_wrap .link::after {
  content: none;
}
header .ttl_wrap {
  margin-left: 39px;
}
header .ttl_wrap .ttl {
  font-weight: 700;
  font-size: 1.2rem;
  line-height: 1.666;
}
header .ttl_wrap .present_by {
  display: flex;
  align-items: flex-end;
  margin-top: 8px;
}
header .ttl_wrap .present_by_txt {
  font-weight: 500;
  font-size: 1rem;
  line-height: 1.3;
  color: #333;
}
header .ttl_wrap .logo_adshin {
  margin: 0 0 2.2px 7px;
}
header .various_list {
  display: flex;
  align-items: center;
}
header .search_box_form {
  display: flex;
  align-items: center;
  position: relative;
  width: 430px;
  height: 50px;
  border: 2px solid #181818;
  border-radius: 4px;
  background: #fff;
}
header .search_box_category {
  position: relative;
}
header .search_box_category::before,
header .search_box_category::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
}
header .search_box_category::before {
  right: 0;
  width: 1px;
  height: 24px;
  background: #DEDEDE;
  transform: translateY(-50%);
}
header .search_box_category::after {
  right: 20px;
  width: 7px;
  height: 7px;
  border-bottom: 2px solid #181818;
  border-right: 2px solid #181818;
  transform: translateY(-50%) rotate(45deg);
  pointer-events: none;
}
header .category_select {
  font-weight: 600;
  letter-spacing: .06em;
  line-height: 1.1875;
  width: 150px;
  padding: 0 18px;
  overflow: hidden;
}
header .search_box_search {
  display: flex;
  position: relative;
  width: calc(100% - 141px);
}
header .search_input {
  font-weight: 700;
  font-size: 1.2rem;
  line-height: 1.666;
  padding: 0 53px 0 19px;
  width: 100%;
  overflow: hidden;
}
.ie11 header .search_input {
  padding: 5px 53px 0 19px;
}
header .search_ico {
  position: absolute;
  top: 50%;
  right: 17px;
  transform: translateY(-50%);
  /*cursor: pointer;*/
}
header .contact_btn {
  margin-left: 30px;
}
header .contact_link {
  font-weight: 600;
  font-size: 1.7rem;
  letter-spacing: .06em;
  line-height: 1.176;
  color: #fff;
  display: inline-flex;
  align-items: center;
  padding: 11.5px 18px 11.5px 26px;
  border: 2px solid #21AEDD;
  border-radius: 50em;
  background: #21AEDD;
}
header .contact_link::after {
  content: "";
  display: block;
  margin-left: 12.4px;
  width: 14px;
  height: 9px;
  background: url(../../img/new/common/ico_white_arrow.svg) center / cover no-repeat;
  transition: .3s;
}
.gnav {
  padding: 0 37px;
  background-color: #fff;
}
.gnav_list {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 0 auto;
  width: 100%;
  height: 60px;
}
header .gnav.m_fixed .gnav_list {
  height: 71px;
}
.gnav_link {
  font-weight: 700;
  font-size: 1.3rem;
  line-height: 60px;
  color:#222222;
  text-align: center;
  position: relative;
  display: block;
  padding: 0 28px;
  height: 60px;
}
header .gnav.m_fixed .gnav_link {
  line-height: 1.3;
  height: 71px;
  padding: 28px 20px;
}
.gnav_link::before {
  content: "";
  display: block;
  position: absolute;
  bottom: 50%;
  right: 0;
  width: 1px;
  height: 18px;
  background: #707070;
  transform: translateY(50%);
}
header ul .gnav_item:nth-child(2) .gnav_link::after,
footer ul .gnav_item:nth-child(1) .gnav_link::after{
  content: "";
  display: block;
  position: absolute;
  bottom: 50%;
  left: 0;
  width: 1px;
  height: 18px;
  background:#707070;
  transform: translateY(50%);
  right: initial;
}
header .gnav.m_fixed {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
}
header .gnav_item_logo,
header .gnav_item_search,
header .gnav_item_content {
  display: none;
}
header .gnav_item_logo {
  margin-right: auto;
}
header .gnav_item_search {
  margin: 0 8px 0 45px;
}
header .gnav_search_btn {
  display: block;
  cursor: pointer;
  position: relative;
}
header .gnav_search_btn::before {
  content: "";
  display: block;
  width: 21px;
  height: 21px;
  background: url(../../img/new/common/ico_black_search.svg) center / cover no-repeat;
}
header .open .gnav_search_btn::before {
  background: url(../../img/new/common/ico_black_search.svg) center / cover no-repeat;
}
header .gnav .gnav_item_content {
  position: fixed;
  top: 71px;
  left: 0;
  width: 100%;
  background: #1B245E;
}
header .search_menu {
  padding: 38px 50px 31px;
}
header .search_menu .search_box_form {
  margin: 0 auto 26px;
  width: 460px;
  border: none;
}
header .keyword_ttl {
  font-weight: 600;
  font-size: 1.8rem;
  line-height: 2.222;
  letter-spacing: .08em;
  text-indent: .08em;
  color: #fff;
  text-align: center;
  margin: 0 auto 24px;
  position: relative;
  height: 40px;
  max-width: 1000px;
}
header .keyword_ttl::before {
  content: "";
  display: block;
  position: absolute;
  bottom: 45%;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 1px;
  background: rgba(255,255,255,.4);
  transform: translateY(50%);
}
header .keyword_txt {
  text-align: center;
  display: inline-block;
  z-index: 1;
  margin: 0 auto;
  width: 168px;
  background: #1B245E;
}
header .keyword_list {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  max-width: 1010px;
}
header .keyword_item {
  margin: 0 5px 10px;
}
header .keyword_link {
  font-weight: 700;
  font-size: 1.2rem;
  line-height: 1;
  color: #222222;
  display: block;
  padding: 9px 11.775px;
  border-radius: 50em;
  background: #fff;
}
.ie11 header .keyword_link {
  padding: 12px 11.775px 6px;
}
header .keyword_link::before {
  content: "#";
}
.gnav .child_menu {
  display: none;
  position: absolute;
  top: auto;
  left: 0;
  z-index: 6;
  width: 100%;
}
.gnav .child_menu_inner {
  padding: 0 50px;
  background: #F5F5F5;
}
.gnav .child_list {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  width: 100%;
  max-width: 1006px;
  height: 100%;
}
.gnav .child_item {
  font-weight: 700;
  font-size: 1.3rem;
  line-height: 1.769;
  color: #5F5F5F;
  margin-right: 30px;
  padding: 15px 0 13px;
}

header .resist_area {
  display: flex;
  align-items: center;
  gap:20px;
  margin: 0 0 0 25px;
}
header .resist_area li {
  text-align: center;
}
header .resist_area li a span {
  display: flex;
  justify-content: center;
  height: 24px;
}
header .resist_area li p {
  font-size: 12px;
  font-weight: bold;
  margin: 8px 0 0;
}
@media screen and (min-width: 768px) {
  
  header .gnav.m_fixed .gnav_item_search {
    display: block;
  }
  header .contact_link:hover {
    color: #21AEDD;
    background: #fff;
    opacity: 1;
  }
  header .contact_link:hover::after {
    background: url(../../img/common/ico_blue_arrow.svg) center / cover no-repeat;
  }
  .gnav_link:hover {
    color: #21AEDD;
    opacity: 1;
  }
  header .keyword_link:hover {
    color: #181818;
    background: #DEDEDE;
    opacity: 1;
  }
  .child_link:hover {
    color: #B2B0B0;
    opacity: 1;
  }
}

@media screen and (max-width: 1280px) {
	header .gnav .gnav_link {
    padding: 0 15px;
  }
}
@media screen and (max-width: 1089px) {
  header .gnav_item_logo {
    width: 80px;
  }
  header .search_box_form {
    width: 300px;
  }
  header .gnav_item_search {
    margin: 0 8px 0 20px;
  }
  header .gnav.m_fixed .gnav_link {
    padding: 0 15px;
  }
  .gnav .child_list {
    display: flex;
    flex-wrap: wrap;
    margin: 0 auto;
    width: 100%;
    max-width: 1006px;
    height: 100%;
  }
}

@media screen and (max-width: 1140px) {
  header .search_box_form {
    width: 340px;
  }
  header .contact_btn {
    display: none;
  }
  .gnav_list {
    overflow-x: scroll;
  }
  .gnav_item {
    white-space: nowrap;
  }
}

@media screen and (max-width: 890px) {
  .gnav_list {
    justify-content: flex-start;
  }
}

@media screen and (max-width: 767px) {
  header .inner {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10;
    padding: 0 4.830917874%;
    width: 100%;
  }
  header .wrap {
    height: 71px;
  }
  header .logo_adlab {
    max-width: 60vw;
  }
  header .ttl_wrap {
    margin-left: 17px;
  }
  header .ttl_wrap .ttl {
    font-size: 1rem;
    line-height: 1.7;
  }
  header .various_list {
    display: block;
  }
  .gnav {
    padding: 71px 20px 0;
    width: 100%;
  }
  .gnav_list {
    justify-content: center;
    max-width: 100%;
    height: 51px;
  }
  .gnav_link {
    line-height: 51px;
    padding: 0 17px;
    height: 51px;
  }
  header .gnav .gnav_item_content {
    z-index: 20;
    padding-bottom: 72px;
    height: 100%;
    overflow-y: scroll;
  }
  header .search_menu {
    padding: 29px 4.830917874%;
    overflow: hidden;
  }
  header .search_menu .search_box_form {
    margin: 0 0 31px;
    width: 88.235294117%;
    height: 40px;
    border: none;
  }
  header .search_menu .search_box_category {
    display: none;
  }
  header .search_menu .search_box_search {
    display: block;
    width: 100%;
  }
  header .search_input {
    padding: 0 15px;
  }
  header .search_ico {
    right: -12%;
  }
  header .keyword_ttl {
    font-size: 1.6rem;
    line-height: 1.8125;
    margin: 0 auto 33px;
    height: 29px;
    max-width: 100%;
  }
  header .keyword_ttl::before {
    bottom: 50%;
  }
  header .keyword_txt {
    width: 121px;
  }
  header .keyword_list {
    margin-bottom: 38px;
    padding: 0 2.673796791% 30px;
    max-width: 100%;
    border-bottom: 1px solid #3C3C3C;
  }
  header .keyword_item {
    margin: 0 2.259887005% 8px 0;
  }
  header .keyword_link {
    font-size: 1rem;
    padding: 8px 11.4px;
  }
  .gnav .child_menu_inner {
    padding: 0 4.830917874%;
  }
  .gnav .child_list {
    max-width: 100%;
  }
  .gnav .child_item {
    font-size: 1rem;
    margin-right: 8px;
    padding: 10px 0;
  }
  header .search_menu_sp .category_list {
    position: relative;
    margin-bottom: 69px;
    padding-bottom: 41px;
    padding-left: 20px;
  }
  header .search_menu_sp .category_list::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 100vw;
    height: 1px;
    background: #3C3C3C;
    transform: translateX(-50vw);
  }
  header .search_menu_sp .category_term {
    font-weight: 700;
    font-size: 1.4rem;
    line-height: 1.357;
    color: #D6D6D6;
    position: relative;
  }
  header .search_menu_sp .category_term + .category_term {
    margin-top: 39px;
  }
  header .search_menu_sp .category_term .btn_accordion {
    position: absolute;
    top: 50%;
    right: 0;
    z-index: 1;
    width: 30px;
    height: 30px;
    transform: translateY(-50%);
  }
  header .search_menu_sp .category_term .btn_accordion::before,
  header .search_menu_sp .category_term .btn_accordion::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    background: #28B52D;
    transform: translateY(-50%);
    transition: .3s;
  }
  header .search_menu_sp .category_term .btn_accordion::before {
    right: 10px;
    width: 10px;
    height: 2px;
  }
  header .search_menu_sp .category_term .btn_accordion::after {
    right: 14px;
    width: 2px;
    height: 10px;
  }
  header .search_menu_sp .open .btn_accordion::before,
  header .search_menu_sp .open .btn_accordion::after {
    transform: translateY(-50%) rotate(90deg);
  }
  header .search_menu_sp .open .btn_accordion::before {
    opacity: 0;
  }
  header .search_menu_sp .category_des {
    display: none;
  }
  header .search_menu_sp .category_des + .category_term {
    margin-top: 39px;
  }
  header .search_menu_sp .sub_category_list {
    padding: 26px 0 10px;
  }
  header .search_menu_sp .sub_category_item {
    font-weight: 700;
    font-size: 1.1rem;
    line-height: 1.727;
    color: #D6D6D6;
    position: relative;
    margin-bottom: 16px;
    padding-left: 29px;
  }
  header .search_menu_sp .sub_category_item::before {
    content: "";
    display: block;
    position: absolute;
    top: 8px;
    left: 4.5px;
    width: 14px;
    height: 1px;
    background: #3C3C3C;
  }
  header .search_menu_sp .page_category_wrap {
    margin-bottom: 51px;
    padding-left: 20px;
  }
  header .search_menu_sp .page_category_list {
    margin-bottom: 20px;
  }
  header .search_menu_sp .page_category_term .btn_accordion {
    font-weight: 700;
    font-size: 1.6rem;
    line-height: 1.1875;
    color: #666;
  }
  header .search_menu_sp .page_sub_category_list {
    padding: 5px 0 6px;
  }
  header .search_menu_sp .page_sub_category_item {
    font-weight: 700;
    font-size: 1.2rem;
    line-height: 1.666;
    color: #D6D6D6;
    position: relative;
    margin-top: 15px;
    padding-left: 29px;
  }
  header .search_menu_sp .page_sub_category_item::before {
    content: "";
    display: block;
    position: absolute;
    top: 10px;
    left: 4.5px;
    width: 14px;
    height: 1px;
    background: #3C3C3C;
  }
  header .search_menu_sp .page_category_btn {
    font-weight: 700;
    font-size: 1.6rem;
    line-height: 1.1875;
    color: #D6D6D6;
    margin-bottom: 20px;
  }
  header .search_menu_sp .contact_btn {
    display: block;
    margin: 0 0 33px;
  }
  header .search_menu_sp .contact_link {
    font-size: 1.9rem;
    line-height: 1.21;
    justify-content: center;
    padding: 10px 0 10px 6px;
    width: 100%;
    max-width: 325px;
  }
  header .search_menu_sp .contact_link::after {
    margin-left: 6.4px;
  }
  header .search_menu_sp .sns_list {
    display: flex;
    justify-content: center;
    margin-bottom: 35px;
  }
  header .search_menu_sp .sns_item + .sns_item {
    margin-left: 19px;
  }
  header .search_menu_sp .sns_item.x img {
    width: 15px;
  }
  header .search_menu_sp .sns_link {
    display: block;
  }
  header .search_menu_sp .btn {
    font-weight: 700;
    font-size: 1.5rem;
    color: #fff;
    display: inline-block;
    position: relative;
    padding-right: 24px;
  }
  header .search_menu_sp .btn::before,
  header .search_menu_sp .btn::after {
    content:"";
    display: block;
    position: absolute;
    top: 50%;
    right: 0;
    width: 12px;
    height: 1px;
    background: #fff;
  }
  header .search_menu_sp .btn::before {
    transform: translateY(-50%) rotate(-45deg);
  }
  header .search_menu_sp .btn::after {
    transform: translateY(-50%) rotate(45deg);
  }
  
  /* menu_btn */
  header .menu_btn {
    position: relative;
    width: 35px;
    height: 22px;
    transition: transform .3s cubic-bezier(0.694,  0.048, 0.335, 1.000);
  }
  header .menu_btn span {
    display: block;
    margin-top: 8px;
    margin-left: auto;
    width: 30px;
    height: 2px;
    background-color: #21AEDD;
    transition: width 0.2s cubic-bezier(0.694,  0.048, 0.335, 1.000);
  }
  header .menu_btn span:first-of-type {
    margin-top: 0;
    width: 100%;  
    transform: scaleX(1);
    transition: transform 0.2s cubic-bezier(0.694,  0.048, 0.335, 1.000);
    transition-delay: 0.4s;
  }
  header .menu_btn span:last-of-type {
    width: 25px;
    transition: width 0.2s cubic-bezier(0.694,  0.048, 0.335, 1.000);
    transition-delay: 0.4s;
  }
  header .menu_btn .other_bar {
    position: absolute;
    top: -6px;
    left: 16px;
    width: 2px;
    height: 0;
    background-color: #21AEDD;
    transition: height 0.4s cubic-bezier(0.694,  0.048, 0.335, 1.000);
  }
  header .menu_btn.active {
    transform: rotate(45deg);
    transition-delay: 0.4s;
  }
  header .menu_btn.active span {
    width: 35px;
  }
  header .menu_btn.active span:first-of-type {
    transform: scaleX(0);
    transition: transform 0.2s cubic-bezier(0.694,  0.048, 0.335, 1.000);
  }
  header .menu_btn.active span:last-of-type {
    width: 0;
    transition: width 0.2s cubic-bezier(0.694,  0.048, 0.335, 1.000);
  }
  header .menu_btn.active .other_bar {
    height: 35px;
    transition: height 0.2s cubic-bezier(0.694,  0.048, 0.335, 1.000);
    transition-delay: 0.3s;
  }
  
  
  
  
  header .sp_link{
    display: block;
    margin-bottom: 2em;
  }

  header .sp_link ul{
    width: 100% !important;
    margin: 3vw auto 0;
    padding: 6vw 0 0;
    border-top: 1px solid rgba(255,255,255,.4)
  }
  header .sp_link ul li{
    width: 100%;
    margin-bottom: 0;
    position: relative;
    text-align: left;
  }
  header .sp_link ul li a{
    padding: 2.5vw 6vw 2.5vw 8vw;
    font-size: 1.6rem;
    color: #fff;
    display: block;
    position: relative;
  }
  header .sp_link ul li a::before {
    position: absolute;
    left: 4vw;
    top: 5vw;
    width: 6px;
    height: 1px;
    background-color: #fff;
    display: block;
    content: "";
}
  header .sp_link ul li .acd_menu + ul {
    display: none;
  }
  header .sp_link ul li .menu_ttl {
    position: relative;
  }
  
  header .sp_link ul li .menu_ttl .icon {
    position: absolute;
    right: 5px;
    top: 50%;
    transform: translatey(-50%);
    width: 38px;
    height: 38px;
  }
  header .sp_link ul li .menu_ttl .icon:before, 
  header .sp_link ul li .menu_ttl .icon:after {
    position: absolute;
    content: "";
    display: block;
    transition: all 0.4s;
    background: #fff;
    left: 50%;
    top: 50%;
    width: 50%;
    height: 1px;
    transform: translate(-50%, -50%);
  }
  header .sp_link ul li .menu_ttl .icon:before {
    transform: translate(-50%, -50%) rotate(90deg);
  }
  header .sp_link ul li .menu_ttl.active .icon:before {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  header .sp_link ul li ul {
    margin: 0 0 6vw;
  }
  header .sp_link ul li ul li a {
    padding: 1.5vw 6vw 1.5vw 12vw;
    font-weight: 400;
  }
  header .sp_link ul li ul li a::before {
    display: none;
  }
  
  header .link_list {
  display: block;
}
header .link_list ul {
  display: block;
  margin: 8vw 0 0;
}
header .link_list ul li{
  min-width: 100%;
  padding: 0 0 5vw 4vw;
  text-align: left;
}
header .link_list ul li::before {
  display: none;
}
  header .link_list ul li a {
    color: #fff;
  }
  
  .resist_area_sp {
    display: flex;
    justify-content: space-between;
    margin: 0 0 4vw;
  }
  .resist_area_sp li {
    width: 49%;
    text-align: center;
  }
  .resist_area_sp li a {
    display: block;
    background-color: #EBF2FD;
    border-radius: 5px;
    padding: 4.5vw 0;
    font-weight: bold;
    fonts:3.8vw;
    color: #1B245E;
    position: relative;
  }
  .resist_area_sp li a::after {
    content: "";
    display: block;
    position: absolute;
    bottom: 50%;
    right: 20px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #1B245E;
    border-right: 2px solid #1B245E;
    transform: translateY(50%) rotate(45deg);
    transition: .3s;
}
}

@media screen and (max-width: 592px) {
  .gnav_list {
    justify-content: flex-start;
  }
}

/* --------------------------------------------------------------------------------

footer

-------------------------------------------------------------------------------- */
footer .gnav {
}
footer .gnav .gnav_list {
  height: 75px;
}
footer .gnav .gnav_link {
  line-height: 75px;
  height: 75px;
}
footer .inner {
  padding: 60px 4.166666666% 35px;
  background: #1B245E;
}
footer .wrap01,
footer .wrap02 {
  display: flex;
  justify-content: space-between;
}
footer .wrap01 {
  margin-bottom: 64px;
}

footer .logo_wrap {
  width: 40%;
}
footer .logo_adlab {
  margin-bottom: 30px;
}

footer .inner .add {
  color: #fff;
  font-size: 12px;
  line-height: 1.83;
}

footer .logo_adlab .link {
  display: inline-block;
}
footer .txt {
  font-size: 1.2rem;
  line-height: 1.666;
  color: #b3b3b3;
  margin-bottom: 30px;
}
footer .sns_wrap_pc {
  display: flex;
  align-items: center;
}
footer .sns_txt {
  font-weight: 600;
  font-size: 1.1rem;
  line-height: 1.272;
  letter-spacing: .06em;
  color: #b3b3b3;
  position: relative;
  margin: 2px 56px 0 0;
}
footer .sns_txt::after {
  content: "";
  display: block;
  position: absolute;
  top: 45%;
  right: -37px;
  width: 28px;
  height: 1px;
  background: #b3b3b3;
  transform: translateY(-50%);
}
footer .sns_list {
  align-items: center;
  display: flex;
}
footer .sns_item + .sns_item {
  margin-left: 10px;
}
footer .sns_link {
  display: block;
}
footer .list_wrap {
  display: flex;
  width: 60%;
}
footer .list_wrap .list {
  width: 33.333333333%;
}
footer .list_wrap .item {
  margin-bottom: 30px;
}
footer .list_wrap .list:first-of-type .item {
  margin-bottom: 16px;
}
footer .list_wrap .link {
  font-size: 1.4rem;
  line-height: 1.285;
  color: #b3b3b3;
}
footer .list_wrap .list:first-of-type .link {
  font-weight: 700;
  margin-left: 5px;
}
footer .list_wrap .list:first-of-type .link::before {
  content: "-";
}
footer .list_wrap .list:first-of-type .item:first-of-type .link {
  color: #505050;
  margin: 0;
  pointer-events: none;
}
footer .list_wrap .list:first-of-type .item:first-of-type .link::before {
  display: none;
}
footer .list_wrap .txt_en {
  font-weight: 600;
}
footer .list_wrap .txt_jp {
  font-weight: 700;
  font-size: 1.2rem;
}
footer .list_wrap .txt_en + .txt_jp {
  margin-left: 1em;
}
footer .wrap02 {
  margin: 2% auto 0;
  max-width: 1280px;
}
footer .logo_wrap02 {
  display: flex;
  align-items: center;
}
footer .logo_adshin {
  margin-right: 29PX;
  width: 128px;
}
footer .logo_adshin img {
  width: 100%;
}
footer address {
  font-size: 1.1rem;
  line-height: 1.727;
  color: #d6d6d6;
}
footer .other_list {
  display: flex;
  align-items: flex-end;
}
footer .other_item {
  font-size: 1.1rem;
  line-height: 1.272;
  color: #b3b3b3;
}
footer .other_item:last-of-type::before {
  content: "|";
  color: #b3b3b3;
  margin: 0 .4em;
}
footer .copy {
  font-size: 1.1rem;
  line-height: 1.272;
  color: #333;
  padding: 1em .5em;
  text-align: center;
  background: #fff;
}
footer .copy {
  text-align: center;
}
@media screen and (min-width: 768px) {
  footer .list_wrap .link:hover {
    color: #fff;
    opacity: 1;
  }
}
@media screen and (max-width: 1396px) {
  footer .wrap02 {
    padding-left: 0px;
    max-width: 1200px;
  }
}

@media screen and (max-width: 1089px) {
  footer .txt {
    font-size: 1rem;
  }
  footer .list_wrap .link {
    font-size: 1rem;
  }
  footer .list_wrap .txt_jp {
    font-size: 1rem;
  }
  footer .logo_wrap02 {
    display: flex;
    align-items: center;
  }
  footer address {
    font-size: 1rem;
  }
  footer .other_item {
    font-size: 1rem;
  }
}

@media screen and (max-width: 767px) {
  footer .inner {
    padding: 22px 0 18px;
  }
  footer .wrap01,
  footer .wrap02 {
    display: block;
  }
  footer .wrap01 {
    margin-bottom: 18px;
  }
  footer .logo_wrap {
    width: 100%;
  }
  footer .logo_adlab {
    text-align: center;
    padding: 0 0 8%;
     border-bottom: 1px solid rgba(255,255,255,.4);
  }
  footer .logo_adlab .link {
    width:76vw;
  }
  footer .txt {
    text-align: center;
    margin-bottom: 22px;
  }
  footer .sns_list {
    justify-content: center;
  }
  /*footer .sns_item {
    margin-right: 0;
  }
  footer .sns_item:first-of-type {
    margin-right: 19px;
  }*/
  footer .sns_item + .sns_item {
    margin-left: 15px;
  }
  footer .list_wrap {
    display: block;
    width: 100%;
  }
  footer .list_wrap .list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    width: 100%;
  }
  footer .list_wrap .list:first-of-type {
    margin: 0 auto 25px;
    max-width: 280px;
  }
  footer .list_wrap .item {
    display: flex;
    align-items: center;
    margin-bottom: 7px;
  }
  footer .list_wrap .item::after {
    color: #707070;
    content:"|";
    padding: 0 17px;
  }
  footer .list_wrap .item:last-of-type::after {
    display: none;
  }
  footer .list_wrap .list:first-of-type .item {
    margin-bottom: 4px;
  }
  footer .list_wrap .list:first-of-type .item::after {
    padding: 0 12px;
  }
  footer .list_wrap .list:first-of-type .item:nth-of-type(3)::after {
    padding-right: 0;
  }
  footer .list_wrap .list:nth-of-type(2) .item:last-of-type::after {
    display: inline;
    padding-right: 0;
  }
  footer .list_wrap .link {
    font-size: 1.3rem;
    line-height: 1.23;
    color: #ccc;
  }
  footer .list_wrap .list:first-of-type .link {
    font-size: 1.2rem;
    line-height: 1.666;
    margin: 0;
  }
  footer .list_wrap .list:first-of-type .link::before {
    display: none;
  }
  footer .wrap02 {
    padding: 0;
    max-width: 100%;
  }
  footer .logo_wrap02 {
    display: flex;
    align-items: center;
  }
  footer .logo_adshin {
    margin: 0 auto 19px;
    width: 112px;
  }
  footer .other_list {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    margin-bottom: 20px;
  }
  footer .other_item {
    line-height: 1.545;
    color: #ccc;
  }
  footer .other_item:last-of-type::before {
    color: #707070;
    margin: 0 1em;
  }
  footer .copy {
    font-size: 1rem;
    line-height: 1.3;
    padding: 16px 0 67px;
  }
  footer .list_wrap .link:active {
    color: #fff;
    opacity: 1;
  }
}

@media screen and (max-width: 413px) {
  footer .list_wrap .item::after {
    padding: 0 10px;
  }
  footer .list_wrap .link {
    font-size: 1.1rem;
  }
}
/* --------------------------------------------------------------------------------

content_wrap

-------------------------------------------------------------------------------- */
.content_wrap {
  padding: 0 3.846153846%;
  background: #fff;
}
.content_wrap > .inner {
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .content_wrap {
    padding: 0;
  }
  .content_wrap > .inner {
    display: block;
  }
}
/* --------------------------------------------------------------------------------

bread_crumb_wrap

-------------------------------------------------------------------------------- */
.bread_crumb_wrap {
  padding: 58px 3.846153846% 36px;
}
.bread_crumb_wrap .wrap > span {
  margin: 0 11px;
}
.bread_crumb_wrap .wrap > span:first-child {
  margin-left: 0;
}
.bread_crumb_wrap .wrap a {
  font-weight: 700;
  font-size: 1.1rem;
  line-height: 1.727;
  color: #21AEDD;
  text-decoration: underline;
}
.bread_crumb_wrap .list {
  display: flex;
}
.bread_crumb_wrap .item:not(:first-of-type) {
  display: flex;
  position: relative;
  margin-left: 22px;
}
.bread_crumb_wrap .item:not(:last-of-type) {
  white-space: nowrap;
}
.bread_crumb_wrap .item:not(:first-of-type)::before {
  content:"";
  display: block;
  position: absolute;
  top: 7px;
  left: -15px;
  width: 6px;
  height: 6px;
  border-top: 1px solid #707070;
  border-right: 1px solid #707070;
  transform: rotate(45deg);
}
.bread_crumb_wrap .link {
  font-weight: 700;
  font-size: 1.1rem;
  line-height: 1.727;
  color: #00BA00;
  text-decoration: underline;
}
.bread_crumb_wrap .item:last-of-type .link {
  color: #707070;
  text-decoration: none;
  pointer-events: none;
  display: -webkit-box;/*文章省略用*/
  -webkit-line-clamp: 1;/*文章省略用*/
  -webkit-box-orient: vertical;/*文章省略用*/
  overflow: hidden;/*文章省略用*/
}

/* --------------------------------------------------------------------------------

main_content

-------------------------------------------------------------------------------- */
.content_wrap .main_content {
  width: 100%;
  max-width: 66.666666666%;
}
@media screen and (max-width: 767px) {
  .content_wrap .main_content {
    max-width: 100%;
  }
}

/* pager_list
---------------------------------------- */
.pager_list ul {
  display: flex;
  align-items: center;
}
.pager_list .item {
  text-align: center;
  margin: 0 7.5px;
}
.pager_list .link {
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 1.4rem;
  line-height: 1;
  letter-spacing: .06em;
  text-indent: .06em;
  color:#1B245E;
  display: block;
  padding: 14px 0;
  width: 42px;
  border-radius: 50em;
  background: #F2F2F2;
  text-align: center;
}
.pager_list .item.current .link {
  color: #fff;
  background: #1B245E;
  pointer-events: none;
}
.pager_list .item_around .link {
  font-size: 1.5rem;
  color:#1B245E;
  display: flex;
  align-items: center;
  padding: 0;
  width: auto;
  border-radius: 0;
  background: transparent;
}
.pager_list .item_around.no_page .link {
  color: #ccc;
  pointer-events: none;
}
.pager_list .item_around .link::before,
.pager_list .item_around .link::after {
  content: "";
  display: block;
  width: 80px;
  height: 12px;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
  transition: .3s;
}
.pager_list .item_around.prev {
  margin-right: auto;
}
.pager_list .item_around.prev .link::before {
  margin-right: 17px;
  background-image: url(../../img/common/ico_prev.svg);
}
.pager_list .item_around.prev.no_page .link::before {
  background-image: url(../../img/common/ico_prev_gray.svg);
}
.pager_list .item_around.next {
  margin-left: auto;
}
.pager_list .item_around.next .link::after {
  margin-left: 17px;
  background-image: url(../../img/common/ico_next.svg);
}
.pager_list .item_around.next.no_page .link::after {
  background-image: url(../../img/common/ico_next_gray.svg);
}

@media screen and (min-width: 768px) {
  .pager_list .item .link:hover {
    color: #fff;
    background: #333;
    opacity: 1;
  }
  .pager_list .item_around .link:hover {
    color: #ccc;
    opacity: 1;
  }
  .pager_list .item_around.prev .link:hover::before {
    background-image: url(../../img/common/ico_prev_gray.svg);
  }
  .pager_list .item_around.next .link:hover::after {
    background-image: url(../../img/common/ico_next_gray.svg);
  }
}

@media screen and (max-width: 767px) {
  .pager_list .item {
    margin: 0 5px;
  }
  .pager_list .link {
    font-size: 1rem;
    padding: 9px 0 7px;
    width: 26px;
  }
  .pager_list .item_around.prev {
    margin-left: 5.314009661%;
  }
  .pager_list .item_around.next {
    margin-right: 5.314009661%;
  }
  .wp-pagenavi .page, .wp-pagenavi span {
    font-size: 1rem;
    margin: 5px;
    padding: 9px 0 7px;
    width: 26px;
  }
  .previouspostslink {
    margin: 0 4%;
  }
  .nextpostslink {
    margin: 0 4%;
  }
}

@media screen and (max-width: 374px) {
  .pager_list .item_around .link {
    font-size: 1rem;
  }
  .pager_list .item_around.prev .link::before {
    margin-right: 7px;
  }
  .pager_list .item_around.next .link::after {
    margin-left: 7px;
  }
}

/* reuse_list
---------------------------------------- */
.reuse_list {
  margin-bottom: 46px;
}
.reuse_item {
  margin-bottom: 36px;
  padding-bottom: 39px;
  border-bottom: 1px solid #dedede;
}
.reuse_item_link {
  display: flex;
  align-items: flex-start;
  width: 100%;
}
.reuse_item_img {
  position: relative;
  width: 100%;
  max-width: 46.25%;
  overflow: hidden;
  border-radius: 10px;
}
.reuse_item_img:after {
  display: block;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #181818;
  opacity: 0;
  -webkit-transition: opacity .25s ease;
  transition: opacity .25s ease;
}
.reuse_item_img img {
  width: 100%;
  transition: .3s;
}
.reuse_item_img span {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 1;
}
.reuse_txt_wrap {
  display: flex;
  flex-direction: column;
  padding: 0 3.375% 0 5%;
  width: 53.75%;
  background: #fff;
}
.reuse_txt_wrap .label_wrap {
  margin-bottom: 29px;
}
.reuse_txt_wrap .sttl {
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1.7;
  display: -webkit-box;/*文章省略用*/
  -webkit-line-clamp: 3;/*文章省略用*/
  -webkit-box-orient: vertical;/*文章省略用*/
  overflow: hidden;/*文章省略用*/
}
.reuse_txt_wrap .member_label {
  margin-top: 24px;
  position: relative;
  z-index: 4;
}

@media screen and (min-width: 768px) {
  .reuse_item_link:hover {
    opacity: 1;
  }
  .reuse_item_link:hover .reuse_item_img:after {
    opacity: .25;
  }
  .reuse_item_link:hover .reuse_item_img img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

@media screen and (max-width: 767px) {
  .reuse_list {
    margin-bottom: 31px;
    padding: 0 4.830917874%;
  }
  .reuse_item {
    margin-bottom: 20px;
    padding-bottom: 15px;
  }
  .reuse_item_link {
    flex-wrap: wrap;width: 100%;
  }
  .reuse_item_img {
    max-width: 36.363636363%;
  }
  .reuse_txt_wrap {
    width: 63.636363637%;
    padding: 0 0 0 3.743315508%;
  }
  .reuse_txt_wrap .label_wrap {
    margin-bottom: 6px;
  }
  .reuse_txt_wrap .sttl {
    font-size: 1.2rem;
    line-height: 1.666;
  }
  .reuse_txt_wrap .member_label {
    margin-top: 15px;
  }
  .reuse_item_link:active {
    opacity: 1;
  }
  .reuse_item_link:active .reuse_item_img img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

/* --------------------------------------------------------------------------------

aside

-------------------------------------------------------------------------------- */
.content_wrap aside {
  width: 100%;
  max-width: 26.666666666%;
}
.aside_ttl {
   font-family: "Inter", sans-serif;
  font-weight: 700;
  font-size: 2.8rem;
  line-height: 1.185;
  letter-spacing: .08em;
  text-indent: .15em;
  color: #1B245E;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  margin-bottom: 11px;
}
.aside_ttl::before {
  content: "";
  display: block;
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}
.aside_lead {
  font-weight: 700;
  font-size: 1.3rem;
  line-height: 1.307;
  color: #181818;
  text-align: center;
  padding-bottom: 24px;
  border-bottom: 1px solid #181818;
}

@media screen and (max-width: 1089px) {
  .content_wrap aside {
    max-width: 30%;
  }
}

@media screen and (max-width: 767px) {
  .content_wrap aside {
    max-width: 100%;
    padding: 0 5vw;
    box-sizing: border-box;
  }
}

/* ranking
---------------------------------------- */
.ranking .item {
  padding: 30px 0;
  border-bottom: 1px solid #d5d3d3;
}
.ranking .item:first-of-type {
  padding: 35px 0 19px;
}
.ranking .link {
  display: flex;
  align-items: flex-start;
  width: 100%;
}
.ranking .item:first-of-type .link {
  display: block;
}
.ranking .item .ranking_img {
  flex: none;
  position: relative;
  margin: 0 5.9375% 0 0;
  width: 37.5%;
  overflow: hidden;
}
.ranking .item .ranking_img:after {
  display: block;
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #181818;
  opacity: 0;
  -webkit-transition: opacity .25s ease;
  transition: opacity .25s ease;
}
.ranking .ranking_img img {
  width: 100%;
  transition: .3s;
}
.ranking .item:first-of-type .ranking_img {
  margin: 0 0 20px 0;
  width: 100%;
}
.ranking .item .date_label {
  margin-bottom: 11px;
}
.ranking .item:first-of-type .date_label {
  margin-bottom: 21px;
}
.ranking .ranking_label {
  font-family: 'Montserrat', sans-serif;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1;
  letter-spacing: .06em;
  text-indent: .06em;
  color: #fff;
  text-align: center;
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  padding: 7px 0;
  width: 29px;
  background: #181818;
}
.ranking .item:nth-of-type(1) .ranking_label {
  background: #E6BD10;
}
.ranking .item:nth-of-type(2) .ranking_label {
  background: #BFBEBE;
}
.ranking .item:nth-of-type(3) .ranking_label {
  background: #B77545;
}
.ranking .reuse_txt_wrap {
  padding: 0;
  width: 62.5%;
}
.ranking .item:first-of-type .reuse_txt_wrap {
  width: 100%;
}
.ranking .reuse_txt_wrap .sttl {
  font-size: 1.3rem;
  line-height: 1.769;
}

@media screen and (min-width: 768px) {
  .ranking .link:hover {
    opacity: 1;
  }
  .ranking .link:hover .ranking_img:after {
    opacity: .25;
  }
  .ranking .link:hover .ranking_img img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
}

@media screen and (max-width: 1089px) {
  .ranking .item .ranking_img {
    width: 43.75%;
  }
}

@media screen and (max-width: 767px) {
  .ranking .inner {
    padding-top: 60px;
  }
  .ranking .item {
    margin: 0;
    padding: 20px 0;
  }
  .ranking .item:first-of-type {
    padding: 35px 0 19px;
  }
  .ranking .item .ranking_img {
    margin: 0 3.713527851% 0 0;
    width: 36.363636363%;
  }
  .ranking .item:first-of-type .ranking_img {
    margin: 0 0 12.6px 0;
  }
  .ranking .item .date_label {
    margin-bottom: 11px;
  }
  .ranking .item:first-of-type .date_label {
    font-size: 1.3rem;
    margin-bottom: 15px;
  }
  .ranking .item:first-of-type .date_label::before {
    margin-right: 8px;
    width: 17px;
    height: 17px;
  }
  .ranking .ranking_label {
    font-size: 1rem;
    padding: 4.5px 0;
    width: 19px;
  }
  .ranking .item:nth-of-type(1) .ranking_label {
    font-size: 1.8rem;
    padding: 7.5px 0;
    width: 33px;
  }
  .ranking .reuse_txt_wrap {
    padding: 0;
    width: 59.922835786%;
  }
  .ranking .reuse_txt_wrap .sttl {
    font-size: 1.3rem;
    line-height: 1.769;
  }
}

/* category
---------------------------------------- */
.category .inner {
  padding-top: 49px;
}
.category .item {
  border-bottom: 1px dashed #ccc;
}
.category .link {
  font-weight: 700;
  font-size: 1.4rem;
  line-height: 1.714;
  color: #000;
  display: block;
  position: relative;
  padding: 15.5px 26px 15.5px 14px;
}
.category .link::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 50%;
  right: 20px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  transform: translateY(50%) rotate(45deg);
  transition: .3s;
}

@media screen and (min-width: 768px) {
  .category .link:hover {
    color: #21AEDD;
    opacity: 1;
  }
  .category .link:hover::after {
    border-top-color: #28B52D;
    border-right-color: #28B52D;
  }
}

@media screen and (max-width: 767px) {
  .category .link {
    padding: 20px 9.178743961% 20px 6.763285024%;
  }
  .category .link::after {
    right: 7.487922705%;
  }
}

/* hot_word
---------------------------------------- */
.hot_word .inner {
  padding-top: 58px;
}
.hot_word .aside_lead {
  margin-bottom: 30px;
}
.hot_word .list {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  max-width: 297px;
}
.hot_word .item {
  margin: 0 4px 9px;
}
.hot_word .link {
  font-weight: 700;
  font-size: 1.2rem;
  line-height: 1;
  color: #222222;
  display: block;
  padding: 9px 10.775px;
  border: 1px solid #DEDEDE;
  border-radius: 50em;
}
.ie11 .hot_word .link {
  padding: 12px 10.775px 6px;
}
.hot_word .link::before {
  content: "#";
}

@media screen and (min-width: 768px) {
  .hot_word .link:hover {
    color: #fff;
    background: #3C3C3C;
    opacity: 1;
  }
}

@media screen and (max-width: 767px) {
  .hot_word .inner {
    padding-top: 50px;
  }
  .hot_word .aside_lead {
    margin-bottom: 30px;
  }
  .hot_word .list {
    max-width: 71.739130434%;
    min-width: 301px;
  }
  .hot_word .item {
    margin: 0 1.346801346% 8px;
  }
}

/* member
---------------------------------------- */
.member .inner {
  padding-top: 41px;
}
.member .aside_ttl::before {
  margin-right: 15.1px;
  width: 30px;
  height: 23px;
  background-image: url(../../img/new/common/ico_person_hat.svg);
}
.member .aside_lead {
  margin-bottom: 30px;
}
.member .list {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  width: 100%;
  max-width: 318px;
}
.member .item {
  width: 100%;
  max-width: 33.333333333%;
}
.member .link {
  display: block;
}
.member .member_img {
  margin: 0 auto 6px;
  max-width: 44px;
}
.member .member_name {
  font-size: 1.1rem;
  line-height: 1.727;
  text-align: center;
  margin-bottom: 16px;
}

@media screen and (min-width: 768px) {
  .member .item a:hover .member_img, 
  .member .item a:hover .member_name {
    opacity: .7;
  }
}

@media screen and (max-width: 767px) {
  .member .inner {
    padding-top: 50px;
  }
  .member .aside_lead {
    margin-bottom: 40px;
  }
  .member .list {
    width: 79.22705314%;
    max-width: 100%;
    min-width: 280px;
  }
  .member .member_img {
    margin: 0 auto 7px;
    max-width: 54px;
  }
  .member .member_name {
    font-size: 1.3rem;
    line-height: 1.769;
    margin-bottom: 20px;
  } 
}

/* other
---------------------------------------- */
.other .inner {
  padding-top: 41px;
}
.other .btn a {
  border: 1px solid #707070;
  color: #000;
  display: block;
  font-weight: 700;
  font-size: 1.4rem;
  line-height: 1.714;
  position: relative;
  padding: 15.5px 26px 15.5px 14px;
}
.other .btn a::after {
  content: "";
  display: block;
  position: absolute;
  bottom: 50%;
  right: 20px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #000;
  border-right: 2px solid #000;
  transform: translateY(50%) rotate(45deg);
  transition: .3s;
}
@media screen and (min-width: 768px) {
  .other .btn a:hover {
    background: #707070;
    color: #fff;
    opacity: 1;
  }
  .other .btn a:hover::after {
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }
}
@media screen and (max-width: 767px) {
  .other .inner {
    padding-top: 30px;
  }
  .other .btn a {
    max-width: 80%;
    margin: 0 auto;
  }
}

/* btn
---------------------------------------- */
.normal_btn {
  text-align: center;
}
.normal_btn a {
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.71428571428;
  color: #fff;
  display: inline-block;
  padding: 17px 0 15px;
  width: 100%;
  max-width: 300px;
  border: 1px solid #1B245E;
  background: #1B245E;
  border-radius: 5px;
}
@media screen and (min-width: 768px) {
  .normal_btn a:hover {
    color: #181818;
    border-color: #707070;
    background: #fff;
    opacity: 1;
  }
}

/* フッター改修
---------------------------------------- */
footer .wrap {
  width: 95%;
  max-width: 1280px;
  margin: auto;
}
footer .right {
  width: 590px;
}
footer a {
  color: #cccccc;
}
footer .link_list {
  display: flex;
  justify-content: space-between;
}
footer .link_list ul {
  display: flex;
  flex-wrap: wrap;
  gap:18px 0;
}
footer .link_list ul li{
  min-width: 210px;
  padding: 0 0 0 20px;
  position: relative;
}
footer .link_list ul li::before {
  position: relative;
    left: -18px;
    top: 11px;
    width: 6px;
    height: 1px;
    background-color: #fff;
    display: block;
    content: "";
}
footer .right ul li a{
  line-height: 1.4;
  font-size: 1.3rem;
  font-weight: 400;
  -webkit-transition: all 0.3s;
  -moz-transition: all 0.3s;
  -o-transition: all 0.3s;
  transition: all 0.3s;
}

footer .right ul li a.sub{
  font-size: 1.3rem;
  padding-left: 1.2em;
}
footer .right ul li a:hover{
  color: #fff;
  opacity: 1.0;
  filter: alpha(opacity=100);
  -moz-opacity: 1.0;
}
footer .right ul li a:hover span{
  color: #fff;
}
footer .right ul li a.no_link:hover{
  color: #b3b3b3;
}
footer .right ul li a span{
  padding-left: .8em;
  font-size: 1.2rem;
  font-weight: 800;
  color: #999999;
  -webkit-transition: 0.5s ease-in-out;
  -moz-transition: 0.5s ease-in-out;
  -o-transition: 0.5s ease-in-out;
  transition: 0.5s ease-in-out;
}
footer .right ul li a.no_link:hover span{
  color: #999999;
}


footer .contact_link {
  font-weight: 600;
  font-size: 1.7rem;
  letter-spacing: .06em;
  line-height: 1.176;
  color: #fff;
  display: inline-flex;
  align-items: center;
  padding: 11.5px 15px 11.5px 22px;
  border: 2px solid #21AEDD;
  border-radius: 50em;
  background: #21AEDD;
}
footer .contact_link::after {
  content: "";
  display: block;
  margin-left: 12.4px;
  width: 14px;
  height: 9px;
  background: url(../../img/new/common/ico_white_arrow.svg) center / cover no-repeat;
  transition: .3s;
}

footer .sp_link {
  display: none;
}
footer .sns_list .sns_item:nth-child(1) img {
  width: 20px;
}
footer .sns_list .sns_item:nth-child(2) img {
  width: 18px;
}
footer .sns_list .sns_item:nth-child(3) img {
  width: 18px;
}

footer .copyright p{
  text-align: right;
  color: #fff;
  font-size: 11px;
  margin: 45px 0 0;
}

@media screen and (min-width: 881px) {
  footer .sp {
    display: none;
  }
}

@media screen and (max-width: 880px) {
  footer .pc {
    display: none;
  }
  footer .wrap {
    display: block;
    width: 100%;
  }
  footer .inner {
    padding: 8% 0 12%;
  }
  footer .logo_wrap01 {
    display: block;
    text-align: center;
  }
  footer .logo_adlab {
    text-align: center;
    margin: 0;
  }
  footer .txt {
    text-align: center;
  }
  footer .right{
    width: 100%;
    text-align: center;
    display: block;
  }
  footer .right ul li{
    text-align: center;
  }
  footer .right ul li a{
    font-size: 1.2rem;
  }
  footer .pc_link{
    display: none;
  }
  footer .sp_link{
    display: block;
    margin-bottom: 2em;
  }

  footer .sp_link ul{
    width: 100% !important;
    margin: 4vw auto 0;
  }
  footer .sp_link ul li{
    width: 100%;
    margin-bottom: 0;
    position: relative;
    text-align: left;
  }
  footer .sp_link ul li a{
    padding: 2.5vw 6vw 2.5vw 12vw;
    font-size: 1.6rem;
    color: #fff;
    display: block;
    position: relative;
  }
  footer .sp_link ul li a::before {
    position: absolute;
    left: 8vw;
    top: 5vw;
    width: 6px;
    height: 1px;
    background-color: #fff;
    display: block;
    content: "";
}
  footer .sp_link ul li .acd_menu + ul {
    display: none;
  }
  footer .sp_link ul li .menu_ttl {
    position: relative;
  }
  
  footer .sp_link ul li .menu_ttl .icon {
    position: absolute;
    right: 5px;
    top: 50%;
    transform: translatey(-50%);
    width: 38px;
    height: 38px;
  }
  footer .sp_link ul li .menu_ttl .icon:before, 
  footer .sp_link ul li .menu_ttl .icon:after {
    position: absolute;
    content: "";
    display: block;
    transition: all 0.4s;
    background: #fff;
    left: 50%;
    top: 50%;
    width: 50%;
    height: 1px;
    transform: translate(-50%, -50%);
  }
  footer .sp_link ul li .menu_ttl .icon:before {
    transform: translate(-50%, -50%) rotate(90deg);
  }
  footer .sp_link ul li .menu_ttl.active .icon:before {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  footer .sp_link ul li ul {
    margin: 0 0 6vw;
  }
  footer .sp_link ul li ul li a {
    padding: 1.5vw 6vw 1.5vw 12vw;
    font-weight: 400;
  }
  footer .sp_link ul li ul li a::before {
    display: none;
  }
  
  footer .link_list {
  display: block;
}
footer .link_list ul {
  display: block;
  margin: 8vw 0 0;
}
footer .link_list ul li{
  min-width: 100%;
  padding: 0 0 5vw 8vw;
  text-align: left;
}
footer .link_list ul li::before {
  display: none;
}
footer .right ul li a{
  line-height: 1.4;
  font-size:3.4vw;
  color: #fff;
}
footer .copyright p{
  text-align: center;
  font-size: 2.8vw;
  padding: 6vw 0;
  line-height: 1.5;
  margin: 0;
  border-top: 1px solid rgba(255,255,255,0.4)
}
}

/* page_top_btn
---------------------------------------- */
.page_top_btn {
  margin: 101px 52px 21px 0;
}

@media screen and (max-width: 767px) {
  .page_top_btn {
    margin:8vw 0;
  }
}

/* 非表示にする場合 */
.hidden_link {
  display: none !important;
}