@charset "utf-8";
/*Webfont読み込み*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap");

/* ============================================================================
unit.aist用　Default styles
スマートフォン用（画面幅896px以下用）CSS
Template Version : 2.0.0
Last Update      : 2025-09-12
============================================================================ */
/* ===========================================================
 root
=========================================================== */
:root {
  --theme-color-red: #cf0027;

  --theme-fontColor-black: #333;

  --content-area-width: 1040px;
  --content-area-sidePadding: clamp(5px, 3%, 20px);

  --fontsz-xxxl: clamp(2.2rem, 1.844rem + 1.78vw, 3rem);
  --fontsz-xxl: clamp(2rem, 1.778rem + 1.11vw, 2.5rem);
  --fontsz-xl: clamp(1.7rem, 1.567rem + 0.67vw, 2rem);
  --fontsz-l: clamp(1.4rem, 1.222rem + 0.89vw, 1.8rem);
  --fontsz-m: 1.3rem;

  font-family: "Noto Sans JP", YuGothic, "Yu Gothic", sans-serif;

  font-weight: 500;
}

/* ===========================================================
 default
=========================================================== */
* {
  box-sizing: border-box;
}

html {
  font-size: 62.5%;
  -webkit-text-size-adjust: 100%;
}

html.dialogOpen {
  overflow: clip;
}

body {
  padding: 0;
  margin: 0;
  font-size: 1.3rem;
  color: var(--theme-fontColor-black);
  line-height: 1.6;
  display: grid;
  grid-template:
    "header" auto
    "main" 1fr
    "footer" auto
    / 1fr;
  min-height: 100vh;
}

body.fixed {
  position: fixed;
  top: var(--scroll-y);
  left: 0;
  right: 0;
  overflow: hidden;
  width: 100%;
}


section {
  margin-bottom: 3em;
}

article {
  margin-bottom: 2em;
}

a {
  color: var(--theme-color-red);
  text-decoration: underline;
}

a:focus {
  text-decoration: none;
}

@media (any-hover: hover) {
  a:any-link:hover {
    text-decoration: none;
  }
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
  display: block;
}

figure {
  margin: 0;
  text-align: center;
  margin-bottom: 1.5em;
}

figure > img{
  margin: auto;
}

figcaption {
  margin-top: 0.5em;
}

picture {
  display: block;
  margin-bottom: 1.5em;
  text-align: center;
}

picture img {
  margin: auto;
}

figure picture{
  margin-bottom: 0;
}


strong {
  font-weight: bold;
}

p {
  margin: 0;
  margin-bottom: 1.5em;
}

ul,
ol {
  margin: 0 0 1.5em 2em;
  padding: 0.5em 0 1em 0;
}

li {
  padding-left: 0;
  margin-bottom: 1em;
}

li:last-child {
  margin-left: 0;
  margin-bottom: 0;
}

h1 {
  font-size: var(--fontsz-xxxl);
  font-weight: normal;
  padding: 0.5em 0;
  margin-bottom: 20px;
  border-bottom: 2px solid var(--theme-color-red);
}

h2 {
  margin: 0 0 1em;
  padding-bottom: 0.3em;
  font-size: var(--fontsz-xxl);
  font-weight: normal;
  background: url(../img/common/bg_heading_red.svg) repeat-x bottom left / 2px 3px;

}

h3 {
  font-size: var(--fontsz-xl);
  margin: 0 0 1em;
  padding-bottom: 0.3em;
  font-weight: normal;
  background: url(../img/common/bg_heading_gray.svg) repeat-x bottom left / 2px 3px;
}

h4 {
  font-size: var(--fontsz-l);
  margin: 0 0 1em;
  padding: 0 0 0.3em 0.3em;
  font-weight: normal;
  border-bottom: 1px solid #bbbbbb;
  border-left: 7px solid #dddddd;
}

h5 {
  font-size: var(--fontsz-m);
  margin: 0 0 1em;
  padding-bottom: 0.3em;
  border-bottom: 1px solid #cccccc;
}

h6 {
  font-size: var(--fontsz-m);
  margin: 0 0 1em;
  padding-bottom: 0.3em;
  border-bottom: 1px dotted #cccccc;
}

/* ===========================================================
 common
=========================================================== */

/*--SP版 PC版のみ表示--*/
.pcView {
  display: none;
}

.spView {
  display: block;
}
/*--スクリーンリーダー専用 テキスト隠し--*/
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  border: 0;
  clip: rect(0 0 0 0);
  overflow: hidden;
}

