/* other.css */

/*----------------------------------
Common
------------------------------------*/

.inner {
    width: calc(100% - 40px);
    max-width: 1120px;
    min-width: 1000px;
    margin: 0 auto;
}

/*----------------------------------
Title
------------------------------------*/
.sec__ti--01 {
margin-bottom: 24px;
overflow: hidden;
overflow: hidden;
padding-bottom: 12px;
border-bottom: solid 1px #445479;
position: relative;
line-height: 1em;
}
.sec__ti--01__inner {
display: inline-block;
font-size: var(--font-h2);
font-weight: bold;
padding-left:28px;
position: relative;
}
.sec__ti--01__inner::before {
content: "";
display: block;
width: 16px;
height: 6px;
border-radius: 3px;
background: var(--color1);
position: absolute;
left: 0px;
top: 18px;
margin-top: -3px;
}


.sec__ti--02 {
font-size: 28px;
margin-bottom: 1.5em;
}
.sec__ti--02 p {
font-weight: bold;
margin-bottom: 0px !important;
}
.sec__ti--02__inner {
display: inline-block;
font-weight: bold;
line-height: 1.2em;
}
.sec__ti--02__info--under {
font-size: 12px;
line-height: 1em;
margin-top: 7px;
}

/*冊子・副読本等*/
.block-section .sec__ti--02__sub {
font-weight: normal !important;
font-size: 0.75em;
line-height: 1.2em !important;
}

.ct2--pack-cate {
display: inline-block;
font-weight: bold;
vertical-align: middle;
margin-right: 2em;
padding-left: 1em;
position: relative;
}
.ct2--pack-cate::before {
content: "";
display: block;
width: 8px;
height: 8px;
background: #000;
position: absolute;
left: 0px;
top: 50%;
margin-top: -3px;
}
.pack-l-insight::before {
background: #B78F46 !important;
}
.pack-ti-fris::before {
background: #C4D700 !important;
}
.pack-hiraku-global::before {
background: #F39600 !important;
}
.pack-tristar::before {
background: #4F9BC7 !important;
}
.pack-t-gex::before {
background: #1A9598 !important;
}
.pack-sogo::before {
background: #555 !important;
}


.ct2--for-cate {
display: inline-block;
font-weight: bold;
vertical-align: middle;
padding-left: 1em;
position: relative;
}
.ct2--for-cate::before {
content: "";
display: block;
width: 8px;
height: 8px;
background: #000;
position: absolute;
left: 0px;
top: 50%;
margin-top: -3px;
}
.for-


.sec__ti--03 {
font-size: 28px;
font-weight: bold;
margin-bottom: 1em;
text-align: center;
}

.sec__ti--04 {
font-size: 28px;
margin-bottom: 48px;
}
.sec__ti--04__inner {
display: inline-block;
font-weight: bold;
line-height: 1.2em;
}
.sec__ti--04__info--under {
width: 100%;
}
.ct4-cate__list {
font-size: 16px;
}
.ct4-cate__item {
display: inline-block;
margin-right: 0.5em;
}
.ct4-cate__item a {
display: inline-block;
margin-top: 0.5em;
padding: 0.3em 0.5em 0.5em 0.5em;
line-height: 1em;
background: #EEEEEE;
border: solid 1px #000;
border-radius: 0.9em;
}

/*コラム内タイトル1*/
.clm__ti--01 {
font-size: var(--font-h3);
color: var(--color2);
margin-bottom: 12px;
padding-bottom: 12px;
padding-left: 28px;
border-bottom: solid 1px #445479;
position: relative;
}
.clm__ti--01__inner {
display: inline-block;
font-weight: bold;
line-height: 1.2em;
}
.clm__ti--01::before {
content: "";
width: 16px;
height: 6px;
border-radius: 3px;
background: var(--color2);
position: absolute;
left: 0px;
top: 50%;
margin-top: -8px;
}

/*.clm__ti--01 .event-cate {
display: inline-block;
vertical-align: middle;
font-size: 10px;
margin-right: 1em;
}
.clm__ti--01 .event-cate span {
display: inline-block;
line-height: 1em;
color: #fff;
background: #000;
margin-top: -8px;
padding: 3px 4px;
vertical-align: middle;
}*/

/*コラム内タイトル3*/
.clm__ti--03 {
position: relative;
margin-bottom: 24px;
padding-bottom: 12px;
border-bottom: solid 1px #BBCDE2;
}
.clm__ti--03--main {
font-size: var(--font-h3);
font-weight: bold;
}
.clm__ti--03--sub {
font-size: 14px;
line-height: 1.6em;
margin-top: 4px;
}
.clm__ti--03--18 {
font-size: 18px;
}
.clm__ti--03--18__inner {
font-weight: bold;
line-height: 1.2em;
}



.event-material__list {
display: flex;
column-gap: 4px;
row-gap:4px;
}
.event-material__item {
width: 100%;
}
.event-material__item a {
display: block;
text-align: center;
border: solid 1px rgba(148, 148, 148, 1);
border-radius: 4px;
font-size: 10px;
vertical-align: middle;
padding: 1em 0px;
text-decoration: none !important;
transition: all 0.2s;
}
.event-material__item a:hover {
background: #272727;
color: #fff;
}

.event-material__item img {
width: 28px;
height: 31px;
vertical-align: middle;
margin-right: 0.5em;
}

/*----------------------------------
Main
------------------------------------*/

