@charset "UTF-8";
/** pxからvwへ変換関数 **/
html {
  font-size: 10px;
}

body {
  color: #0B0B10;
  font-size: 1.5rem;
  font-weight: 300;
  line-height: 1.8;
  font-family: "游ゴシック体", "YuGothic", "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
}

ul {
  list-style: none;
}

a {
  -webkit-transition: all .5s 0s ease;
  transition: all .5s 0s ease;
}

a:hover {
  color: #574B9C;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

h3 {
  font-size: 1.8rem;
}

p {
  font-weight: 300;
}

table {
  width: 100%;
  text-align: left;
}

.w1000 {
  max-width: 1000px;
  width: 100%;
  margin: 0 auto;
}

.w800 {
  max-width: 800px;
  width: 100%;
  margin: 0 auto;
}

.img-h-400 {
  height: 400px;
  overflow: hidden;
}

.img-h-400 img {
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  height: 400px;
}

.text-align-left {
  text-align: left;
}

.text-align-center {
  text-align: center;
}

.text-align-right {
  text-align: right;
}

.font-bold {
  font-weight: bold;
}

.mt-05 {
  margin-top: 5rem;
}

.mt-042 {
  margin-top: 4.2rem;
}

.mt-04 {
  margin-top: 4rem;
}

.mt-03 {
  margin-top: 3rem;
}

.mb-05 {
  margin-bottom: 5rem;
}

.mb-04 {
  margin-bottom: 4rem;
}

.mb-03 {
  margin-bottom: 3rem;
}

.mb-025 {
  margin-bottom: 2.5rem;
}

.mb-02 {
  margin-bottom: 2rem;
}

.pb-05 {
	padding-bottom: 5rem;
}

.pb-04 {
	padding-bottom: 4rem;
}

.pb-03 {
	padding-bottom: 3rem;
}

.pb-02 {
	padding-bottom: 2rem;
}

.pb-01 {
	padding-bottom: 1rem;
}

.pb-00 {
	padding-bottom: 0 !important;
}

.p10 {
  padding: 1rem;
}

main {
  overflow: hidden;
  padding: 10rem 0 5rem;
  
}

.main-pb-0 {
  padding: 10rem 0 0;
}

.btns {
  margin-top: 4rem;
}

.btns .btn {
  position: relative;
  display: block;
  max-width: 400px;
  text-align: center;
  border: 1px solid #0B0B10;
  margin: 0 auto;
  padding: 1.5rem 0;
}

.btns .btn:after {
  position: absolute;
  display: block;
  content: '';
  top: 45%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 15px;
  width: 8px;
  height: 8px;
  border-top: 1px solid #0B0B10;
  border-right: 1px solid #0B0B10;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: all .3s ease-in-out;
  transition: all .3s ease-in-out;
}

.btns .btn svg {
  position: absolute;
  right: 2rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.btns .btn:hover {
  color: #fff;
  background-color: #352977;
}

.btns .btn:hover svg path {
  stroke: #fff;
}

.btns .btn:hover:after {
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}

.arrow-after:after {
  position: absolute;
  display: block;
  content: '';
  top: 45%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 22px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #0B0B10;
  border-right: 2px solid #0B0B10;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: all .3s ease-in-out;
  transition: all .3s ease-in-out;
}

.arrow-after-white:after {
  position: absolute;
  display: block;
  content: '';
  top: 45%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 22px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: all .3s ease-in-out;
  transition: all .3s ease-in-out;
}

/*===========
color
=============*/
.bg-light-blue {
  background-color: #F0F2F5;
}

.bg-purple {
  background-color: #574B9C;
}

.bg-white {
  background-color: #fff;
}

.bg-light-gray {
  background-color: #ccc;
}

.border-gray {
  border: 1px solid #CCCCCC;
}

.color-white {
  color: #fff !important;
}

.color-black {
  color: #0B0B10 !important;
}

.cat-ir, .cat-news, .cat-sustainability {
  color: #E77519;
  border: 1px solid #E77519;
}

.cat-information, .cat-recareer, .cat-renewface {
  background-color: #F0F2F5;
}

.box-purple {
  margin-top: 3rem;
}

.box-purple a {
  display: block;
  color: #fff;
  border: 1px solid #fff;
  text-align: center;
  padding: 1.5rem 1rem;
}

.close-btn {
  margin-top: 3rem;
}

.close-btn button {
  display: block;
  color: #fff;
  background-color: #0B0B10;
  text-align: center;
  padding: 1.5rem 1rem;
  width: 100%;
}

.style-p-bb {
  border-bottom: 1px solid #ccc;
  padding-bottom: 1rem;
  margin-bottom: 1rem;
}

/*===========
font
=============*/
.noto-sans-jp {
  font-family: "Noto Sans JP";
}

.outfit {
  font-family: "Outfit";
}

.btn-a {
  max-width: 300px;
  margin: 4rem auto 0;
}

.btn-a a {
  font-size: 1.8rem;
  color: #fff;
  padding: .5rem;
  text-align: center;
  display: block;
  width: 100%;
}

/*===========
font-size
=============*/
.font-size-10 {
  font-size: 1.0rem;
}

.font-size-12 {
  font-size: 1.2rem;
}

.font-size-14 {
  font-size: 1.4rem;
}

.font-size-16 {
  font-size: 1.6rem;
}

.font-size-18 {
  font-size: 1.8rem;
}

.font-size-22 {
  font-size: 2.2rem;
}

.font-size-26 {
  font-size: 2.6rem;
}

.font-size-40 {
  font-size: 4.0rem;
}

@media screen and (max-width: 540px) {
  .font-size-10 {
    font-size: 2.66667vw;
  }
  .font-size-12 {
    font-size: 2.93333vw;
  }
  .font-size-14 {
    font-size: 3.46667vw;
  }
  .font-size-16 {
    font-size: 4vw;
  }
  .font-size-18 {
    font-size: 4.53333vw;
  }
  .font-size-22 {
    font-size: 5vw;
  }
  .font-size-26 {
    font-size: 5.86667vw;
  }
  .font-size-40 {
    font-size: 7.46667vw;
  }
  .sp-font-size-13 {
    font-size: 3.46667vw;
  }
}

/*===========
main contents ベーシック設定
=============*/
.container {
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
}

.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.flex-between {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.flex-center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.flex-end {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

.flex-align-center {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.flex-align-start {
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.flex-direction-col {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.col-01 {
  width: 100%;
}

.col-02 {
  width: 48%;
  margin-bottom: 4rem;
}

.col-03 {
  width: 32.3%;
  margin-bottom: 4rem;
}

.col-04 {
  width: 23.6%;
}

.col-02-08 {
  width: 78%;
}

.col-02-06 {
  width: 67%;
}

.col-02-04 {
  width: 30%;
}

.col-02-02 {
  width: 18%;
}

.col01-box {
  padding: 4rem 8rem;
}

.col01-box .col-02 {
  margin-bottom: 0;
}

.col01-box .col-02 h3 {
  margin-bottom: 1.5rem;
}

.col01-box.bg-purple {
  margin-top: 5rem;
  color: #fff;
}

.col01-box.bg-purple .btns .btn {
  color: #0B0B10;
  border: 1px solid #fff;
  background-color: #fff;
  transition: all .3s;
}

.col01-box.bg-purple .btns .btn:after {
  border-top: 2px solid #0B0B10;
  border-right: 2px solid #0B0B10;
}

.col01-box.bg-purple:hover .btns .btn {
  color: #fff;
  background-color: transparent;
}

.col01-box.bg-purple:hover .btns .btn:after {
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
}

.list-circle-purple li:before {
  content: "";
  background-image: url("../img/common/icon-arrow-purple.svg");
  display: inline-block;
  width: 20px;
  height: 20px;
  position: relative;
  top: 4px;
  margin-right: 1rem;
}

.box {
  padding: 3rem;
}

.box li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 1.3rem 0;
  border-bottom: 1px solid #ccc;
}

.box li:last-child {
  border-bottom: 0px;
}

.icon-pdf {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-right: 1rem;
}

.section {
  padding: 8rem 0;
}

.section .title-top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  line-height: 1;
  margin-bottom: 3rem;
}

.section .title-top .title {
  color: #574B9C;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

.section .title-top h2 {
  font-weight: 400;
  color: #574B9C;
  margin-left: 1rem;
  margin-bottom: 0.3rem;
}

.section .title-top .rss {
  color: #fff;
  background-color: #0B0B10;
  padding: .5rem 2rem;
  border-radius: 30px;
}

.section .title-top .rss svg {
  margin-right: .5rem;
}

.style-section {
  padding: 8rem 0 4rem;
}

.lead-section {
  padding: 3rem 0 0;
}

.flex-cardbox a .img {
	position: relative;
}

.flex-cardbox a .img img {
	width: 100%;
}

.flex-cardbox a .img::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	background-color: rgba(87, 75, 156, 0);
	transition: all .3s;
}

.flex-cardbox a:hover .img::before {
	background-color: rgba(87, 75, 156, .3);
}

.flex-cardbox .page-next {
  color: #574B9C;
  background-color: #fff;
  padding: 1rem;
  position: relative;
  -webkit-transition: all .3s;
  transition: all .3s;
}

.flex-cardbox .page-next .arrow {
  position: absolute;
  top: 0;
  right: 0;
  width: 56px;
  height: 100%;
  background-color: #574B9C;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.flex-cardbox a:hover .page-next {
  color: #fff;
  background-color: #574B9C;
}

.flex-cardbox a:hover .arrow {
  background-color: #fff;
}

.flex-cardbox a:hover .arrow svg path {
  stroke: #574B9C;
}

.flex-cardbox-white .page-next {
  font-weight: 300;
  color: #fff;
  padding: 1rem;
  position: relative;
}

.flex-cardbox-white .page-next span {
  width: 100%;
}

.flex-cardbox-white .page-next .arrow {
  position: absolute;
  top: 0;
  right: 0;
  width: 56px;
  height: 100%;
  background-color: #574B9C;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.flex-cardbox-basic-02 .img {
  margin-bottom: 1.5rem;
}

.flex-cardbox-basic-02:after {
  content: "";
  display: block;
  width: 32.3%;
}

.flex-cardbox-basic-02 .col-01 {
  margin-bottom: 6rem;
}

.flex-cardbox-basic-02 .col-01 .list-circle-purple {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.flex-cardbox-basic-02 .col-01 .list-circle-purple li {
  width: 25%;
}

.flex-cardbox-basic-02 .col-03 {
  margin-bottom: 6rem;
}

.flex-cardbox-basic-02 .list-circle-purple li {
  margin-bottom: .5rem;
}

.flex-cardbox-basic-03 .col-03 {
  margin-bottom: 0;
}

.flex-cardbox-basic-03 .btns {
  margin-top: 0;
  margin-bottom: 2.5rem;
}

.flex-cardbox-basic-03 .btns .btn {
  height: 100px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 1rem 2rem;
  height: 100px;
}

.flex-cardbox-basic-03 .btns .text-align-left {
  text-align: left !important;
}

/*================
NEWSコンテンツ
==================*/
.news-section {
	padding: 9rem 0 8rem;
}
.news-tab-group {
  margin-top: 20px;
  list-style: none;
  text-align: center;
  width: 100%;
}

.news-tab-group .tab-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  list-style: none;
  cursor: pointer;
  margin-bottom: 1.5rem;
}

.news-tab-group .tab-button .is-active {
  background: #574B9C;
  color: #FFF;
  border: 1px solid #574B9C;
}

.news-tab-group .tab {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  border-right: 1px solid #CCCCCC;
  padding: 8px;
  border-bottom: none;
}

.news-tab-group .tab:last-child {
  border-right: 0px;
}

.news-tab-group .tab-contents {
  border-top: none;
}

.news-tab-group .tab-contents dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 2.7rem 0;
  border-bottom: 1px solid #CCCCCC;
  font-weight: 400;
  position: relative;
}

.news-tab-group .tab-contents dl .info {
  padding: 0 2rem;
}

.news-tab-group .tab-contents dl .info span {
  font-weight: 300;
}

.news-tab-group .tab-contents dl .info .date {
  margin-right: 1rem;
}

.news-tab-group .tab-contents dl .info .category {
  display: inline-block;
  width: 150px;
  text-align: center;
}

.news-tab-group .tab-contents dl dd {
  position: relative;
  display: flex;
}

.news-tab-group .tab-contents dl dd a {
  position: relative;
  width: 100%;
}

.news-tab-group .tab-contents dl dd img {
}

.news-tab-group .tab-contents dl .arrow {
  position: absolute;
  right: 0;
}

.news-tab-group .tab-content {
  display: none;
  text-align: left;
  border-top: 1px solid #ccc;
}

.news-tab-group .tab-content.is-display {
  display: block;
}

.mv {
  background-size: cover;
  background-position: center;
  position: relative;
}

.mv-second-layer {
  background-size: cover;
  background-position: center;
  position: relative;
  height: 500px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.mv-second-layer h1 {
  font-weight: 400;
  display: inline-block;
  color: #fff;
  background-color: rgba(11, 11, 16, 0.8);
  padding: 7rem 2rem;
  width: 524px;
}

#mv-ir {
  background-image: url("../img/ir/mv.jpg");
}

#mv-sustainability {
  background-image: url("../img/sustainability/mv.jpg");
}

/*===========
header
=============*/
.header {
  position: fixed;
  width: 100%;
  z-index: 10;
  background-color: #fff;
  border-bottom: 1px solid #ccc;
  height: 102px;
}

.header .header-container {
  max-width: 1280px;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 1rem 0;
}

.menu-container .sub-menu-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-bottom: 1.5rem;
}

.menu-container .sub-menu-container .switchFont {
  font-size: 1.2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-right: 3rem;
}

.menu-container .sub-menu-container #switchFontSize {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.menu-container .sub-menu-container #switchFontSize li {
  width: 30px;
  height: 30px;
  background-color: #F0F2F5;
  border: 1px solid #CCCCCC;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  cursor: pointer;
}

.menu-container .sub-menu-container #switchFontSize li:first-child {
  margin-left: 1rem;
}