/* ===========================================================
 header
=========================================================== */
header {
  grid-area: header;
  position: sticky;
  top: 0;
  z-index: 9999;
  background: #FFFFFF;
}

.pcHeader {
  display: none;
}


/* スマートフォン版（画面サイズ896以下）ヘッダー ------------------------------------------------*/

.spHeader a {
  color: var(--theme-fontColor-black);
  text-decoration: none;
}

.spHeader a:focus-visible {
  color: var(--theme-color-red);
}

@media (any-hover: hover) {
  .spHeader a:any-link:hover {
    color: var(--theme-color-red);
  }
}


.spHeader .headingBox {
  border-bottom: 5px solid var(--theme-color-red);
  width: 100%;
  display: grid;
  grid-template: "siteTitleBox menuBtnBox";
  grid-template-columns: 1fr auto;
  grid-template-rows: 1fr;
  background-color: #FFFFFF;
  z-index: 9999;
  position: sticky;
}

.spHeader .headingBox>* {
  align-self: center;
}

/*--メニューボタン--*/
.spHeader .menuBtnBox .menuBtn {
  min-width: 45px;
  min-height: 45px;
  background-color: #333333;
  color: #FFFFFF;
}

.menuBtnBox .menuBtn .line {
  display: block;
  position: relative;
  height: 16px;
  width: 19px;
  margin: 0 auto 5px;
}

.spHeader .menuBtnBox .menuBtn .line>span {
  display: inline-block;
  transition: all 0.4s;
  position: absolute;
  left: 0;
  width: 19px;
  height: 2px;
  background-color: #fff;
}

.spHeader .menuBtnBox .menuBtn .line>span:nth-of-type(1) {
  top: 0;
}

.spHeader .menuBtnBox .menuBtn .line>span:nth-of-type(2) {
  top: 7px;
}

.spHeader .menuBtnBox .menuBtn .line>span:nth-of-type(3) {
  top: 14px;
}

.spHeader .menuBtnBox .menuBtn .txt {
  display: block;
  font-weight: 600;
  color: #FFFFFF;
  font-size: 1.1rem;
  word-break: break-all;
}

.spHeader .headingBox .menuBtnBox {
  grid-area: menuBtnBox;
  height: 100%;
}

.spHeader .headingBox .menuBtnBox button {
  border: 0;
  height: 100%;
  cursor: pointer;
}

.spHeader .headingBox .menuBtnBox button:focus-visible {
  opacity: 0.7;
}

@media (any-hover: hover) {
  .spHeader .headingBox .menuBtnBox button:hover {
    opacity: 0.7;
  }
}



/*--メニューボタン（active時）--*/

.spHeader .menuBtnBox .menuBtn.active {
  background: #e7e7e7;
  color: #333333;
}

.spHeader .menuBtnBox .menuBtn.active .txt {
  color: #333333;
}

.spHeader .menuBtnBox .menuBtn.active .line>span {
  background: #333333;
}

.spHeader .menuBtnBox .menuBtn.active .line>span:nth-of-type(1) {
  transform: translateY(7px) rotate(-45deg);
}

.spHeader .menuBtnBox .menuBtn.active .line>span:nth-of-type(2) {
  opacity: 0;
}

.spHeader .menuBtnBox .menuBtn.active .line>span:nth-of-type(3) {
  transform: translateY(-7px) rotate(45deg);
}