.o_top_wrap {
background: url("/wp-content/themes/ResearcherPlus/img/other/img-main-pc-under@2x.jpg") right top /cover no-repeat;
position: relative;
}

.o_top .inner{
    padding: 89px 0 97px;
				min-width: inherit;
}

.o_top h1 {
    font-size: var(--font-h1);
    font-weight: 700;
    position: relative;
    line-height: 1.2;
}

/*----------------------------------
Bread
------------------------------------*/
.bread {
				background: #333;
}
.bread .inner {
    width: calc(100% - 40px);
				min-width: inherit;
    max-width: 1120px;
    margin: 0 auto;
    padding: 8px 0px;
				color: #fff;
    font-size: var(--font-h6);
}

.bread a,
.bread span {
display: inline-block;
color: #fff;
}

.bread a {
text-decoration: underline;
}
.bread a:hover {
text-decoration: none;
}

.bread--gt {
margin: 0px 1em;
}

/*----------------------------------
List
------------------------------------*/
/*共通リスト1（GP、GPレポート）*/
.img__list {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
row-gap:48px;
margin-bottom: 52px;
}
.img__item {
position: relative;
padding-bottom: 25px;
}
.img__list--2col .img__item {
width: calc((100% - 36px) / 2);
}
.img__list--3col .img__item {
width: calc((100% - 20px) / 3);
}
.img__item--img {
height: 0px;
padding-top: 56.25%;
text-indent: 100%;
white-space: nowrap;
overflow: hidden;
border-radius: var(--radius-16);
margin-bottom: 16px;
/*border: solid 1px #ccc;*/
position: relative;
}
.img__item--img span {
display: block;
width: 100%;
height: 0px;
padding-top: 56.8%;
position: absolute;
top: 0px;
left: 0px;
transition: all 0.2s;
}
.img__item a:hover .img__item--img span {
transform: scale(1.05);
}

.img__item--ti {
font-size: 16px;
font-weight: bold;
margin-bottom: 8px;
}
.img__item--txt {
font-size: 14px;
margin-bottom: 16px;
line-height: 1.8em;
}

/*共通リスト2（イベント、副読本）*/
.cmn1__item {
width: 100%;
}
.cmn1__item:not(:last-child) {
margin-bottom: 84px;
}

.book__list .cmn1__item:not(:last-child) {
margin-bottom: 68px;
}



/*----------------------------------
リンクボタンリスト
------------------------------------*/
.link__list--anc01 {
display: flex;
justify-content: center;
flex-wrap: wrap;
column-gap: 20px;
row-gap: 20px;
font-size: var(--font-h4);
margin-bottom: 80px;
}
.link-item {
width: 360px;
}
.link-item a {
display: block;
width: 22em;
height: 56px;
line-height: 56px;
padding: 0px 3.5em 0px 32px;
border-radius: 28px;
position: relative;
text-decoration: none !important;
font-weight: bold;
background: var(--color5);
transition: all 0.2s;
}
.link-item a:hover {
opacity: 0.7;
}
.link-item--anc01 a::before {
content: "";
display: block;
width: 32px;
height: 32px;
border-radius: 50%;
background: #fff;
position: absolute;
right: 12px;
top: 50%;
margin-top: -16px;
transition: all 0.2s;
}

.link-item--anc01 a::after {
content: "";
display: block;
width: 13px;
height: 13px;
background: url("/wp-content/themes/ResearcherPlus/img/common/arrow-1-b.svg") center center /contain no-repeat;
position: absolute;
right: 21px;
top: 50%;
margin-top: -5px;
transition: all 0.2s;
transform: rotate(90deg);
}



/*----------------------------------
ページャー
------------------------------------*/
/* ページネーション全体 */
.pagination {
  display: flex;
  justify-content: center; /* 中央寄せ */
  list-style: none;
  padding: 0;
  margin:40px 0px 16px;
  gap: 6px; /* 要素間の余白 */
}

/* 各ページ番号リンク */
.pagination li a,
.pagination li span {
  display: block;
		width: 40px;
		height: 40px;
		line-height: 40px;
		margin: 0px 3px ;
		text-align: center;
		font-size: var(--font-h5);
		text-decoration: none !important;
		background-color:#F2F4F5;
		border-radius: 50%;
  transition: all 0.2s ease;
}
/* ホバー時 */
.pagination li a:hover {
  background-color: #D6D8D9;
		color: #fff;
}

/* 現在ページ */
.pagination li .current {
  background-color: #D6D8D9;   /* WordPress管理画面っぽい青 */
  pointer-events: none;
}

/* 省略（…） */
.pagination li.dots span {
  border: none;
  background: none;
  color: #999;
  cursor: default;
		width: 20px;
}

/*前後ボタン*/
.pagination li a.prev,
.pagination li a.next {
background-color: var(--color1);
background-image: url("/wp-content/themes/ResearcherPlus/img/common/arrow-1-w.svg");
background-size: 27%;
background-position: center;
background-repeat: no-repeat;
text-indent: 110%;
white-space: nowrap;
color: #fff;
}
.pagination li a.prev {
transform: scale(-1,1);
}



/* 前へ・次へリンクを少し強調 */
.pagination li a.prev,
.pagination li a.next {
  font-weight: bold;
}

/*表示件数*/
.list-volume {
width: 100%;
margin-bottom: 36px;
padding-bottom: 10px;
border-bottom: solid 1px var(--color4);
font-size: var(--font-h5);
}