.menu-container .sub-menu-container #switchFontSize #fontS {
  font-size: 1.2rem;
}

.menu-container .sub-menu-container #switchFontSize #fontM {
  font-size: 1.5rem;
}

.menu-container .sub-menu-container #switchFontSize #fontL {
  font-size: 1.8rem;
}

.menu-container .sub-menu-container #switchFontSize .active {
  color: #fff;
  background-color: #574B9C;
  border: 1px solid #574B9C;
}

.menu-container .sub-menu-container .submenu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.menu-container .sub-menu-container .submenu ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.menu-container .sub-menu-container .submenu ul li {
  padding: 0 1.2rem;
  border-right: 1px solid #CCCCCC;
}

.menu-container .sub-menu-container .submenu .print {
  margin-left: 3rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.menu-container .sub-menu-container .submenu .print-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #F0F2F5;
  padding: 0.3rem 1rem;
  margin-right: 1.5rem;
}

.menu-container .sub-menu-container .submenu .print-link img {
  margin-right: .5rem;
}

.menu .menu_list {
  margin-left: 1.6rem;
}

.menu .menu_list:first-child {
  margin-left: 0;
}

.menu .menu_list > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}

.menu .menu_list > a span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-left: .5rem;
}

.menu .menu_list > a span img {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.menu .menu_list > a:hover span img {
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
}

.menu .menu_list > a:hover:after {
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}

.menu .menu_list > a:after {
  position: absolute;
  left: 0;
  content: '';
  width: 100%;
  height: 5px;
  background: #352977;
  bottom: -16px;
  -webkit-transform: scale(0, 1);
  transform: scale(0, 1);
  -webkit-transform-origin: right top;
  transform-origin: right top;
  -webkit-transition: -webkit-transform 0.3s;
  transition: -webkit-transform 0.3s;
  transition: transform 0.3s;
  transition: transform 0.3s, -webkit-transform 0.3s;
}

.mgzine_list > a {
  color: #574B9C;
  border: 1px solid #574B9C;
  padding: .3rem 1rem;
}

.mgzine_list > a:hover:after {
  content: none;
}

.menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.menu_contents {
  background: #574B9C;
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  padding: 2rem 0 4rem;
}

.menu_contents .menu_title h3 {
  color: #fff;
  margin-bottom: 3rem;
}

.menu_contents .menu_title a {
  width: 300px;
  text-align: center;
  display: block;
  color: #fff;
  border: 1px solid #fff;
  padding: .5rem 0;
}

.menu_contents .menu_title .mgzine_list-link {
  color: #fff;
  border: 1px solid #fff;
}

.menu_contents .second-layer {
  margin-top: 7.3rem;
  margin-left: 1rem;
}

.menu_contents .second-layer > li > a {
  width: 300px;
  font-weight: 300;
  display: block;
  padding: 1rem;
  position: relative;
}

.menu_contents .second-layer > li > a svg {
  position: absolute;
  right: 2rem;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.menu_contents .second-layer > li > a:hover {
  color: #574B9C;
  background-color: #F0F2F5;
}

.menu_contents .second-layer > li > a:hover svg path {
  stroke: #574B9C;
}

.menu_contents .third-layer {
  position: absolute;
  top: 0;
  -webkit-transition: all 0.5s 0s ease;
  transition: all 0.5s 0s ease;
  display: none;
  -webkit-transform: translateX(300px);
          transform: translateX(300px);
  width: 100%;
  height: 100%;
  background-color: #F0F2F5;
  padding-top: 9.3rem;
}

.menu_contents .third-layer ul li a {
  color: #574B9C;
  padding: 1rem 4rem;
  display: block;
}

.menu_contents .third-layer.active-contents {
  display: block;
}

.menu_contents li {
  width: 100%;
}

.menu_contents li a {
  color: #fff;
}

.breadcrumb {
  padding: 1.2rem 0;
}

.breadcrumb ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.breadcrumb ul li {
  margin-right: 1rem;
}

.breadcrumb ul li a {
  text-decoration: underline;
}

.breadcrumb ul li svg {
  position: relative;
  top: 3px;
}

.breadcrumb ul li:after {
  font-size: 1.4rem;
  content: "＞";
  padding-left: 1rem;
}

.breadcrumb ul li:last-child:after {
  content: none;
}

/*===========
footer
=============*/
footer .footer-upper {
  font-weight: 300;
  padding: 6rem 0;
  background-color: #585860;
}

footer .footer-upper h5 {
  margin-bottom: .8rem;
}

footer .footer-upper h5:before {
  content: "";
  background-image: url("../img/common/icon-footer-arrow.svg");
  width: 5px;
  height: 10px;
  display: inline-block;
  margin-right: 1rem;
}

footer .footer-upper ul li {
  margin-bottom: .8rem;
}

footer .footer-upper ul li:before {
  content: "";
  background-image: url("../img/common/icon-footer-arrow.svg");
  width: 5px;
  height: 10px;
  display: inline-block;
  margin-right: 1rem;
}

footer .footer-upper a {
  color: #fff;
}

footer .footer-upper .w100 {
  width: 100%;
  margin-bottom: 3.5rem;
}

footer .footer-middle {
  background-color: #0B0B10;
  padding: 4rem 0;
}

footer .footer-middle ul li {
  margin-right: 3rem;
  font-weight: 300;
}

footer .footer-middle ul li:before {
  content: "";
  background-image: url("../img/common/icon-footer-arrow.svg");
  width: 5px;
  height: 10px;
  display: inline-block;
  margin-right: 1rem;
}

footer .footer-middle a {
  color: #fff;
}

footer .footer-bottom {
  padding: 1rem 0;
}

footer .footer-bottom ul {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

footer .footer-bottom ul li {
  margin-left: 2rem;
}

footer .footer-bottom ul li img {
  width: 70px;
}

footer .mg-link-btn {
  border: 1px solid #fff;
  text-align: center;
  position: relative;
  margin-bottom: 1.2rem !important;
}

footer .mg-link-btn:before {
  content: none !important;
}

.magazine h3 {
  margin-top: 1rem;
  font-weight: 300;
}

.magazine .col-03 a {
  display: block;
}

.magazine .container:after {
	content: "";
	width: 32.3%;
}

.magazine .thumbnail {
  margin-bottom: 1rem;
  overflow: hidden;
}

.magazine .col-03 a .thumbnail img {
  transition: all .3s;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.magazine .col-03 a:hover .thumbnail img {
  transform: scale(1.2);
}

.magazine .catetory {
  padding: .3rem 1.5rem;
}

.magazine .cat-women, .magazine .cat-newgrad, .magazine .cat-aftergrad {
  color: #E77519;
  background-color: rgba(231, 117, 25, 0.1);
}

.magazine .cat-life, .magazine .cat-trend, .magazine .cat-technology, .magazine .cat-engineer {
  color: #574B9C;
  background-color: rgba(87, 75, 156, 0.1);
}

.magazine .date {
  font-family: "Outfit";
}

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

@media screen and (min-width: 1161px) {
  .change-browser-sp {
    display: none !important;
  }
  .hamburger {
    display: none;
  }
}

@media screen and (max-width: 1160px) {
  .change-browser {
    display: none;
  }
  /*===========
  header ベーシック設定
  =============*/
  .header {
    height: auto;
  }
  .header .header-container {
    padding: 1.5rem 2rem;
  }
  .header .logo img {
    width: 140px;
  }
  main {
    padding-top: 68px !important;
  }
  .breadcrumb {
	padding: 1.2rem 2rem;
  }
}

@media screen and (max-width: 760px) {
  .pc {
    display: none !important;
  }
  /*===========
  main contents ベーシック設定
  =============*/
  .col-02 {
    width: 100%;
    margin-bottom: 4rem;
  }
  .col-03 {
    width: 100%;
    margin-bottom: 4rem;
  }
  .col-04 {
    width: 100%;
    margin-bottom: 3rem;
  }
  .col-02-08 {
    width: 100%;
    margin-bottom: 4rem;
  }
  .col-02-06 {
    width: 100%;
    margin-bottom: 4rem;
  }
  .col-02-04 {
    width: 100%;
  }
  .col-02-02 {
    width: 100%;
  }
  .breadcrumb {
    padding: 1.2rem 5.33333vw;
  }
  .img-h-400 {
    height: auto;
  }
  .img-h-400 img {
    height: auto;
  }
  .col01-box {
    padding: 4rem 2rem;
  }
  .col01-box .col-02 h3 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .flex-cardbox .page-next {
    color: #fff;
    background-color: #574B9C;
  }
  .flex-cardbox .page-next .arrow {
    background-color: #fff;
  }
  .flex-cardbox .page-next .arrow svg path {
    stroke: #574B9C;
  }
  .list-circle-purple li a {
    color: #574B9C;
    text-decoration: underline;
  }
  .section {
    padding: 6rem 5.33333vw;
  }
  .section h2 {
    text-align: center;
    font-weight: 400;
  }
  .section .title-top {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    position: relative;
  }
  .section .title-top .title {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .section .title-top .title h2 {
    color: #0B0B10;
    margin-top: .5rem;
    margin-left: 0;
    margin-bottom: 0;
    font-size: 1.3rem;
  }
  .section .title-top .rss {
    position: absolute;
    right: 0;
    bottom: 0;
  }
  .section .title-top .rss svg {
	width: 14px;
    position: relative;
    top: 1px;
  }
  .lead-section {
    padding: 6rem 5.33333vw 0;
  }
  .flex-cardbox-basic-02 .col-01 .list-circle-purple li {
    width: 100%;
  }
  .box {
    padding: 3rem 2rem;
  }
  .news-section .accordion-container {
    margin: 0 auto;
    max-width: 100%;
    width: 100%;
  }
  .news-section .accordion-title {
    cursor: pointer;
    font-weight: 500;
    padding: 1.5rem 1rem;
    position: relative;
    color: #574B9C;
    border-bottom: 2px solid #574B9C;
  }
  .news-section .accordion-title.open {
    color: #fff;
    background-color: #574B9C;
  }
  .news-section .accordion-title.open:after {
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
  }
  .news-section .accordion-title:after {
    position: absolute;
    display: block;
    content: '';
    top: 35%;
    right: 22px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #000;
    border-right: 2px solid #000;
    -webkit-transform: rotate(135deg);
            transform: rotate(135deg);
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
  }
  .news-section .accordion-title.open:after {
    -webkit-transform: rotate(-45deg);
            transform: rotate(-45deg);
    top: 45%;
  }
  .news-section .accordion-text {
    display: none;
  }
  .news-section .accordion-text ul li {
    padding: 1.5rem 5.5rem 1.5rem 1rem;
    position: relative;
    border-bottom: 1px solid #ccc;
  }
  .news-section .accordion-text .info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
  .news-section .accordion-text .info .date {
    font-size: 1.3rem;
    margin-right: 2rem;
  }
  .news-section .accordion-text .info .category {
    font-size: 1.3rem;
    padding: .3rem 0;
    display: block;
    width: 140px;
    text-align: center;
  }
  .news-section .accordion-text p {
    margin-top: 1rem;
  }
  .news-section .arrow {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    right: 2rem;
  }
  .pickup-section .col-04 {
    width: 100%;
    margin-bottom: 2rem;
  }
  .pickup-section .mt-05 {
	  margin-top: 0;
  }
  .pickup-section .mt-05 .col-02 {
	  margin-bottom: 0;
  }
  .about-section .bg-light-gray {
    height: 400px;
  }
  .about-section .container-center {
    height: 100%;
  }
  .about-section .container-center .content {
    text-align: center;
  }
  .about-section .col-03 {
    width: 100%;
    margin-bottom: 1rem;
  }
  .about-section {
	padding: 6rem 5.33333vw 2rem;
  }
  .magazine .col-03 {
    width: 100%;
    margin-bottom: 2rem;
  }
  .magazine .col-03 a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
  .magazine .col-03 a .thumbnail {
    width: 48%;
  }
  .magazine .col-03 a .thumbnail img {
    width: 100%;
    height: 120px;
    -o-object-fit: cover;
       object-fit: cover;
  }
  .magazine .col-03 a .text {
    width: 48%;
  }
  .magazine .btns .btn {
    max-width: 80%;
    margin: 0 auto;
  }
  .magazine .col-03 a {
	display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
  .flex-cardbox-basic-03 {
    padding: 0 5.33333vw 6rem;
  }
  .flex-cardbox-basic-03 .btns {
    margin-top: 0;
  }
  .flex-cardbox-basic-03 .col-03 {
    margin-bottom: 1rem;
  }
  .mt-042 {
	margin-top: 0;
  }
  .mt-04 {
	margin-top: 0;
  }
  .flex-cardbox .page-next .arrow {
	  width: 30px;
  }
  .flex-cardbox .page-next .arrow svg {
	  width: 8px;
  }
  .flex-cardbox .page-next .arrow svg path {
	  stroke-width: 2px;
  }
  .flex-cardbox-basic-02 .col-03 {
	  margin-bottom: 3rem;
  }
  .flex-cardbox-basic-02 .col-03:last-child {
	  margin-bottom: 0;
  }
  .flex-cardbox-basic-03 .btns .btn {
	  height: auto;
  }
  /*===========
  footer
  =============*/
  footer .mt-03 {
    margin-top: 0;
  }
  footer .sp-col-02 {
    width: 48%;
  }
  footer .sp-col-01 {
    width: 100%;
  }
  footer .footer-upper {
    padding: 6rem 5.33333vw;
  }
  footer .footer-upper .w100 {
    margin-bottom: 0;
  }
  footer .footer-upper h5 {
    font-weight: 400;
    border-bottom: 1px solid #fff;
    margin-bottom: 0;
    padding: 1.5rem 1rem;
    position: relative;
  }
  footer .footer-upper h5:after {
    position: absolute;
    display: block;
    content: '';
    top: 45%;
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
    right: 22px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #ffffff;
    border-right: 2px solid #ffffff;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
  }
  footer .footer-upper h5:before {
    content: none;
  }
  footer .footer-upper .col-05 {
    width: 100%;
  }
  footer .footer-upper .col-05 ul {
    display: none;
  }
  footer .footer-upper .mg-link-btn {
	margin-top: 3rem;
  }
  footer .footer-middle {
    padding: 4rem 5.33333vw;
  }
  footer .footer-middle ul li {
    margin-right: 0;
    margin-bottom: 2.5rem;
  }
  footer .footer-middle ul li:last-child {
    margin-bottom: 0;
  }
  footer .footer-bottom {
    padding: 2rem 5.33333vw;
  }
  footer .footer-bottom .container {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }
  footer .footer-bottom ul {
    margin-bottom: 2rem;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: 100%;
  }
  footer .footer-bottom ul li {
    margin-left: 0;
  }
}

@media screen and (max-width: 540px) {
  body {
    font-size: 4vw;
  }
  p {
    font-size: 3.73333vw;
  }
  .section p {
	  font-size: 3.73333vw;
  }
  .ir-info {
	  font-size: 3.73333vw;
  }
  .breadcrumb {
    font-size: 2.93333vw;
  }
  .section .title-top .title h2 {
    font-size: 3.46667vw;
  }
  .main-second .section .title-top .title h2 {
    font-size: 5.33333vw;
  }
  .mv-second-layer {
    height: 200px;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
  }
  .mv-second-layer h1 {
    font-size: 5.33333vw;
    width: 92%;
    display: block;
    margin: 0 auto;
    padding: 1.5rem 2rem;
    -webkit-transform: translateY(50%);
            transform: translateY(50%);
  }
  
  .btns .btn {
	font-size: 3.53333vw;
  }
  .flex-cardbox .page-next {
	font-size: 4vw;
  }
  footer .footer-upper {
	padding: 4rem 5.33333vw;
  }
  footer .footer-upper h5 {
	font-size: 4vw;
  }
  .box-purple a {
	  
  }
}

.header_nav_sp {
  position: absolute;
  right: 0;
  left: 0;
  top: 0;
  width: 100%;
  height: 100vh;
  -webkit-transform: translateX(100%);
          transform: translateX(100%);
  -webkit-transition: ease .4s;
  transition: ease .4s;
}

.header_nav_sp .nav-items {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  padding: 0;
}

.header_nav_sp .container-hum {
  background-color: #574B9C;
  height: 100%;
  margin-top: 7rem;
  padding: 2rem;
  overflow-y: scroll;
}

.header_nav_sp .container-hum .flex {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.header_nav_sp .container-hum .flex .col-02 {
  width: 48%;
  margin-bottom: 2rem;
}

.header_nav_sp .container-hum .flex .col-02 a {
  font-size: 3.4vw;
  display: block;
  text-align: center;
  color: #fff;
  padding: 1.5rem 1rem;
  border: 1px solid #fff;
  position: relative;
}

.header_nav_sp .container-hum .flex .col-02 a::after {
	position: absolute;
    display: block;
    content: '';
    top: 44%;
    right: 18px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    -webkit-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
}

.header_nav_sp .container-hum .accordion-container {
  margin: 2rem 0 10rem;
  max-width: 100%;
  width: 100%;
}

.header_nav_sp .container-hum .accordion-list:not(:first-child) {
  margin-top: 10px;
}

.header_nav_sp .container-hum .accordion-title {
  cursor: pointer;
  color: #fff;
  padding: 1.5rem 1rem;
  position: relative;
  border-bottom: 1px solid #fff;
}

.header_nav_sp .container-hum .accordion-title:after {
  position: absolute;
  display: block;
  content: '';
  top: 35%;
  right: 22px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  -webkit-transform: rotate(135deg);
          transform: rotate(135deg);
  -webkit-transition: all .3s ease-in-out;
  transition: all .3s ease-in-out;
}

.header_nav_sp .container-hum .accordion-title.open:after {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  top: 45%;
  right: 18px;
}

.header_nav_sp .container-hum .accordion-text {
  display: none;
}

.header_nav_sp .container-hum .accordion-text ul li {
  border-bottom: 1px solid #574B9C;
}

.header_nav_sp .container-hum .accordion-text ul li a {
  font-weight: 500;
  color: #574B9C;
  background-color: #F0F2F5;
  display: block;
  padding: 1.5rem 1rem 1.5rem 3rem;
  position: relative;
}

.header_nav_sp .container-hum .accordion-text ul li a:after {
  position: absolute;
  display: block;
  content: '';
  top: 50%;
  right: 22px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #574B9C;
  border-right: 2px solid #574B9C;
  -webkit-transform: rotate(45deg) translateY(-50%);
          transform: rotate(45deg) translateY(-50%);
  -webkit-transition: all .3s ease-in-out;
  transition: all .3s ease-in-out;
}

.header_nav_sp .container-hum .accordion-text ul .layer-btn > a:after {
  -webkit-transform: rotate(135deg);
          transform: rotate(135deg);
  top: 45%;
  right: 18px;
}

.header_nav_sp .container-hum .accordion-text ul .layer-btn .open:after {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  top: 45%;
}

.header_nav_sp .container-hum .accordion-text ul .layer-btn .third-layer-sp li a {
  font-weight: 300;
  padding: 1.5rem 1rem 1.5rem 4rem;
}

.header_nav_sp .container-hum .accordion-text ul .layer-btn .third-layer-sp li a:after {
  border-top: 1px solid #574B9C;
  border-right: 1px solid #574B9C;
}

.header_nav_sp .container-hum .accordion-text .third-layer-sp {
  display: none;
}

.header_nav_sp .container-hum .accordion-text .third-layer-sp li a {
	background-color: #fff;
}

.header_nav_sp .container-hum .accordion-text .third-layer-sp li:first-child {
	border-top: 1px solid #574B9C;
}

.header__hamburger {
  width: 60px;
}

.hamburger {
  background-color: transparent;
  border-color: transparent;
  z-index: 9999;
  position: absolute;
  right: .5rem;
  top: 1.3rem;
}

.hamburger span {
  width: 100%;
  height: 3px;
  background-color: #574B9C;
  position: relative;
  -webkit-transition: ease .4s;
  transition: ease .4s;
  display: block;
  width: 70%;
  margin: 0 auto;
}

.hamburger div {
  color: #0B0B10;
  margin-top: 1rem;
}

.icon-search {
  position: absolute;
  right: 7rem;
}

.icon-search a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.icon-search a span {
  margin-top: 1px;
}

.hamburger span:nth-child(1) {
  top: 0;
}

.hamburger span:nth-child(2) {
  margin: 6px auto;
}

.hamburger span:nth-child(3) {
  top: 0;
}

/* ハンバーガーメニュークリック後のスタイル */
.header_nav_sp.active {
  -webkit-transform: translateX(0);
          transform: translateX(0);
}

.hamburger.active span:nth-child(1) {
  top: 8px;
  -webkit-transform: rotate(35deg);
          transform: rotate(35deg);
}

.hamburger.active span:nth-child(2) {
  opacity: 0;
}

.hamburger.active span:nth-child(3) {
  top: -10px;
  -webkit-transform: rotate(-35deg);
          transform: rotate(-35deg);
}

@media screen and (min-width: 541px) and (max-width: 760px) {
  .about-section .bg-light-gray {
    height: auto;
  }
}

@media screen and (min-width: 761px) and (max-width: 1280px) {
  .header {
    padding: 0 3rem;
  }
  .section {
    padding: 8rem 3rem;
  }
  .about-section .container-center .content {
    padding-left: 2rem;
  }
  footer .footer-upper {
    padding: 6rem 3rem;
  }
  footer .footer-upper .col-05 {
    margin-bottom: 3rem;
  }
  footer .footer-upper .flex-between {
    gap: 50px;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  footer .footer-middle {
    padding: 4rem 3rem;
  }
  footer .footer-bottom {
    padding: 1rem 3rem;
  }
  .lead-section {
    padding: 3rem 3rem 0;
  }
  .breadcrumb {
	    padding: 1.2rem 2rem;
	}
}
@media screen and (max-width: 760px) {
	.magazine {
		padding: 6rem 5.33333vw 2rem;
	}
	.magazine .btns {
		margin-top: 0;
	}
}
@media screen and (max-width: 540px) {
  .accordion-text .info .date {
    font-size: 3.46667vw;
  }
  .accordion-text .info .category {
    font-size: 3.46667vw;
  }
  .magazine .col-03 a .text {
    font-size: 4vw;
  }
  .magazine .catetory {
    display: block;
    width: 100%;
    text-align: center;
  }
  .magazine h3 {
    font-size: 4vw;
  }
}
/*# sourceMappingURL=style.css.map */