/*--サイトタイトル--*/
.spHeader .headingBox .siteTitleBox {
  grid-area: siteTitleBox;
  padding: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.spHeader .headingBox .siteTitleBox .aistlogo {
  width: 80px;
}

.spHeader .headingBox .siteTitleBox .aistlogo a {
  display: block;
  width: 80px;
  padding-top: 0.2em;
}

.spHeader .headingBox .siteTitleBox .unitnameBox {
  width: 100%;
}

.spHeader .headingBox .siteTitleBox .unitnameBox h1,
.spHeader .headingBox .siteTitleBox .unitnameBox p {
  border-bottom: 0;
  padding: 0;
  margin: 0;
  font-size: 1.4rem;
  font-weight: 700;
}

.lang_jp .spHeader .headingBox .siteTitleBox .unitnameBox h1,
.lang_jp .spHeader .headingBox .siteTitleBox .unitnameBox p {
  word-break: break-all;
}

/* メニュー本体 ------------------------------------------------*/
.spHeader .menuBox {
  position: fixed;
  top: -100dvh;
  left: 0;
  width: 100%;
  height: 0;
  background: #fff;
  transition: top 0.3s ease, opacity 0.3s ease;
  opacity: 0;
  visibility: hidden;
  z-index: -1;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;

}

.spHeader .menuBox_inner {
  height: 100%;
  padding-bottom: 30px;
}

/*-- メニューオープン時 --*/
.spHeader .menuBox.open {
  top: 0;
  opacity: 1;
  visibility: visible;
  height: 100dvh;
}

/*--メニューサブボックス--*/
.spHeader .subBox {
  background: #333333;
  padding: 20px var(--content-area-sidePadding);
  color: #FFFFFF;
}

.spHeader .subBox>* {
  margin-bottom: 1.5em;
}

.spHeader .subBox>*:last-child {
  margin-bottom: 0;
}

.spHeader .subBox a {
  text-decoration: underline;
  color: #FFFFFF;
}

.spHeader .subBox a:focus-visible {
  color: inherit;
  text-decoration: none;
}

@media (any-hover: hover) {
  .spHeader .subBox a:any-link:hover {
    color: inherit;
    text-decoration: none;
  }
}

.spHeader .menuBox .navi_inner {
  padding: var(--content-area-sidePadding);
}


/* 言語切り替えリンク ------------------------------------------------*/
.spHeader .languageWrap {
  display: flex;
  justify-content: center;
}

.spHeader .languageWrap ul {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  gap: 1em;
  margin: 0;
  padding: 0;
  padding-left: 1.5em;
  position: relative;
  line-height: 1;
}

.spHeader .languageWrap ul::before {
  content: '';
  display: block;
  width: 1em;
  height: 1em;
  background: url(../img/common/ico_language.svg) no-repeat left center / 1em;
  filter: invert(100%) sepia(0%) saturate(0%) hue-rotate(330deg) brightness(108%) contrast(101%);
  position: absolute;
  left: 0;
  top: 0.1em;
}

.spHeader .languageWrap ul li:not(:last-child) {
  border-right: 1px solid #e7e7e7;
  padding-right: 1em;

}

/* 産総研トップへ　ボタン ------------------------------------------------*/
.spHeader .aist-topPage a {
  display: block flex;
  background: #EEEEEE;
  padding: 0.5em;
  color: var(--theme-fontColor-black);
  text-decoration: none;
  justify-content: center;
  align-items: center;
  gap: 10px;
}

.spHeader .aist-topPage a:focus-visible {
  color: var(--theme-color-red);
}

@media (any-hover: hover) {
  .spHeader .aist-topPage a:any-link:hover {
    color: var(--theme-color-red);
  }
}

.spHeader .aist-topPage a::before {
  content: '';
  display: inline-block;
  width: 2em;
  height: 2em;
  background: url(../img/common/ico_aist-top.svg) no-repeat center/80%;
}

/* ナビリンク ------------------------------------------------*/
.spHeader .menuBox nav.link_list>ul {
  list-style: none;
  margin: 0 0 2em;
  padding: 0;
  font-size: 1.6rem;
  border-top: 1px solid #e7e7e7;
}

.spHeader .menuBox nav.link_list>ul>li {
  border-bottom: 1px solid #e7e7e7;
  padding: 0;
  margin-bottom: 0;
}

.spHeader .menuBox nav.link_list>ul>li>a {
  display: block;
  position: relative;
  padding: 1em 20px 1em 0;
}

.spHeader .menuBox nav.link_list>ul>li>a::after {
  content: "";
  display: block;
  width: 5px;
  height: 5px;
  border-top: 2px solid #888888;
  border-right: 2px solid #888888;
  position: absolute;
  right: 5px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}

.spHeader .menuBox nav.link_list>ul>li>a:focus-visible {
  background: #F9F9F9;
}

.spHeader .menuBox nav.link_list>ul>li>a:focus-visible::after {
  border-color: var(--theme-color-red);
}


@media (any-hover: hover) {
  .spHeader .menuBox nav.link_list>ul>li>a:any-link:hover {
    background: #F9F9F9;
  }

  .spHeader .menuBox nav.link_list>ul>li>a:any-link:hover::after {
    border-color: var(--theme-color-red);
  }
}


/* サブリンク ------------------------------------------------*/
.spHeader .menuBox nav.textlink_list ul {
  display: flex;
  list-style: none;
  gap: 1em 2em;
  padding: 0;
  margin: 0;
  flex-wrap: wrap;
}

.spHeader .menuBox nav.textlink_list ul li {
  margin: 0;
  padding: 0;
}

.spHeader .menuBox nav.textlink_list a:focus-visible {
  text-decoration: underline;
}

@media (any-hover: hover) {
  .spHeader .menuBox nav.textlink_list a:any-link:hover {
    text-decoration: underline;
  }
}


/* ===========================================================
 footer
=========================================================== */
footer {
  grid-area: footer;
}

.footBody {
  background: #474747;
  text-align: center;
  padding: 20px 0;
}

.footBody .inner {
  max-width: var(--content-area-width);
  padding: 0 var(--content-area-sidePadding);
  margin: auto;
}

/* pagetop  ------------------------------------------------*/
footer .pagetop {
  max-width: var(--content-area-width);
  padding: 0 var(--content-area-sidePadding);
  margin: 0 auto 1em;
  text-align: right;
  font-size: 1.1rem;
  text-decoration: none;
}

footer .pagetop a {
  color: #666666;
}

footer .pagetop a::before {
  content: '▲';
}

/* linkList  ------------------------------------------------*/
.footBody .linkList {
  margin-bottom: 30px;
}

.footBody .linkList ul {
  display: flex;
  justify-content: center;
  padding: 0;
  list-style: none;
  font-size: 1.4rem;
  flex-wrap: wrap;
  gap: 0.5em 2em;
}

.footBody .linkList li {
  padding: 0;
  margin: 0;
}

.footBody .linkList li a {
  color: #fff;
  text-decoration: none;
}

.footBody .linkList li a:hover {
  text-decoration: underline;
}

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

.footBody .footer_logo img {
  max-width: 325px;
  margin: auto;
  width: calc(100vw - 24px);
}

body.lang_en .footBody .footer_logo img {
  max-width: 700px;
  width: 100%;
}

.footBody .copyright {
  color: #fff;
  font-size: 1.2rem;
  font-style: normal;
  line-height: 1.5;
}

/* ===========================================================
 Layout
=========================================================== */
main {
  grid-area: main;
  padding: 20px 0 40px;
}

.contentPane {
  margin-bottom: 40px;
}

.contentPane:last-child {
  margin-bottom: 0;
}

.contentArea {
  padding: 0 var(--content-area-sidePadding);
  max-width: var(--content-area-width);
  margin: 0 auto;
}

.mainVisual .contentArea {
  padding: 0;
}


/* ===========================================================
breadcrumbs
=========================================================== */
.breadcrumbPane {
  margin-bottom: 1em;
}

.breadcrumb ol {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  margin: 0;
  padding: 0;
  color: #444444;
  font-weight: 500;
  gap: 0.5em;
}

.breadcrumb li {
  margin: 0;
}

.breadcrumb ol li:not(:last-child)::after {
  content: ">";
  padding-left: 0.5em;
}

.breadcrumb ol li a {
  color: #444444;
}

/* ===========================================================
 List
=========================================================== */
/*2列並び 左寄せ　右寄せの設定*/
ul.half,
ul.row-left,
ul.row-right {
  display: flex;
  gap: 0.5em 3em;
  flex-wrap: wrap;
}

ul.half li {
  width: calc(50% - 1.5em);
}

ul.row-right {
  justify-content: flex-end;
}

.defaultList {
  margin-left: 1em;
}

.defaultList li {
  list-style: none;
  text-indent: -1em;
}

/* listIcon   ------------------------------------------------*/
.listIcon>li {
  padding-left: 1.5em;
  list-style: none;
  position: relative;
}

.listIcon>li::before {
  content: '';
  display: block;
  background: var(--theme-color-red);
  width: 10px;
  height: 10px;
  border-radius: 100%;
  position: absolute;
  left: 0;
  top: 0.5em;
}

/* group_list (listIconと併用)  ------------------------------------------------*/
.listIcon.group_list {
  font-weight: bold;
  font-size: 1.7rem;
  margin-left: 0;
}

.listIcon.group_list li {
  margin-bottom: 1em;
}

.listIcon.group_list a {
  color: var(--theme-fontColor-black);
}

.listIcon.group_list .gl_name {
  font-size: 1.4rem;
  font-weight: normal;
}



/* listArrow   ------------------------------------------------*/
.listArrow li {
  padding-left: 0.75em;
  position: relative;
  list-style: none;
}

.listArrow li::before {
  content: "";
  display: block;
  background: var(--theme-color-red);
  height: calc(0.5em / 2 * tan(60deg));
  width: 0.4em;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  position: absolute;
  top: 0.5em;
  left: 0;
}

/* ===========================================================
Table
=========================================================== */
/*-- 基本設定 --*/
table {
  width: 100%;
  border: 3px solid #d7d7d7;
  border-collapse: collapse;
  margin-bottom: 1.5em;
  text-align: left;
}

th,
td {
  padding: 10px;
  border: 1px solid #d7d7d7;
}

th {
  font-weight: bold;
  background: #f3f3f3;
}

/*-- 中央寄せ --*/
table.th_center th {
  text-align: center;
}

table.td_center td {
  text-align: center;
}

/*-- 左寄せ --*/
table.th_right th {
  text-align: right;
}

table.td_right td {
  text-align: right;
}

/*--SP版（画面幅896px以下）のとき、縦積みにする--*/
table.table-stack-sp thead {
  display: none;
}

table.table-stack-sp th,
table.table-stack-sp td {
  display: block;
  border: none;
  border-bottom: 1px solid #d7d7d7;
}

table.table-stack-sp td::before {
  content: attr(data-label);
  display: block;
  font-size: 1.2rem;
  width: fit-content;
  margin-bottom: 0.2rem;
  background: #f3f3f3;
  padding: 0.3em 0.5em;
  border: 1px solid #d7d7d7;
}

/*--member_list　(table-stack-spと併用します)--*/
table.table-stack-sp.member_list th,
table.table-stack-sp.member_list td {
  border: none;
}

table.table-stack-sp.member_list tr td:last-child {
  border: none;
  border-bottom: 1px solid #d7d7d7;
}

table.table-stack-sp.member_list td.photo::before,
table.table-stack-sp.member_list td.name::before {
  display: none;
}

table.table-stack-sp.member_list td.photo {
  text-align: center;
}

table.table-stack-sp.member_list td.photo img {
  margin: auto;
  max-width: 300px;
  width: 100%;
}

table.table-stack-sp.member_list td.name {
  font-weight: bold;
  text-align: center;
}

/* ===========================================================
newsList
=========================================================== */

ul.newsList {
  list-style: none;
  padding: 0;
  margin: 0 0 2em;
  display: flex;
  gap: 1.2em;
  flex-direction: column;
}

ul.newsList>li {
  margin-bottom: 0;
  border-bottom: 1px dotted #cccccc;
  padding-bottom: 1em;
  display: flex;
  flex-direction: column;
  gap: 0.3em;
  width: 100%;
}

ul.newsList>li time {
  display: block;
  margin-bottom: 0.5em;
}

/* ===========================================================
site map List
=========================================================== */
ul.sitemapList {
  list-style: none;
  margin: 0.5em 0 1.5em 0;
  padding-left: 0;
  border-top: dotted 1px #d7d7d7;
}

ul.sitemapList ul {
  padding-left: 15px;
  padding-bottom: 0;
  margin-bottom: 0;

}

ul.sitemapList li {
  list-style: none;
  border-bottom: dotted 1px #d7d7d7;
  position: relative;
  margin-bottom: 0;
}

ul.sitemapList>li,
ul.sitemapList>li>li {
  font-size: var(--fontsz-l);
}

ul.sitemapList>li li li {
  font-size: var(--fontsz-m);
}

ul.sitemapList>li li:last-child {
  border-bottom: none;
}

.sitemapList li a {
  display: block;
  color: var(--theme-fontColor-black);
  text-decoration: none;
  padding: 0.5em 0 0.5em 15px;
}

.sitemapList li a::before {
  content: "";
  display: block;
  background-color: #717070;
  height: calc(0.5em / 2 * tan(60deg));
  width: 0.4em;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  position: absolute;
  top: 1.1em;
  left: 0;
}

ul.sitemapList>li>a::before,
ul.sitemapList>li>ul>li>a::before {
  background: var(--theme-color-red);
}

.sitemapList li a:focus-visible {
  text-decoration: none;
  background-color: #eeeeee;
}

@media (any-hover: hover) {
  .sitemapList li a:any-link:hover {
    text-decoration: none;
    background-color: #eeeeee;
  }
}

/* ===========================================================
imageTextBox
=========================================================== */
/* 画像・テキスト横並び ------------------------------------------------*/
.imageTextBox {
  display: flex;
  gap: 3em;
  margin-bottom: 3em;
  flex-direction: column;
}

.imageTextBox .txtBox {
  flex: 1;
  width: 100%;
}

.imageTextBox .imgBox {
  text-align: center;
  margin: auto;
}

.imageTextBox .imgBox img {
  margin: 0 auto 0.7em;
  max-width: 500px;
}

/* 画像・テキスト横並び 枠なし（2カラム） ------------------------------------------------*/
.columnbox {
  margin: 30px auto;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

.columnbox div.text_area {
  max-width: 49%;
}

.columnbox div.photo_area {
  max-width: 49%;
  display: table;
}

.columnbox div.photo_area img {
  max-width: 470px;
  height: auto;
}

.txtbox>div:not(:first-of-type),
.columnbox>div:nth-child(2) {
  margin: 0 0 0 20px;
}

.txtbox div.photo_area .caption,
.columnbox div.photo_area .caption {
  display: table-caption;
  caption-side: bottom;
  padding: 10px 0 0;
  text-align: center;
}

/*========================================================
 grayLineBox
 ========================================================*/
.grayLineBox {
  border: 5px solid #e6e5e5;
  padding: 12px;
}

.grayLineBox :where(h2, h3, h4, h5, h6) {
  margin: 0 0 15px 0;
  padding: 10px 0 10px 10px;
  font-size: var(--fontsz-l);
  font-weight: normal;
  background: #f3f3f3;
  border-left: var(--theme-color-red) solid 1px;
  border-bottom: none;
}

.grayLineBox *:last-child {
  margin-bottom: 0;
}

/*========================================================
 button
 ========================================================*/
/* ボタン  ------------------------------------------------*/
.comBtn {
  margin-bottom: 3px;
  text-align: center;
  margin: 0 auto 1.5em;
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
}

.comBtn a {
  padding: 15px 30px 15px 15px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 170px;
  color: #ffffff;
  font-size: 1.4rem;
  text-decoration: none;
  line-height: 1.2;
  background: url(../img/common/ico_arrow01_white.svg) #001730 no-repeat right 10px center / 7px auto;
}

.comBtn a:focus-visible {
  opacity: 0.7;
}

@media (any-hover: hover) {
  .comBtn a:any-link:hover {
    opacity: 0.7;
  }
}


/* 横並びボタン(comBtnと併用) ------------------------------------------------*/

.comBtnList.comBtn {
  text-align: left;

}

.comBtnList.comBtn li {
  list-style: none;
  padding: 0;
  width: 100%;
  margin-bottom: 0;
}

.comBtnList.comBtn a {
  width: 100%;
}

/* comTextUl   ------------------------------------------------*/
.comTextUl {
  padding: 0;
  margin: 0 0 1.5em;
  list-style: none;
  gap: 10px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  flex-direction: column;
  text-align: left;
}

.comTextUl li {
  margin-bottom: 0;
}

.comTextUl>li {
  padding: 0;
  list-style: none;
  border: 1px solid #ccc;
}

.comTextUl>li a {
  color: var(--theme-fontColor-black);
  text-decoration: none;
  padding: 20px;
  /* min-height: 198px; */
  height: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  border-right: 25px solid #eee;
  position: relative;
}

.comTextUl>li a span.title {
  margin-bottom: 9px;
  font-size: 1.5rem;
  font-weight: bold;
  display: block;
}

.comTextUl>li a::after {
  width: 14px;
  height: 14px;
  right: -15px;
  top: 50%;
  transform: translateY(-50%);
  color: #eee;
  position: absolute;
  content: "";
  background: url("../img/common/ico_arrow01_black.svg") no-repeat right center / 7px auto;
}

.comTextUl>li:focus-visible {
  border-color: #115c9e;
}

.comTextUl>li a:focus-visible {
  color: #115c9e;
  border-color: #115c9e;
}

@media (any-hover: hover) {
  .comTextUl>li:hover {
    border-color: #115c9e;
  }

  .comTextUl>li a:any-link:hover {
    color: #115c9e;
    border-color: #115c9e;
  }

  .comTextUl>li a:any-link:hover::after {
    background: url("../img/common/ico_arrow01_white.svg") no-repeat right center / 7px auto;
  }

}

/*------------------------------------------------------------
	微調整用
------------------------------------------------------------*/

.alignRight {
  text-align: right !important;
}

.alignCenter {
  text-align: center !important;
}

.alignLeft {
  text-align: left !important;
}

.attentionRed {
  font-weight: bold;
  color: var(--theme-color-red);
}