.list-volume--total {
font-weight: bold;
}

/*----------------------------------
開閉ボタン
------------------------------------*/
i.btn_toggle {
content: "";
display: block;
width: 30px;
height: 30px;
border-radius: 50%;
border: solid 1px var(--color2);
position: absolute;
top: 50%;
margin-top: -15px;
right: 15px;
cursor: pointer;
}
i.btn_toggle::before,
i.btn_toggle::after {
content: "";
display: block;
width: 12px;
height: 2px;
background: var(--color2);
position: absolute;
top: 50%;
margin-top: -1px;
right: 50%;
margin-right: -6px;
}
i.btn_toggle::after {
width: 2.5px;
height: 12px;
top: 50%;
margin-top: -6px;
right: 50%;
margin-right: -1px;
}
.gp__list__ti:has(+ .item--open) i.btn_toggle::after,
.rs-search__toggle.item--open ~ i.btn_toggle::after {
display: none;
}

.rs-search__list i.btn_toggle {
display: none;
}
@media screen and (min-width:768px) {
.rs-search___labels {
display: block !important;
}
}


.rs-search__toggle {
max-height: 0px;
transition: max-height 1s ease;
overflow: hidden;
}
.rs-search__toggle.item--open {
max-height: 1000px;
}

.rs-search__toggle ~ i.btn_toggle {
top: -45px;
margin-top: 0px;
right: 0px;
cursor: pointer;
}

/*----------------------------------
Researcher+
------------------------------------*/
.package-comp__item {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
padding: 3px;
background: #eee;
}
.package-comp__item:not(:last-child) {
margin-bottom: 10px;
}
.package-comp__item--l {
width: 270px;
}
.package-comp--l__name {
font-size: 14px;
font-weight: bold;
}
.package-comp--l__txt {
font-size: 12px;
}

.package-comp__item--r {
width: calc(100% - 280px);
display: flex;
justify-content: space-between;
align-items: center;
}
.package-comp--r__line {
flex: 1;
border-bottom: 1px dotted #333;
margin-right: 0.5em; 
}

.program-map1__cont {
max-width:700px;
margin: auto;
}

/*----------------------------------
研究者育成プログラム・パッケージ第二版
------------------------------------*/
.gpSlider__list__cont {
}
.gpSlider__list {
width: 1000px;
margin-bottom: 40px;
}
.gpSlider__list .slick-slide {
  margin: 0 10px; /* サムネイルの左右に5pxのアキを作る */
}
.gpSlider__list .slick-list {
  margin: 0 -10px; /* 両端の余白を調整して中央を揃える */
		overflow: visible;
}
.gpSlider__item a {
text-decoration: none !important;
}

.gpSlider__item--img {
margin-bottom: 12px;
border-radius: var(--radius-16);
overflow: hidden;
}
.gpSlider__item--img span {
display: block;
width: 100%;
height: 0px;
padding-top: 56%;
background: #ccc;
transition: all 0.2s;
}
.gpSlider__item a:hover .gpSlider__item--img span {
transform: scale(1.05);
}

.gpSlider__item--ti {
font-size: 16px;
line-height: 1.5em;
font-weight: bold;margin-bottom: 16px;
}

.slick-prev, .slick-next {
z-index: 1;
top: 90px;
width: 48px;
height: 48px;
border-radius: 50%;
box-shadow: 0px 4px 8px 0px rgba(52, 63, 92, 0.2);
background-color: rgba(255,255,255,1) !important;
transition: all 0.2s;
}
.slick-prev::before,
.slick-next::before {
display: block;
width: 14px;
height: 14px;
background: url("/wp-content/themes/ResearcherPlus/img/common/arrow-1-bk.svg") center center / contain no-repeat;
position: absolute;
top: 50%;
margin-top: -7px;
left: 50%;
margin-left: -7px;
transition: all 0.2s;
}
.slick-prev::before {
content: "";
transform: rotate(180deg);
}
.slick-next::before {
content: "";
}
.slick-prev:hover,
.slick-next:hover {
background-color: rgba(255,255,255,0.7) !important;
}
.slick-prev:hover::before,
.slick-next:hover::before {
opacity: 0.7 !important;
}

.slick-prev.slick-disabled, .slick-next.slick-disabled {
opacity: 0;
cursor: default;
}

.rp-img__box {
display: flex;
justify-content: space-between;
align-items: center;
}
.rp-img__box--l {
width: 33.2%;
}
.rp-img__box--r {
width: 64%;
text-align: center;
}

/*パッケージリスト*/
.program__list:not(:last-child) {
margin-bottom: 64px;
}
.program__item {
width: 100%;
margin-bottom: 20px;
padding-top: 20px;
}

.program__ti {
padding-bottom: 12px;
border-bottom: solid 1px #445479;
}
.program-cate {
display: inline-block;
font-size: 12px;
font-weight: bold;
margin-bottom: 8px;
}

.program__ti__inner {
font-size: 20px;
font-weight: bold;
}
.program-info__list {
margin-bottom: 20px;
}
.program-info__item {
display: flex;
flex-wrap: wrap;
row-gap:10px;
padding: 12px 0px;
}
.program-info__item:not(:last-child) {
border-bottom: dashed 1px var(--color4);
}
.program-info__pro {
width: 254px;
font-size: 14px;
}
.program-info__val:first-of-type {
font-weight: bold;
}
.program-info__pro span {
font-weight: bold;
}
.program-info__val {
width: calc(100% - 254px);
font-size: 14px;
}
.program__comp {
margin-bottom: 12px;
}
.program__comp a {
display: block;
font-size: 12px;
text-align: center;
height: 60px;
border-radius: 9px;
border: solid 1px rgba(192, 192, 192, 1);
padding: 10px;
position: relative;
}
.program__comp span {
display: inline-block;
font-size: 10px;
padding: 3px;
background: rgba(238, 238, 238, 1);
position: absolute;
left: 1em;
top: 50%;
margin-top: calc(-1 * (0.5em + 6px));
}
.program__comp a::after {
content: "";
display: block;
width: 2em;
height: 1.8em;
border-width: 1px;
border-style: solid;
border-color: #000 #000 transparent transparent;
position: absolute;
left: 50%;
margin-left: -1.1em;
bottom: 1em;
transform: rotate(145deg) skewX(200deg);
}


.rp-comp__list {
padding-top: 5px;
display: flex;
justify-content: flex-start;
flex-wrap: wrap;
row-gap: 16px;
}
.rp-comp__item {
font-size: 12px;
font-weight: bold;
padding-top: 2px;
padding-left: 35px;
margin-bottom: 8px;
line-height: 1.2em;
position: relative;
}
.rp-comp__list li {
width: 20%;
}
/*教本・副読冊子等 用*/
.cmn1__item .rp-comp__list li {
width: 33.3%;
}


.rp-comp__item span {
display: inline-block;
counter-increment: fw-num 1;
content: counter(fw-num, decimal-leading-zero);
width: 25px;
height: 25px;
line-height: 23px;
font-size: 12px;
text-align: center;
color:#fff;
background:  #000;
position: absolute;
left: 0px;
top: -3px;
}

.rp-comp__item.comp-o span {
background:  var(--color-comp-o);
}
.rp-comp__item.comp-g span {
background:  var(--color-comp-g);
}
.rp-comp__item.comp-b span {
background:  var(--color-comp-b);
}
.rp-comp__item.comp-p span {
background:  var(--color-comp-p);
}


/*----------------------------------
絞り込み検索
------------------------------------*/
.rs-search__cont {
width: 100%;
max-width: 900px;
margin: auto;
border-radius: var(--radius-16);
border: solid 1px var(--color4);
/*overflow: hidden;*/
}
.rs-search__ti {
font-weight: Bold;
margin-bottom: 20px;
font-size: 18px;
}
.rs-search__group {
position: relative;
}
.rs-search__list {
display: flex;
align-items: center;
padding: 20px 48px;
justify-content: space-between;
flex-wrap: nowrap;
}

.rs-search__box {
border-bottom: solid 1px var(--color4);
}
.post-type-archive-good_practice .rs-search__box:last-child {
border-bottom: none;
}

.rs-search__box .acf-label {
width: 172px;
font-size: 16px;
font-weight: bold;
}
.rs-search__box .acf-label span {
display: inline-block;
font-weight: bold;
vertical-align: middle;
}

.rs-search___labels {
width: calc(100% - 172px);
}

.rs-search__box label {
display: inline-block;
height: 32px;
line-height: 32px;
background: var(--color5);
font-weight: bold;
font-size: var(--font-h6);
margin: 8px 16px 8px 0px;
padding: 0px 16px 0px 10px;
border-radius: 16px;
cursor: pointer;
transition: all 0.2s;
}

.rs-search__box label:has(input:checked) {
background: #333;
color: #fff;
}
.rs-search__box label:hover {
opacity: 0.8;
}

.rs-search__box input[type="checkbox"] {
  position: relative;
  width: 16px;
  height: 16px;
		background: #fff;
		border-radius: 50%;
  vertical-align: -5px;
  appearance: none;
		margin-right: 0.7em;
}

.rs-search__box input[type="checkbox"]:checked:before {
  position: absolute;
  top: 3px;
  left: 5px;
  transform: rotate(50deg);
  width: 3.5px;
  height: 7px;
  border-right: 2px solid #000;
  border-bottom: 2px solid #000;
  content: '';
}



/*フリーワード検索入力欄*/
.rs-search__freeword__box {
margin-bottom: 20px;
}
.rs-search__freeword__ti {
font-weight: bold;
margin-bottom: 5px;
}

.rs-search__freeword {
width: 100%;
font-size: 14px;
  padding: 8px 0px 8px 16px;
  border-radius: 16px;
		background: #F2F4F5;
  border: none;
}

.rs-search__freeword:focus {
  outline: 0;
  border: 2px solid #2196f3;
}

/*ボタン*/
.rs-search____btn__box {
display: flex;
justify-content: center;
column-gap: 24px;
background: #EDEFF0;
padding: 16px 0px;
}
.rs-search____btn {
text-align: center;
width: 218px;
height: 49px;
line-height: 49px;
border-radius: 24.5px;
font-size: 14px;
border:none;
cursor: pointer;
transition: all 0.2s;
}
.rs-search____btn--reset {
background: #fff;
border: solid 1px var(--color4);
}
.rs-search____btn--reset:hover {
background: #F2F4F5;
}

.rs-search____btn--narrow {
background: #333;
color: #fff;
}
.rs-search____btn--narrow:hover {
opacity: 0.8;
}


/*----------------------------------
Good Practice
------------------------------------*/
.gp__list:has(.item--open) {
margin-bottom: 64px;
}
.gp__list__ti {
font-size: var(--font-h3);
color: var(--color2);
background: #F2F4F5;
padding: 12px 50px 12px 24px;
cursor: pointer;
position: relative;
margin-bottom: 24px;
}
.program__list .gp__list__ti {
font-size: 14px;
text-align: center;
padding: 12px 50px;
}

.gp__list:has(.item--open) .gp__list__ti {
margin-bottom: 28px;
}

.gp__list:not(:has(.item--open)):last-child .gp__list__ti {
margin-bottom: 0px;
}
.gp__list__ti__inner {
font-weight: bold;
line-height: 1.2em;
}

.gp__item {
max-height: 0px;
transition: max-height 1s ease;
overflow: hidden;
}
.gp__item.item--open {
max-height: 1500px;
}

.gp__hairline {
width: 5000px;
position: relative;
left: 50%;
margin-left: -2500px;
margin-bottom: 72px;
border-bottom: solid 1px #d9d9d9;
}

.thumb__cont {
text-align: center;
}
.thumb__cont img {
border-radius: var(--radius-20);
}

.thumb__cont img {
height: 310px;
}

/*----------------------------------
Event
------------------------------------*/
/*-- 一覧 --*/
.event-cate {
vertical-align: middle;
font-size: 12px;
margin-bottom: 8px;
padding-left: 16px;
line-height: 1.4em;
position: relative;
font-weight: bold;
}
.event-cate::before {
content: "";
display: block;
width: 8px;
height: 8px;
position: absolute;
top: 50%;
margin-top: -4px;
left: 0px;
background: #555555;
}
.event-cate.strategic-development::before {
background: #C40606;
}

.event__ti--sub {
font-size: 16px;
font-weight: bold;
line-height: 1.4em;
margin-bottom: 12px;
}
.event-date {
font-size: 14px;
font-weight: bold;
vertical-align: middle;
padding-bottom: 20px;
margin-bottom: 20px;
border-bottom: dashed 1px var(--color4);
}
.event-date--type {
display: inline-block;
font-size: 12px;
color: var(--color2);
font-weight: bold;
height: 20px;
line-height: 20px;
margin-right: 12px;
padding: 0px 16px;
background: #F5FFA6;
border-radius: 10px;
}
.event-date--type.event-implement {
background: #7C7C7C;
color: #fff;
}
.event__img {
height: 0px;
padding-top: 56.3%;
border-radius: 12px;
text-indent: 102%;
white-space: nowrap;
overflow: hidden;
}

/*ダウンロードボタン*/
.dl__list {
display: flex;
margin-top: 64px;
justify-content: center;
}
.dl__item {
width: 33.33%;
}
.dl__item a {
display: block;
height: 73px;
line-height: 73px !important;
text-align: center;
border: solid 1px var(--color4);
text-decoration: none !important;
background: #fff;
transition: all 0.2s;
}
.dl__item a:hover {
background: #eee;
}
.dl__item a::after {
display: none !important;
}

.dl__item a * {
vertical-align: middle;
}
.dl__item img {
width: 24px;
height: auto;
margin-right: 16px;
}


.dl__item.dl__item--pos {

}

/*----------------------------------
戦略育成事業（Univ）
------------------------------------*/
.ag__agency__cont {
height: 0px;
padding-top: 70%;
background: url("/wp-content/themes/ResearcherPlus/img/other/univ/index/img-map@2x.jpg") center center /contain no-repeat;
position: relative;
}
.ag__agency__ti {
width: 266px;
display: flex;
justify-content: center;
align-items: center;
position: absolute;
left: 0px;
top: 3%;
}
.ag__agency--mark {
width: 70px;
margin-right: 10px;
}
.ag__agency--txt {
width: 186px;
}
.ag__agency--txt span {
display: inline-block;
font-size: 18px;
font-weight: bold;
line-height: 1.6em;
letter-spacing: 0.12em;
}

.ag__link__item {
width: 310px;
position: absolute;
background: #fff;
}
#ag__link--l-insight {
left: 0px;
top: 25%;
}
#ag__link--hiraku-global {
left: 0%;
bottom: 5%;
}
#ag__link--ti-fris {
right: 0px;
top:18%;
}
#ag__link--tristar {
right: 0px;
top: 50%;
}
#ag__link--t-gex {
right: 0px;
bottom: 5%;
}
.ag__link__item a {
display: flex;
justify-content: center;
align-items: center;
text-decoration: none !important;
transition: all 0.2s;
}
.ag__link__item a:hover {
transform: scale(1.05);
}

.ag__link--mark {
width: 80px;
}
.ag__link--info {
width: calc(100% - 96px);
}
.ag__link-saitaku {
font-size: 12px;
}
.ag__link-name {
font-size: 16px;
font-weight: bold;
padding-left: 1em;
position: relative;
}
.ag__link-name::before {
content: "";
display: block;
width: 8px;
height: 8px;
background: #000;
position: absolute;
left: 0px;
top: 50%;
margin-top: -3px;
}
.ag__link-copy {
display: inline-block;
font-size: 14px;
line-height: 1.4em;
}
.ag__link-copy span {
display: inline-block;
}

/*----------------------------------
実施機関
------------------------------------*/
.ag__ti {
font-size: 14px;
padding-left: 1em;
position: relative;
margin-bottom: 10px;
letter-spacing: 4%;
}
.ag__ti::before {
content:"";
display: block;
width: 4px;
height: 4px;
border: solid 2px #445479;
border-radius: 50%;
position: absolute;
left: 0px;
top: 7px;
}
.ag-pj__info {
display: flex;
justify-content: space-between;
align-items: center;
background: #FAFAFA;
padding: 8px 12px;
margin-bottom: 20px;
}
.ag-pj__info--l {
width: 100px;
margin-right: 16px;
}
.ag-pj__info--l img {
vertical-align: middle;
}

.ag-pj__info--r {
width: calc(100% - 85px);
}
.ag-pj__name {
width: 300px;
font-size: var(--font-h2);
font-weight: bold;
margin-bottom: 4px;
}
.ag-pj__name--under {
font-size: 14px;
line-height: 1.8em;
}
.ag__lead {
font-size: 14px;
margin-bottom: 16px;
}
.ag__joint {
display: flex;
justify-content: space-between;
align-items: flex-start;
flex-wrap: wrap;
font-size: 12px;
}
.ag__joint--pro {
display: inline-block;
width: 100px;
padding: 3px 0px 5px;
margin-right: 24px;
border: solid 1px #445479;
text-align: center;
line-height: 1.8em;
}
.ag__joint--val {
width: calc(100% - 124px);
line-height: 1.8em;
margin-top: 4px;
}

.ag__honbun__ti {
font-weight: bold;
font-size: 16px;
margin-bottom: 8px;
}
.ag__honbun__txt {
font-size: 14px;
line-height: 1.8em;
}
.ag__inner:not(:last-child) {
margin-bottom: 30px;
}

.ag__prog__list {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
column-gap: 12px;
row-gap:12px;
}
.ag__prog__item {
width: calc((100% - 12px) / 2);
padding: 20px 24px 32px;
}


.ag_koryu {
background: rgba(94, 120, 184, 0.1);
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.ag_kyodo {
background: rgba(72, 153, 99, 0.1);
}
.ag_jisso {
background: rgba(168, 91, 153, 0.1);
}
.ag_trans,
.ag_kyotsu,
.ag_double {
background: rgba(239, 237, 235, 0.5);
}
.ag_koryu,
.ag_double {
width: 100%;
}

.ag__prog__inner {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.ag_koryu .ag__prog__inner {
width: calc((100% - 20px) / 2);
}
.ag__prog__inner--l,
.ag__prog__inner--r {
width: calc((100% - 20px) / 2);
}
.ag__prog__inner img {
width: 100%;
}

.ag__gakusai {
margin-bottom: 8px;
padding-left: 0.8em;
font-size: 14px;
font-weight: bold;
color: #6077B0;
position: relative;
}
.ag_kyodo .ag__gakusai {
color: #10B190;
}
.ag_jisso .ag__gakusai {
color: #A85B99;
}


.ag__gakusai::before {
content: "";
display: block;
width: 0px;
height: 0px;
border-width: 0.4em 0px 0.4em 0.5em;
border-color: transparent transparent transparent #6077B0;
border-style: solid;
position: absolute;
left: 0px;
top: 50%;
margin-top: -0.3em;
}
.ag_kyodo .ag__gakusai::before {
border-color: transparent transparent transparent #10B190;
}
.ag_jisso .ag__gakusai::before {
border-color: transparent transparent transparent #A85B99;
}
.ag__prog__ti {
font-size: 18px;
font-weight: bold;
line-height: 1.3em;
margin-bottom: 8px;

}
.ag_double .ag__prog__ti {
width: 100%;
}
.ag__prog__ti span {
font-size: 14px;
font-weight: normal;
margin-bottom: 4px;
}
span.ag__prog__ti--pre {
display: block;
font-weight: bold;
}
.ag__prog__ti.ag__pop {
padding-bottom: 12px;
border-bottom: dashed 1px var(--color1);
}

.ag__subti {
font-size: 14px;
line-height: 1.6em;
font-weight: bold;
margin-bottom: 4px;
}
.ag_double .ag__subti {
padding-top: 0.3em;
}

.ag__prog__txt {
font-size: 14px;
line-height: 1.8em;
}
.ag__prog_matter {
font-size: 14px;
line-height: 1.8em;
margin-top: 10px
}
.ag__prog_matter li {
padding-left: 1em;
position: relative;
line-height: 1.5em;
}
.ag__prog_matter li::before {
display: block;
content: "";
width: 3px;
height: 3px;
border-radius: 50%;
background: var(--color1);
position: absolute;
left: calc(0.5em - 3px);
top: 0.76em;
margin-top: -1.5px;
}
.ag_trans .ag__prog_matter li::before,
.ag_kyotsu .ag__prog_matter li::before {
background: #000;
}

.ag-chart__list--01 {
display: flex;
flex-wrap: wrap;
max-width: 800px;
column-gap: 80px;
row-gap: 28px;
margin: auto;
}

.phase__cont {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
column-gap: 7px;
row-gap:20px;
font-size: 14px;
}
.phase__box {
width: calc((100% - 7px) / 2);
}

.phase__ti.phase-01 {
margin-bottom: 7px;
}
.phase__ti.phase-01 {
color: #32B09D;
}
.phase__ti.phase-02 {
color: #424B95;
}


.phase__ti--pro {
display: inline-block;
padding: 2px 1.5em 4px;
margin-right: 1em;
font-size: 12px;
}
.phase-01 .phase__ti--pro {
border: solid 1px #32B09D;
}
.phase-02 .phase__ti--pro {
border: solid 1px #424B95;
}
.phase__ti--val {
font-weight: bold;
font-size: 16px;
}
.phase-01 .phase__ti--val {
}
.phase-02 .phase__ti--val {
}

.ag-prog-type__list {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
column-gap: 10px;
row-gap: 10px;
}
.ag-prog-type__item {
width: calc((100% - 30px) / 4);
font-size: 14px;
padding: 16px 20px;
background: rgba(238, 247, 250, 0.7);
border-radius: 8px;
}
.ag-prog-type__ti {
font-weight: bold;
font-size: 16px;
}


.ag__cycle__list {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
position: relative;
}
.ag__cycle__item {
width: calc((100% - 236px) / 2);
border: solid 1px #445479;
background: #fff;
position: relative;
z-index: 3;
}
.ag__cycle__item.ag_sien {
width: 382px;
margin: 0px calc((100% - 382px) / 2);
margin-top: 40px;
}
.ag__cycle__inner__ti  {
color: #fff;
background: #445479;
font-size: 16px;
font-weight: bold;
line-height: 1.2em;
padding: 5px 1em 6px;
}
.ag__cycle__inner__ti span {
display: inline-block;
font-weight: bold;
}
.ag__cycle__inner__val {
padding-left: calc(24px + 1em);
padding-right: 24px;
font-size: 14px;
font-weight: bold;
line-height: 1.4em;
color: #5E78B8;
position: relative;
}
.ag__cycle__inner__val.ag_cl_red {
color: #BD6C53;
}
.ag__cycle__inner__val:not(:last-child) {
margin-bottom: 4px;
}
.ag__cycle__inner__val:first-of-type {
margin-top: 16px;
}
.ag__cycle__inner__val:last-child {
margin-bottom: 24px;
}
.ag__cycle__inner__val::before {
content: "";
display: block;
width: 6px;
height: 6px;
border-radius: 3px;
background: #5E78B8;
position: absolute;
left: 24px;
top: 0.7em;
margin-top: -3px;
}
.ag__cycle__inner__val.ag_cl_red::before {
background: #BD6C53;
}
.ag__cycle__list::before {
content: "";
display: block;
width: 140px;
height: 0px;
padding-top: 198px;
background: url("/wp-content/themes/ResearcherPlus/img/other/univ/agency/l-insight/img-03@2x.jpg") center center / contain no-repeat;
position: absolute;
left: calc((100% - 140px) / 2);
bottom: 150px;
z-index: 2;
}
.ag__cycle__list::after {
content: "";
display: block;
width: 625px;
height: 0px;
padding-top: 102px;
background: url("/wp-content/themes/ResearcherPlus/img/other/univ/agency/l-insight/img-cycle-arrow-pc.jpg") center center / contain no-repeat;
position: absolute;
left: 50%;
margin-left: -312.5px;
bottom: 20%;
z-index: 1;
}

.ag__jissi__list__ti {
line-height: 1.4em;
font-weight: bold;
font-size: 16px;
margin-bottom: 16px;
padding: 4px 8px;
background: #F2F4F5;
}

.ag__jissi__list {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
row-gap: 28px;
}
.ag__jissi__item {
width: calc((100% - 60px) / 4);
}
.ag__jissi__ti {
font-size: 14px;
font-weight: bold;
margin-bottom: 4px;
}
.ag__jissi__img {
border-radius: var(--radius-8);
}
.ag__jissi__cap {
font-size: 14px;
line-height: 1.4em;
}

.layer3__list {
background: #F6FFE8;
padding: 20px 20px 20px 0px;
font-size: 14px;
}
.layer3__ti1 {
font-weight: bold;
font-size: 16px;
line-height: 1em;
color: #4BCCBE;
padding-left: 20px;
margin-bottom: 10px;
}
.layer3__item2 .layer3__ti1 {
color: #4A8ADE;
}
.layer3__item3 .layer3__ti1 {
color: #C06795;
}

.ayer3__ti2 {
font-weight: bold;
margin-bottom: 3px;
padding-left: 1.5em;
margin-left: 20px;
position: relative;
}
.ayer3__ti2::before {
content: "";
display: block;
width: 0px;
height: 0px;
border-width: 0.35em 0px 0.35em 0.45em;
border-color: transparent transparent transparent var(--color1);
border-style: solid;
position: absolute;
left: 0.5em;
top: 0.45em;
}

.layer3__item1 {
line-height: 1.8em;
}
.layer3__item2 {
background: #DDFFF5;
padding: 20px 20px 20px 0px;
margin-top: 20px;
}
.layer3__item3 {
background: #F2E9FF;
padding: 20px 20px 20px 0px;
margin-top: 20px;
}

.layer3__item1__list {
margin-left: 20px;
line-height: 1.8em;
}
.layer3__item1__item {
display: inline-block;
padding-left: 1.3em;
margin-right: 1.8em;
line-height: 1.8em;
position: relative;
}
.layer3__item2 .layer3__item1__item {
display: block;
}
.layer3__item1__item::before {
}

.layer3__item1__list:not(:last-child) {
margin-bottom: 8px;
}
.layer3__item1__item::before {
content: "";
width: 0.3em;
height: 0.3em;
border-radius: 50%;
background: #000;
position: absolute;
left: 0.5em;
top: 0.65em;
}

.layer3__item2__list {
line-height: 1.8em;
margin-left: 20px;
}
.layer3__item2__item {
line-height: 1.8em;
}

/*----------------------------------
Survey
------------------------------------*/
.survey__list {
max-width: 840px;
margin: auto;
}
.survey__item {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
flex-direction: row-reverse;
}
.survey__item:not(:last-child) {
margin-bottom: 20px;
}
.survey__item--l {
width: calc((100% - 20px) * 0.455);
}
.survey__item--r {
width: calc((100% - 20px) * 0.545);
}
.survey__ti {
font-size: 18px;
font-weight: bold;
margin-bottom: 10px;
}
.survey__txt {
font-size: 16px;
line-height: 1.2em;
margin-bottom: 10px;
}


/*----------------------------------
Flamework
------------------------------------*/
.fw__ti {
font-size: 18px;
margin-bottom: 24px;
padding-bottom: 12px;
border-bottom: solid 1px #445479;
}
.fw__ti__inner {
font-weight: bold;
line-height: 1.2em;
}

.fw__list {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
margin-bottom: 48px;
}
.fw__list--l {
width: 400px;
}
.fw__list--l img {
width: 100%;
}
.fw__list--r {
width: calc(100% - 432px);
}
.fw-power__list {
font-size: 18px;
line-height: 1.2em;
}
.fw-power__item--pro {
font-size: 16px;
font-weight: bold;
display: inline-block;
margin-bottom: 5px;
}
.fw-p1 {
color: var(--color-comp-o);
}
.fw-p2 {
color: var(--color-comp-g);
}
.fw-p3 {
color: var(--color-comp-b);
}

.fw-power__item--val:not(:last-child){
margin-bottom: 20px;
}

.fw-skill__list {
margin: auto;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
row-gap:20px;
counter-reset: fw-num 0;
}
.fw-skill__item {
width: calc((100% - 40px) / 2);
position: relative;
}
/*.fw-skill__item::before {
  counter-increment: fw-num 1;
  content: counter(fw-num, decimal-leading-zero);
		font-size: 20px;
		position: absolute;
		left: 0px;
		top: 10px;;
		line-height: 1em;
}*/
.fw-skill__item__inner {
display: flex;
justify-content: space-between;
line-height: 1.2em;
}
.fw-skill__item__img {
width: 150px;
border-radius: 4px;
}
.fw-skill__item__txt {
width: calc(100% - 170px);
}
.fw-skill__item__txt--l {
font-size: 16px;
font-weight: bold;
padding-top: 2px;
padding-left: 35px;
margin-bottom: 8px;
line-height: 1.2em;
position: relative;
}
.fw-skill__item__txt--l::before {
display: inline-block;
counter-increment: fw-num 1;
content: counter(fw-num, decimal-leading-zero);
width: 25px;
height: 25px;
line-height: 23px;
font-size: 12px;
text-align: center;
color:#fff;
background:  #000;
position: absolute;
left: 0px;
top: 0px;
}
.comp-o .fw-skill__item__txt--l::before {
background:  var(--color-comp-o);
}
.comp-g .fw-skill__item__txt--l::before {
background:  var(--color-comp-g);
}
.comp-b .fw-skill__item__txt--l::before {
background:  var(--color-comp-b);
}
.comp-p .fw-skill__item__txt--l::before {
background:  var(--color-comp-p);
}

.fw-skill__item__txt--s {
display: inline-block;
font-size: 14px;
line-height: 1.5em;
vertical-align: top;
}


/*----------------------------------
Book
------------------------------------*/
.book__img {
display: flex;
align-items: stretch;
min-height: 203px;
padding: 35px 41px;
background: #eee;
border-radius: 12px;
}
.book__img span {
display: block;
width: 100%;
text-indent: 100%;
white-space: nowrap;
overflow: hidden;
flex: 1;
}


/*----------------------------------
Casestudy
------------------------------------*/
.casestudy__item {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
flex-direction: row-reverse;
}
.casestudy__item:not(:last-child) {
margin-bottom: 44px;
}
.casestudy__item--r {
width:  calc((100% - 56px) * 0.32);
}
.casestudy__item--l {
width:  calc((100% - 56px) * 0.68);
}
.casestudy__ti {
font-size: 18px;
font-weight: bold;
margin-bottom: 8px;
}
.casestudy__txt {
font-size: 14px;
line-height: 1.8em;
margin-bottom: 16px;
}

.casestudy__item--r .casestudy__img {
height: 0px;
padding-top: 56.3%;
background: #eee;
border-radius: 12px;
text-indent: 100%;
white-space: nowrap;
overflow: hidden;
}


/*----------------------------------
Fund
------------------------------------*/
.fund-attention {
font-size: 14px;
font-weight: bold;
margin-bottom: 32px;
}
.fund-group__item:not(:last-child) {
margin-bottom: 88px;
}
.fund__list:not(:last-child) {
margin-bottom: 44px;
}
.fund__ti {
line-height: 1.4em;
font-weight: bold;
font-size: 16px;
margin-bottom: 16px;
padding: 4px 8px;
background: #F2F4F5;
}
.fund-link__item {
margin-left: 8px;
}
.fund-link__item:not(:last-child) {
margin-bottom: 16px;
padding-bottom: 16px;
border-bottom: dashed 1px var(--color4);
}
.fund__name {
display: inline-block;
font-size: 14px;
margin-right: 20px;
}
.fund__url {
display: inline;
}
.fund__url a {
color: var(--color3);
word-break: break-all;
}
