@charset "UTF-8";
/* CSS Document */
/*=======================================
  共　通
=======================================*/
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz@0,14..32;1,14..32&family=Noto+Sans+JP:wght@100..900&family=Zen+Kaku+Gothic+Antique:wght@500&family=Zen+Old+Mincho&display=swap');
/*
:root {
	--KOKUYO-TEXT-DARK: #454545;
}
body.kc_GREEN .kc_bg{background: var(--KOKUYO-GREEN)!important;}
*/
/*
#loadArea {
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 10000;
	visibility: visible;
	opacity: 1;
	background: #fff;
	transition:
		opacity 0.8s ease,
		visibility 0.8s ease;
	z-index: 10000;
}
body.is-loaded #loadArea{
	visibility: hidden;
	opacity: 0;
}
#loadArea .loadpBar {
	position: fixed;
	top:50%;
	left:0;
	background: #000;
	height: 1px;
	width: 0;
	transition: width 0.2s ease;
}
#loadArea .loadPer {
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 9999;
	transform: translate(-50%, -50%);
	font-size: 50px;
}
*/

html {
	background:#fff;
	color:#000;
	font-size: 625%;/*rem用100px*/
	/*scrollbar hidden*/
	/*-ms-overflow-style: none;*//* IE, Edge 対応 */
	/*scrollbar-width: none;*//* Firefox 対応 */
}
/*scrollbar hidden*/
html::-webkit-scrollbar {/* Chrome, Safari 対応 */
	/*display:none;*/
}

html.lock{
	overflow: hidden;
	-ms-touch-action: none;
	touch-action: none;
}

body{
	/*font-size:12px;*/
	font-size: 0.12em;/*rem用12px 以下rem chrome対策でem 以下fontsizeはremで1/100指定*/
	font-family: "Noto Sans JP", "Noto Sans", sans-serif;
	font-weight: 300;
	font-style: normal;
	font-feature-settings: "palt";/*Google Notoは効く、Adobe notoは効かない、メイリオは効かない*/
	line-height:1.0;
	letter-spacing:0.1em;
	-webkit-text-size-adjust: 100%;/*スマホ文字拡大対策*/
}
.fmin_zr{
  font-family: "Zen Old Mincho", serif !important;
  font-weight: 400 !important;
}
.fgo_m{
	font-family: "Zen Kaku Gothic Antique", sans-serif !important;
  font-weight: 500 !important;
}
.fen_m{
	font-family: 'Inter','Noto Sans JP', sans-serif !important;
	font-optical-sizing: auto;
  font-weight: 500!important;
}
.fen_sb{
	font-family: 'Inter','Noto Sans JP', sans-serif !important;
	font-optical-sizing: auto;
  font-weight: 600!important;
}
.fen_b{
	font-family: 'Inter','Noto Sans JP', sans-serif !important;
	font-optical-sizing: auto;
  font-weight: 700!important;
}

::selection {
  color: white;
  background-color: #727171;
}

/* --A-- */
a {
	cursor:pointer;
	text-decoration:none;
	-webkit-tap-highlight-color:rgba(0,0,0,0);/*リンクタップ時のハイライト表示無効*/
	color: #000;
}
a.noLink{cursor: default;}

a:active {
	text-decoration:none;
}
/* --HEADLINE-- */
h1, h2, h3, h4, h5, h6 {
	font-size:100%;
	margin:0;
	font-weight: 300;
	/*max-height: 100%;android chrome 文字大きくなるバグ対策→meta initial-scale あれば大丈夫*/
}
/* --OTHER TAGS-- */
p {
	margin-bottom:0;
	text-align:left;
	width:auto;
	/*max-height: 100%;android chrome 文字大きくなるバグ対策→meta initial-scale あれば大丈夫*/
}
em, strong {
	font-weight:bold;
}
/* --clearfix-- */
.clf:after{
	content: ".";
	display: block;
	height: 0;
	font-size:0;
	clear: both;
	visibility:hidden;
}
.clf{
	display: inline-block;
}
	/* Hides from IE Mac */
	* html .clf{
		height: 1%;
	}
	.clf{
		display:block;
	}
	

.vm,
.vmTxt{
	display: inline-block;
	position: relative;
	top:50%;
	transform: translateY(-50%);
}
/*========
上下中央寄せ
========*/
/*上下中央寄せ*/
.vmf,
.sp_vmf{
	display: flex;
	flex-direction: column;
	justify-content: center;
}
/*上下左右中央寄せ*/
.vmf_c,
.sp_vmf_c{
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}
.vmg_c,
.sp_vmg_c{
	display: grid;
	place-content: center;
	place-items: center;
}
.flex,
.sp_flex{
	display: flex;
}
.f_warp,.sp_f_warp	{flex-wrap: wrap;}
.f_ac,.sp_f_ac			{align-items: center;}
.f_as,.sp_f_as			{align-items: flex-start;}
.f_ae,.sp_f_ae			{align-items: flex-end;}
.f_dr,.sp_f_dr			{flex-direction: row-reverse;}/*逆順*/
.f_dc,.sp_f_dc			{flex-direction: column;}
.f_cc,.sp_f_cc			{justify-content: center;}
.f_ce,.sp_f_ce			{justify-content: flex-end;}/*後ろ付き*/
.f_cb,.sp_f_cb			{justify-content: space-between;}
.f_warp.f_fit > *,
.f_warp.sp_f_fit > *,
.sp_f_warp.sp_f_fit	> *,
.sp_f_warp.f_fit > *{
  flex: 1;
  min-width: fit-content;
}

.grid,
.sp_grid{display: grid;}
.grid .ga1,
.sp_grid .sp_ga1{grid-area: 1/1;}


.phShowAni{
  position: relative;
  overflow: hidden;
}

.phShowAni::after{
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top:0;
  left:0;
  background: #FFF;
  transform: translateX(0%);
  transition: transform 4s 0s var(--easeing);
}
.phKey.show .phShowAni::after,
.phShowAni.show::after{transform: translateX(100%);}


.opBtf a,
a.opBtf{
	opacity: 1;
	transition: opacity 0.25s ease;
}
.opBtf a:not(.noLink):active,
a.opBtf:not(.noLink):active{
	opacity: 0.5;
	transition: opacity 0.35s ease;
}

a.op_hov .op{
	opacity: 1;
	transition: opacity 0.25s ease;
}
a.op_hov:not(.noLink):active .op{
	opacity: 0.5;
	transition: opacity 0.35s ease;
}


.zoomBt a,
a.zoomBt{
	transform: scale(1.0);
	transition: transform 0.35s ease;
}
.zoomBt a,
a.zoomBt,
.zoomBt a *,
a.zoomBt *{
	backface-visibility: hidden;/*chrome transition 1pxズレ対策*/
}
.zoomBt a:not(.noLink):active,
a.zoomBt:not(.noLink):active{
	transition: transform 0.2s ease;
	transform: scale(1.15);
}


a.zoomImg_hov img.zoomImg,
.zoomImg_hovKey:has(a.zoomImg_hov) img.zoomImg{
	transform: scale(1);
	transition: transform 0.75s ease;
}
a.zoomImg_hov:not(.noLink):active img.zoomImg,
.zoomImg_hovKey:has(a.zoomImg_hov:not(.noLink):active) img.zoomImg,
.imgShowKey.show .zoomImg_hovKey:has(a.zoomImg_hov:not(.noLink):active) img.zoomImg,
.imgShowKey.show a.zoomImg_hov:not(.noLink):active img.zoomImg{
	transform: scale(1.1);
}

/*imgShowKeyとinViewを併用*/
.imgShowKey img.imgShowAni,
.imgShowKey .zoomImg_hovKey:has(a.zoomImg_hov) img.imgShowAni,
.imgShowKey a.zoomImg_hov img.imgShowAni{
	opacity: 0;
	transform: scale(1.3);
	transition:
		opacity 1s ease,
		transform 1s ease;
}
.imgShowKey.show img.imgShowAni,
.imgShowKey.show .zoomImg_hovKey:has(a.zoomImg_hov) img.imgShowAni,
.imgShowKey.show a.zoomImg_hov img.imgShowAni{
	opacity: 1;
	transform: scale(1.0);
}


a.txt_hovAni_1px,
a.txt_hovAni_2px {
  display: inline;
  background-image: linear-gradient(#000, #000);
  background-position: 0% 100%;
  background-repeat: no-repeat;
	transition: background 0.35s ease;
	padding: 2px 0;
}
a.txt_hovAni_1px {background-size: 0% 1px;}
a.txt_hovAni_2px {background-size: 0% 2px;}
a.txt_hovAni_1px:active {background-size: 100% 1px;}
a.txt_hovAni_2px:active {background-size: 100% 2px;}


a.line_hovAni_1px,
a.line_hovAni_2px{
  display: inline;
  background-image: linear-gradient(90deg,#000 0%, #000 50%, #CCC 50%,#CCC 100%);
	background-position: 100% 100%;
  background-repeat: no-repeat;
	transition: background-position 0.35s ease;
	padding: 2px 0;
}
a.line_hovAni_1px{background-size: 200% 1px;}
a.line_hovAni_2px{background-size: 200% 2px;}
a.line_hovAni_1px:active,
a.line_hovAni_2px:active{background-position: 0% 100%;}



#loaderOuter{
	position:fixed;
	width:100%;
	height:100%;
	z-index:499;
	background:#FFF;
}
#loader{
	position: fixed;
	top:50%;
	left:50%;
	z-index:90;
}
.pc{display: none !important;}
/*.pc{display: none !important;}*/

.noEvent{pointer-events:none;}/*IE11以降（IE11ではaタグには利かない）*/
.wrapper{}
.yokoSc::-webkit-scrollbar,
.yokoSc_pc::-webkit-scrollbar {
	display: none;
}

.obFit,
.obFit_ct{width: 100%;height: 100%;}
.obFit   {object-fit: cover;}
.obFit_ct{object-fit: contain;}
.obPos_tc,
.sp_obPos_tc{object-position: top center;}

.cover,
.contain{
	width: auto;
  height: auto;
  display: block;
}
.cover {
  min-width: 100%;
  min-height: 100%;
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
}
*:has( > .cover){
	position: relative;
	overflow: hidden;
}
.contain {
	max-width: 100%;
	max-height: 100%;
}



.bdr999{
	isolation: isolate;
	border-radius: 9999px;
}
/*splide利用するしているページでoverflow:hiddeen;など使っている要素に*/
.willc_trans{will-change: transform;}





/*txtBtAni*/
a .txtBtAni{display: inline-block;}
a:active:not(.noLink) .txtBtAni{
	position: relative;
	animation: txtBtAni 0.5s ease 0s 1 normal both;
}
@keyframes         txtBtAni {
	0% {
		top: 0;
		opacity: 1;
	}
	30% {
		top: -0.25em;
		opacity: 0;
	}
	31% {
		top: 0.25em;
		opacity: 0;
	}
	100% {
		top:0;
		opacity: 1;
	}
}


a.btBgAni:not(:has(.btBg_tgt)),
a.btBgAni .btBg_tgt{
	position: relative;
	overflow: hidden;
}
a.btBgAni:not(:has(.btBg_tgt))::after,
a.btBgAni .btBg_tgt::after{
	content: '';
	width: 100%;
	height: calc(100% + 4px);
	display: block;
	position: absolute;
	top:-2px;
	left:0;
	transform: scale(0, 1);
  transform-origin: right top;
	transition: transform 0.35s ease;
	z-index: 0;
}
a.btBgAni.btBg_bk::after,
a.btBgAni .btBg_tgt.btBg_bk::after{background: #000;}
a.btBgAni.btBg_w::after,
a.btBgAni .btBg_tgt.btBg_w::after{background: #FFF;}
a.btBgAni:not(:has(.btBg_tgt)):not(.noLink):active::after,
a.btBgAni:not(.noLink):active .btBg_tgt::after{
	transform: scale(1, 1);
  transform-origin: left top;
}

a.btBgAni .hovTxt{
	transition: color 0.35s ease;
	position: relative;
	z-index: 1;
}
a.btBgAni.btBg_bk .hovTxt,
a.btBgAni .btBg_bk .hovTxt{color: #000;}
a.btBgAni.btBg_bk:not(.noLink):active .hovTxt,
a.btBgAni:not(.noLink):active .btBg_bk .hovTxt{color: #FFF;}
a.btBgAni.btBg_w .hovTxt,
a.btBgAni .btBg_w .hovTxt{color: #FFF;}
a.btBgAni.btBg_w:not(.noLink):active .hovTxt,
a.btBgAni:not(.noLink):active .btBg_w .hovTxt{color: #000;}


/*icon_next*/
a.icon_next .icon{
	display: grid;
	place-content: center;
	place-items: center;
	transition: background 0.35s ease;
}
a.icon_next .icon::before{
	content: '';
	display: block;
	mask-size: 100% 100%;
	transition: background 0.35s ease;
}
a.icon_next .icon_arrow01::before{
	width: 17px;
	height: 10px;
	mask-image: url('../img/icon_arrow01.svg');
}
a.icon_next .icon_bk::before				{background: #000;}
a.icon_next .icon_w::before					{background: rgba(255,255,255,1);}
a.icon_next .icon_wBk::before				{background: rgba(255,255,255,1);}
a.icon_next:active .icon_wBk::before	{background: rgba(0,0,0,1);}

a.icon_next:active .icon.iconAni::before					{animation: iconAni 0.5s ease 0.1s 1 normal both;}
a.icon_next:active .icon.iconAni_deg90::before		{animation: iconAni_deg90 0.5s ease 0.1s 1 normal both;}
a.icon_next:active .icon.iconAni_deg-90::before	{animation: iconAni_deg-90 0.5s ease 0.1s 1 normal both;}
@keyframes         iconAni {
	0% {
		transform: translateX(0px);
		opacity: 1;
	}
	50% {
		transform: translateX(10px);
		opacity: 0;
	}
	51% {
		transform: translateX(-10px);
		opacity: 0;
	}
	100% {
		transform: translateX(0px);
		opacity: 1;
	}
}
@keyframes         iconAni_deg90 {
	0% {
		transform: translateY(0);
		opacity: 1;
	}
	50% {
		transform: translateY(10px);
		opacity: 0;
	}
	51% {
		transform: translateY(-10px);
		opacity: 0;
	}
	100% {
		transform: translateY(0);
		opacity: 1;
	}
}
@keyframes         iconAni_deg-90 {
	0% {
		transform: translateY(0);
		opacity: 1;
	}
	50% {
		transform: translateY(-10px);
		opacity: 0;
	}
	51% {
		transform: translateY(10px);
		opacity: 0;
	}
	100% {
		transform: translateY( 0);
		opacity: 1;
	}
}

/*oneByOneTxt*/
.oneByOneTxt,
.oneByOneTxt span{opacity: 0;}
.oneByOneTxt span{display: inline-block; transform: translateY(0.35em);}
.oneByOneTxt.startAni{opacity: 1;}
.oneByOneTxt.startAni span{animation: oneByOneAni 0.35s ease-out forwards;}
@-webkit-keyframes oneByOneAni {
	0% {
		transform: translateY(0.35em);
		opacity: 0;
	}
	100% {
		transform: translateY(0);
		opacity: 1;
	}
}
@keyframes         oneByOneAni {
	0% {
		transform: translateY(0.35em);
		opacity: 0;
	}
	100% {
		transform: translateY(0);
		opacity: 1;
	}
}

/* noise
=============================*/
:root {
  --w_xxs: 70%;
  --w_xs: 88%;
  --w_s: 90%;
  --w_m: 92%;
  --w_l: 95%;
  --w_xl: 98%;
  --w_xxl: 105%;

	--noiseBg01_1: #78C1E1;
  --noiseBg01_2: #25425A;
  --noiseBg01_3: #89F1D7;
  --noiseBg01_4: #000000;

  --noiseBg02_1: #E192FF;
  --noiseBg02_2: #25425A;
  --noiseBg02_3: #5A35FF;
  --noiseBg02_4: #000000;

  --noiseBg03_1: #75552C;
  --noiseBg03_2: #E0D8A7;
  --noiseBg03_3: #BF3F2C;
  --noiseBg03_4: #000000;

  --noiseBg04_1: #1561B7;
  --noiseBg04_2: #9B9CA1;
  --noiseBg04_3: #2e4a69;
  --noiseBg04_4: #000000;

  --noiseBg05_1: #000;
  --noiseBg05_2: #B5B5B6;
  --noiseBg05_3: #231815; 
  --noiseBg05_4: #727171;

  --noiseBg06_1: #25425A;
  --noiseBg06_2: #422A16;
  --noiseBg06_3: #C5994B; 
  --noiseBg06_4: #C7D93B;

  --noiseBg07_1: #000;
  --noiseBg07_2: #B5B5B6;
  --noiseBg07_3: #3D372F; 
  --noiseBg07_4: #F0CA79;

	/*about*/
	--noiseBg08_1: #000;
  --noiseBg08_2: #B5B5B6;
  --noiseBg08_3: #2D5F4B; 
  --noiseBg08_4: #727171;

	/*pjt*/
	--noiseBg09_1: #000;
  --noiseBg09_2: #B5B5B6;
  --noiseBg09_3: #D6D6E2; 
  --noiseBg09_4: #C2BAB2;

  --noise01_01: linear-gradient(90deg, var(--noiseBg01_1) 0%, var(--noiseBg01_1) 33.3333%, var(--noiseBg01_2) 33.3333%, var(--noiseBg01_2) 66.6666%, var(--noiseBg01_1) 66.6666%, var(--noiseBg01_1) 100%);
  --noise01_02: linear-gradient(90deg, var(--noiseBg01_1) 0%, var(--noiseBg01_1) 33.3333%, var(--noiseBg01_3) 33.3333%, var(--noiseBg01_3) 66.6666%, var(--noiseBg01_1) 66.6666%, var(--noiseBg01_1) 100%);
  --noise01_03: linear-gradient(90deg, var(--noiseBg01_1) 0%, var(--noiseBg01_1) 33.3333%, var(--noiseBg01_4) 33.3333%, var(--noiseBg01_4) 66.6666%, var(--noiseBg01_1) 66.6666%, var(--noiseBg01_1) 100%);
  --noise01_04: linear-gradient(90deg, var(--noiseBg01_2) 0%, var(--noiseBg01_2) 33.3333%, var(--noiseBg01_1) 33.3333%, var(--noiseBg01_1) 66.6666%, var(--noiseBg01_2) 66.6666%, var(--noiseBg01_2) 100%);
  --noise01_05: linear-gradient(90deg, var(--noiseBg01_2) 0%, var(--noiseBg01_2) 33.3333%, var(--noiseBg01_3) 33.3333%, var(--noiseBg01_3) 66.6666%, var(--noiseBg01_2) 66.6666%, var(--noiseBg01_2) 100%);
  --noise01_06: linear-gradient(90deg, var(--noiseBg01_2) 0%, var(--noiseBg01_2) 33.3333%, var(--noiseBg01_4) 33.3333%, var(--noiseBg01_4) 66.6666%, var(--noiseBg01_2) 66.6666%, var(--noiseBg01_2) 100%);
  --noise01_07: linear-gradient(90deg, var(--noiseBg01_3) 0%, var(--noiseBg01_3) 33.3333%, var(--noiseBg01_1) 33.3333%, var(--noiseBg01_1) 66.6666%, var(--noiseBg01_3) 66.6666%, var(--noiseBg01_3) 100%);
  --noise01_08: linear-gradient(90deg, var(--noiseBg01_3) 0%, var(--noiseBg01_3) 33.3333%, var(--noiseBg01_2) 33.3333%, var(--noiseBg01_2) 66.6666%, var(--noiseBg01_3) 66.6666%, var(--noiseBg01_3) 100%);
  --noise01_09: linear-gradient(90deg, var(--noiseBg01_3) 0%, var(--noiseBg01_3) 33.3333%, var(--noiseBg01_4) 33.3333%, var(--noiseBg01_4) 66.6666%, var(--noiseBg01_3) 66.6666%, var(--noiseBg01_3) 100%);
  --noise01_10: linear-gradient(90deg, var(--noiseBg01_4) 0%, var(--noiseBg01_4) 33.3333%, var(--noiseBg01_1) 33.3333%, var(--noiseBg01_1) 66.6666%, var(--noiseBg01_4) 66.6666%, var(--noiseBg01_4) 100%);
  --noise01_11: linear-gradient(90deg, var(--noiseBg01_4) 0%, var(--noiseBg01_4) 33.3333%, var(--noiseBg01_2) 33.3333%, var(--noiseBg01_2) 66.6666%, var(--noiseBg01_4) 66.6666%, var(--noiseBg01_4) 100%);
  --noise01_12: linear-gradient(90deg, var(--noiseBg01_4) 0%, var(--noiseBg01_4) 33.3333%, var(--noiseBg01_3) 33.3333%, var(--noiseBg01_3) 66.6666%, var(--noiseBg01_4) 66.6666%, var(--noiseBg01_4) 100%);

  --noise02_01: linear-gradient(90deg, var(--noiseBg02_1) 0%, var(--noiseBg02_1) 33.3333%, var(--noiseBg02_2) 33.3333%, var(--noiseBg02_2) 66.6666%, var(--noiseBg02_1) 66.6666%, var(--noiseBg02_1) 100%);
  --noise02_02: linear-gradient(90deg, var(--noiseBg02_1) 0%, var(--noiseBg02_1) 33.3333%, var(--noiseBg02_3) 33.3333%, var(--noiseBg02_3) 66.6666%, var(--noiseBg02_1) 66.6666%, var(--noiseBg02_1) 100%);
  --noise02_03: linear-gradient(90deg, var(--noiseBg02_1) 0%, var(--noiseBg02_1) 33.3333%, var(--noiseBg02_4) 33.3333%, var(--noiseBg02_4) 66.6666%, var(--noiseBg02_1) 66.6666%, var(--noiseBg02_1) 100%);
  --noise02_04: linear-gradient(90deg, var(--noiseBg02_2) 0%, var(--noiseBg02_2) 33.3333%, var(--noiseBg02_1) 33.3333%, var(--noiseBg02_1) 66.6666%, var(--noiseBg02_2) 66.6666%, var(--noiseBg02_2) 100%);
  --noise02_05: linear-gradient(90deg, var(--noiseBg02_2) 0%, var(--noiseBg02_2) 33.3333%, var(--noiseBg02_3) 33.3333%, var(--noiseBg02_3) 66.6666%, var(--noiseBg02_2) 66.6666%, var(--noiseBg02_2) 100%);
  --noise02_06: linear-gradient(90deg, var(--noiseBg02_2) 0%, var(--noiseBg02_2) 33.3333%, var(--noiseBg02_4) 33.3333%, var(--noiseBg02_4) 66.6666%, var(--noiseBg02_2) 66.6666%, var(--noiseBg02_2) 100%);
  --noise02_07: linear-gradient(90deg, var(--noiseBg02_3) 0%, var(--noiseBg02_3) 33.3333%, var(--noiseBg02_1) 33.3333%, var(--noiseBg02_1) 66.6666%, var(--noiseBg02_3) 66.6666%, var(--noiseBg02_3) 100%);
  --noise02_08: linear-gradient(90deg, var(--noiseBg02_3) 0%, var(--noiseBg02_3) 33.3333%, var(--noiseBg02_2) 33.3333%, var(--noiseBg02_2) 66.6666%, var(--noiseBg02_3) 66.6666%, var(--noiseBg02_3) 100%);
  --noise02_09: linear-gradient(90deg, var(--noiseBg02_3) 0%, var(--noiseBg02_3) 33.3333%, var(--noiseBg02_4) 33.3333%, var(--noiseBg02_4) 66.6666%, var(--noiseBg02_3) 66.6666%, var(--noiseBg02_3) 100%);
  --noise02_10: linear-gradient(90deg, var(--noiseBg02_4) 0%, var(--noiseBg02_4) 33.3333%, var(--noiseBg02_1) 33.3333%, var(--noiseBg02_1) 66.6666%, var(--noiseBg02_4) 66.6666%, var(--noiseBg02_4) 100%);
  --noise02_11: linear-gradient(90deg, var(--noiseBg02_4) 0%, var(--noiseBg02_4) 33.3333%, var(--noiseBg02_2) 33.3333%, var(--noiseBg02_2) 66.6666%, var(--noiseBg02_4) 66.6666%, var(--noiseBg02_4) 100%);
  --noise02_12: linear-gradient(90deg, var(--noiseBg02_4) 0%, var(--noiseBg02_4) 33.3333%, var(--noiseBg02_3) 33.3333%, var(--noiseBg02_3) 66.6666%, var(--noiseBg02_4) 66.6666%, var(--noiseBg02_4) 100%);

  --noise03_01: linear-gradient(90deg, var(--noiseBg03_1) 0%, var(--noiseBg03_1) 33.3333%, var(--noiseBg03_2) 33.3333%, var(--noiseBg03_2) 66.6666%, var(--noiseBg03_1) 66.6666%, var(--noiseBg03_1) 100%);
  --noise03_02: linear-gradient(90deg, var(--noiseBg03_1) 0%, var(--noiseBg03_1) 33.3333%, var(--noiseBg03_3) 33.3333%, var(--noiseBg03_3) 66.6666%, var(--noiseBg03_1) 66.6666%, var(--noiseBg03_1) 100%);
  --noise03_03: linear-gradient(90deg, var(--noiseBg03_1) 0%, var(--noiseBg03_1) 33.3333%, var(--noiseBg03_4) 33.3333%, var(--noiseBg03_4) 66.6666%, var(--noiseBg03_1) 66.6666%, var(--noiseBg03_1) 100%);
  --noise03_04: linear-gradient(90deg, var(--noiseBg03_2) 0%, var(--noiseBg03_2) 33.3333%, var(--noiseBg03_1) 33.3333%, var(--noiseBg03_1) 66.6666%, var(--noiseBg03_2) 66.6666%, var(--noiseBg03_2) 100%);
  --noise03_05: linear-gradient(90deg, var(--noiseBg03_2) 0%, var(--noiseBg03_2) 33.3333%, var(--noiseBg03_3) 33.3333%, var(--noiseBg03_3) 66.6666%, var(--noiseBg03_2) 66.6666%, var(--noiseBg03_2) 100%);
  --noise03_06: linear-gradient(90deg, var(--noiseBg03_2) 0%, var(--noiseBg03_2) 33.3333%, var(--noiseBg03_4) 33.3333%, var(--noiseBg03_4) 66.6666%, var(--noiseBg03_2) 66.6666%, var(--noiseBg03_2) 100%);
  --noise03_07: linear-gradient(90deg, var(--noiseBg03_3) 0%, var(--noiseBg03_3) 33.3333%, var(--noiseBg03_1) 33.3333%, var(--noiseBg03_1) 66.6666%, var(--noiseBg03_3) 66.6666%, var(--noiseBg03_3) 100%);
  --noise03_08: linear-gradient(90deg, var(--noiseBg03_3) 0%, var(--noiseBg03_3) 33.3333%, var(--noiseBg03_2) 33.3333%, var(--noiseBg03_2) 66.6666%, var(--noiseBg03_3) 66.6666%, var(--noiseBg03_3) 100%);
  --noise03_09: linear-gradient(90deg, var(--noiseBg03_3) 0%, var(--noiseBg03_3) 33.3333%, var(--noiseBg03_4) 33.3333%, var(--noiseBg03_4) 66.6666%, var(--noiseBg03_3) 66.6666%, var(--noiseBg03_3) 100%);
  --noise03_10: linear-gradient(90deg, var(--noiseBg03_4) 0%, var(--noiseBg03_4) 33.3333%, var(--noiseBg03_1) 33.3333%, var(--noiseBg03_1) 66.6666%, var(--noiseBg03_4) 66.6666%, var(--noiseBg03_4) 100%);
  --noise03_11: linear-gradient(90deg, var(--noiseBg03_4) 0%, var(--noiseBg03_4) 33.3333%, var(--noiseBg03_2) 33.3333%, var(--noiseBg03_2) 66.6666%, var(--noiseBg03_4) 66.6666%, var(--noiseBg03_4) 100%);
  --noise03_12: linear-gradient(90deg, var(--noiseBg03_4) 0%, var(--noiseBg03_4) 33.3333%, var(--noiseBg03_3) 33.3333%, var(--noiseBg03_3) 66.6666%, var(--noiseBg03_4) 66.6666%, var(--noiseBg03_4) 100%);

  --noise04_01: linear-gradient(90deg, var(--noiseBg04_1) 0%, var(--noiseBg04_1) 33.3333%, var(--noiseBg04_2) 33.3333%, var(--noiseBg04_2) 66.6666%, var(--noiseBg04_1) 66.6666%, var(--noiseBg04_1) 100%);
  --noise04_02: linear-gradient(90deg, var(--noiseBg04_1) 0%, var(--noiseBg04_1) 33.3333%, var(--noiseBg04_3) 33.3333%, var(--noiseBg04_3) 66.6666%, var(--noiseBg04_1) 66.6666%, var(--noiseBg04_1) 100%);
  --noise04_03: linear-gradient(90deg, var(--noiseBg04_1) 0%, var(--noiseBg04_1) 33.3333%, var(--noiseBg04_4) 33.3333%, var(--noiseBg04_4) 66.6666%, var(--noiseBg04_1) 66.6666%, var(--noiseBg04_1) 100%);
  --noise04_04: linear-gradient(90deg, var(--noiseBg04_2) 0%, var(--noiseBg04_2) 33.3333%, var(--noiseBg04_1) 33.3333%, var(--noiseBg04_1) 66.6666%, var(--noiseBg04_2) 66.6666%, var(--noiseBg04_2) 100%);
  --noise04_05: linear-gradient(90deg, var(--noiseBg04_2) 0%, var(--noiseBg04_2) 33.3333%, var(--noiseBg04_3) 33.3333%, var(--noiseBg04_3) 66.6666%, var(--noiseBg04_2) 66.6666%, var(--noiseBg04_2) 100%);
  --noise04_06: linear-gradient(90deg, var(--noiseBg04_2) 0%, var(--noiseBg04_2) 33.3333%, var(--noiseBg04_4) 33.3333%, var(--noiseBg04_4) 66.6666%, var(--noiseBg04_2) 66.6666%, var(--noiseBg04_2) 100%);
  --noise04_07: linear-gradient(90deg, var(--noiseBg04_3) 0%, var(--noiseBg04_3) 33.3333%, var(--noiseBg04_1) 33.3333%, var(--noiseBg04_1) 66.6666%, var(--noiseBg04_3) 66.6666%, var(--noiseBg04_3) 100%);
  --noise04_08: linear-gradient(90deg, var(--noiseBg04_3) 0%, var(--noiseBg04_3) 33.3333%, var(--noiseBg04_2) 33.3333%, var(--noiseBg04_2) 66.6666%, var(--noiseBg04_3) 66.6666%, var(--noiseBg04_3) 100%);
  --noise04_09: linear-gradient(90deg, var(--noiseBg04_3) 0%, var(--noiseBg04_3) 33.3333%, var(--noiseBg04_4) 33.3333%, var(--noiseBg04_4) 66.6666%, var(--noiseBg04_3) 66.6666%, var(--noiseBg04_3) 100%);
  --noise04_10: linear-gradient(90deg, var(--noiseBg04_4) 0%, var(--noiseBg04_4) 33.3333%, var(--noiseBg04_1) 33.3333%, var(--noiseBg04_1) 66.6666%, var(--noiseBg04_4) 66.6666%, var(--noiseBg04_4) 100%);
  --noise04_11: linear-gradient(90deg, var(--noiseBg04_4) 0%, var(--noiseBg04_4) 33.3333%, var(--noiseBg04_2) 33.3333%, var(--noiseBg04_2) 66.6666%, var(--noiseBg04_4) 66.6666%, var(--noiseBg04_4) 100%);
  --noise04_12: linear-gradient(90deg, var(--noiseBg04_4) 0%, var(--noiseBg04_4) 33.3333%, var(--noiseBg04_3) 33.3333%, var(--noiseBg04_3) 66.6666%, var(--noiseBg04_4) 66.6666%, var(--noiseBg04_4) 100%);


  --noise06_01: linear-gradient(90deg, var(--noiseBg05_1) 0%, var(--noiseBg05_1) 33.3333%, var(--noiseBg05_2) 33.3333%, var(--noiseBg05_2) 66.6666%, var(--noiseBg05_1) 66.6666%, var(--noiseBg05_1) 100%);
  --noise05_02: linear-gradient(90deg, var(--noiseBg05_1) 0%, var(--noiseBg05_1) 33.3333%, var(--noiseBg05_3) 33.3333%, var(--noiseBg05_3) 66.6666%, var(--noiseBg05_1) 66.6666%, var(--noiseBg05_1) 100%);
  --noise05_03: linear-gradient(90deg, var(--noiseBg05_1) 0%, var(--noiseBg05_1) 33.3333%, var(--noiseBg05_4) 33.3333%, var(--noiseBg05_4) 66.6666%, var(--noiseBg05_1) 66.6666%, var(--noiseBg05_1) 100%);
  --noise05_04: linear-gradient(90deg, var(--noiseBg05_2) 0%, var(--noiseBg05_2) 33.3333%, var(--noiseBg05_1) 33.3333%, var(--noiseBg05_1) 66.6666%, var(--noiseBg05_2) 66.6666%, var(--noiseBg05_2) 100%);
  --noise05_05: linear-gradient(90deg, var(--noiseBg05_2) 0%, var(--noiseBg05_2) 33.3333%, var(--noiseBg05_3) 33.3333%, var(--noiseBg05_3) 66.6666%, var(--noiseBg05_2) 66.6666%, var(--noiseBg05_2) 100%);
  --noise05_06: linear-gradient(90deg, var(--noiseBg05_2) 0%, var(--noiseBg05_2) 33.3333%, var(--noiseBg05_4) 33.3333%, var(--noiseBg05_4) 66.6666%, var(--noiseBg05_2) 66.6666%, var(--noiseBg05_2) 100%);
  --noise05_07: linear-gradient(90deg, var(--noiseBg05_3) 0%, var(--noiseBg05_3) 33.3333%, var(--noiseBg05_1) 33.3333%, var(--noiseBg05_1) 66.6666%, var(--noiseBg05_3) 66.6666%, var(--noiseBg05_3) 100%);
  --noise05_08: linear-gradient(90deg, var(--noiseBg05_3) 0%, var(--noiseBg05_3) 33.3333%, var(--noiseBg05_2) 33.3333%, var(--noiseBg05_2) 66.6666%, var(--noiseBg05_3) 66.6666%, var(--noiseBg05_3) 100%);
  --noise05_09: linear-gradient(90deg, var(--noiseBg05_3) 0%, var(--noiseBg05_3) 33.3333%, var(--noiseBg05_4) 33.3333%, var(--noiseBg05_4) 66.6666%, var(--noiseBg05_3) 66.6666%, var(--noiseBg05_3) 100%);
  --noise05_10: linear-gradient(90deg, var(--noiseBg05_4) 0%, var(--noiseBg05_4) 33.3333%, var(--noiseBg05_1) 33.3333%, var(--noiseBg05_1) 66.6666%, var(--noiseBg05_4) 66.6666%, var(--noiseBg05_4) 100%);
  --noise05_11: linear-gradient(90deg, var(--noiseBg05_4) 0%, var(--noiseBg05_4) 33.3333%, var(--noiseBg05_2) 33.3333%, var(--noiseBg05_2) 66.6666%, var(--noiseBg05_4) 66.6666%, var(--noiseBg05_4) 100%);
  --noise05_12: linear-gradient(90deg, var(--noiseBg05_4) 0%, var(--noiseBg05_4) 33.3333%, var(--noiseBg05_3) 33.3333%, var(--noiseBg05_3) 66.6666%, var(--noiseBg05_4) 66.6666%, var(--noiseBg05_4) 100%);

  --noise06_01: linear-gradient(90deg, var(--noiseBg06_1) 0%, var(--noiseBg06_1) 33.3333%, var(--noiseBg06_2) 33.3333%, var(--noiseBg06_2) 66.6666%, var(--noiseBg06_1) 66.6666%, var(--noiseBg06_1) 100%);
  --noise06_02: linear-gradient(90deg, var(--noiseBg06_1) 0%, var(--noiseBg06_1) 33.3333%, var(--noiseBg06_3) 33.3333%, var(--noiseBg06_3) 66.6666%, var(--noiseBg06_1) 66.6666%, var(--noiseBg06_1) 100%);
  --noise06_03: linear-gradient(90deg, var(--noiseBg06_1) 0%, var(--noiseBg06_1) 33.3333%, var(--noiseBg06_4) 33.3333%, var(--noiseBg06_4) 66.6666%, var(--noiseBg06_1) 66.6666%, var(--noiseBg06_1) 100%);
  --noise06_04: linear-gradient(90deg, var(--noiseBg06_2) 0%, var(--noiseBg06_2) 33.3333%, var(--noiseBg06_1) 33.3333%, var(--noiseBg06_1) 66.6666%, var(--noiseBg06_2) 66.6666%, var(--noiseBg06_2) 100%);
  --noise06_05: linear-gradient(90deg, var(--noiseBg06_2) 0%, var(--noiseBg06_2) 33.3333%, var(--noiseBg06_3) 33.3333%, var(--noiseBg06_3) 66.6666%, var(--noiseBg06_2) 66.6666%, var(--noiseBg06_2) 100%);
  --noise06_06: linear-gradient(90deg, var(--noiseBg06_2) 0%, var(--noiseBg06_2) 33.3333%, var(--noiseBg06_4) 33.3333%, var(--noiseBg06_4) 66.6666%, var(--noiseBg06_2) 66.6666%, var(--noiseBg06_2) 100%);
  --noise06_07: linear-gradient(90deg, var(--noiseBg06_3) 0%, var(--noiseBg06_3) 33.3333%, var(--noiseBg06_1) 33.3333%, var(--noiseBg06_1) 66.6666%, var(--noiseBg06_3) 66.6666%, var(--noiseBg06_3) 100%);
  --noise06_08: linear-gradient(90deg, var(--noiseBg06_3) 0%, var(--noiseBg06_3) 33.3333%, var(--noiseBg06_2) 33.3333%, var(--noiseBg06_2) 66.6666%, var(--noiseBg06_3) 66.6666%, var(--noiseBg06_3) 100%);
  --noise06_09: linear-gradient(90deg, var(--noiseBg06_3) 0%, var(--noiseBg06_3) 33.3333%, var(--noiseBg06_4) 33.3333%, var(--noiseBg06_4) 66.6666%, var(--noiseBg06_3) 66.6666%, var(--noiseBg06_3) 100%);
  --noise06_10: linear-gradient(90deg, var(--noiseBg06_4) 0%, var(--noiseBg06_4) 33.3333%, var(--noiseBg06_1) 33.3333%, var(--noiseBg06_1) 66.6666%, var(--noiseBg06_4) 66.6666%, var(--noiseBg06_4) 100%);
  --noise06_11: linear-gradient(90deg, var(--noiseBg06_4) 0%, var(--noiseBg06_4) 33.3333%, var(--noiseBg06_2) 33.3333%, var(--noiseBg06_2) 66.6666%, var(--noiseBg06_4) 66.6666%, var(--noiseBg06_4) 100%);
  --noise06_12: linear-gradient(90deg, var(--noiseBg06_4) 0%, var(--noiseBg06_4) 33.3333%, var(--noiseBg06_3) 33.3333%, var(--noiseBg06_3) 66.6666%, var(--noiseBg06_4) 66.6666%, var(--noiseBg06_4) 100%);

  --noise07_01: linear-gradient(90deg, var(--noiseBg07_1) 0%, var(--noiseBg07_1) 33.3333%, var(--noiseBg07_2) 33.3333%, var(--noiseBg07_2) 66.6666%, var(--noiseBg07_1) 66.6666%, var(--noiseBg07_1) 100%);
  --noise07_02: linear-gradient(90deg, var(--noiseBg07_1) 0%, var(--noiseBg07_1) 33.3333%, var(--noiseBg07_3) 33.3333%, var(--noiseBg07_3) 66.6666%, var(--noiseBg07_1) 66.6666%, var(--noiseBg07_1) 100%);
  --noise07_03: linear-gradient(90deg, var(--noiseBg07_1) 0%, var(--noiseBg07_1) 33.3333%, var(--noiseBg07_4) 33.3333%, var(--noiseBg07_4) 66.6666%, var(--noiseBg07_1) 66.6666%, var(--noiseBg07_1) 100%);
  --noise07_04: linear-gradient(90deg, var(--noiseBg07_2) 0%, var(--noiseBg07_2) 33.3333%, var(--noiseBg07_1) 33.3333%, var(--noiseBg07_1) 66.6666%, var(--noiseBg07_2) 66.6666%, var(--noiseBg07_2) 100%);
  --noise07_05: linear-gradient(90deg, var(--noiseBg07_2) 0%, var(--noiseBg07_2) 33.3333%, var(--noiseBg07_3) 33.3333%, var(--noiseBg07_3) 66.6666%, var(--noiseBg07_2) 66.6666%, var(--noiseBg07_2) 100%);
  --noise07_06: linear-gradient(90deg, var(--noiseBg07_2) 0%, var(--noiseBg07_2) 33.3333%, var(--noiseBg07_4) 33.3333%, var(--noiseBg07_4) 66.6666%, var(--noiseBg07_2) 66.6666%, var(--noiseBg07_2) 100%);
  --noise07_07: linear-gradient(90deg, var(--noiseBg07_3) 0%, var(--noiseBg07_3) 33.3333%, var(--noiseBg07_1) 33.3333%, var(--noiseBg07_1) 66.6666%, var(--noiseBg07_3) 66.6666%, var(--noiseBg07_3) 100%);
  --noise07_08: linear-gradient(90deg, var(--noiseBg07_3) 0%, var(--noiseBg07_3) 33.3333%, var(--noiseBg07_2) 33.3333%, var(--noiseBg07_2) 66.6666%, var(--noiseBg07_3) 66.6666%, var(--noiseBg07_3) 100%);
  --noise07_09: linear-gradient(90deg, var(--noiseBg07_3) 0%, var(--noiseBg07_3) 33.3333%, var(--noiseBg07_4) 33.3333%, var(--noiseBg07_4) 66.6666%, var(--noiseBg07_3) 66.6666%, var(--noiseBg07_3) 100%);
  --noise07_10: linear-gradient(90deg, var(--noiseBg07_4) 0%, var(--noiseBg07_4) 33.3333%, var(--noiseBg07_1) 33.3333%, var(--noiseBg07_1) 66.6666%, var(--noiseBg07_4) 66.6666%, var(--noiseBg07_4) 100%);
  --noise07_11: linear-gradient(90deg, var(--noiseBg07_4) 0%, var(--noiseBg07_4) 33.3333%, var(--noiseBg07_2) 33.3333%, var(--noiseBg07_2) 66.6666%, var(--noiseBg07_4) 66.6666%, var(--noiseBg07_4) 100%);
  --noise07_12: linear-gradient(90deg, var(--noiseBg07_4) 0%, var(--noiseBg07_4) 33.3333%, var(--noiseBg07_3) 33.3333%, var(--noiseBg07_3) 66.6666%, var(--noiseBg07_4) 66.6666%, var(--noiseBg07_4) 100%);

	/*about*/
  --noise08_01: linear-gradient(90deg, var(--noiseBg08_1) 0%, var(--noiseBg08_1) 33.3333%, var(--noiseBg08_2) 33.3333%, var(--noiseBg08_2) 66.6666%, var(--noiseBg08_1) 66.6666%, var(--noiseBg08_1) 100%);
  --noise08_02: linear-gradient(90deg, var(--noiseBg08_1) 0%, var(--noiseBg08_1) 33.3333%, var(--noiseBg08_3) 33.3333%, var(--noiseBg08_3) 66.6666%, var(--noiseBg08_1) 66.6666%, var(--noiseBg08_1) 100%);
  --noise08_03: linear-gradient(90deg, var(--noiseBg08_1) 0%, var(--noiseBg08_1) 33.3333%, var(--noiseBg08_4) 33.3333%, var(--noiseBg08_4) 66.6666%, var(--noiseBg08_1) 66.6666%, var(--noiseBg08_1) 100%);
  --noise08_04: linear-gradient(90deg, var(--noiseBg08_2) 0%, var(--noiseBg08_2) 33.3333%, var(--noiseBg08_1) 33.3333%, var(--noiseBg08_1) 66.6666%, var(--noiseBg08_2) 66.6666%, var(--noiseBg08_2) 100%);
  --noise08_05: linear-gradient(90deg, var(--noiseBg08_2) 0%, var(--noiseBg08_2) 33.3333%, var(--noiseBg08_3) 33.3333%, var(--noiseBg08_3) 66.6666%, var(--noiseBg08_2) 66.6666%, var(--noiseBg08_2) 100%);
  --noise08_06: linear-gradient(90deg, var(--noiseBg08_2) 0%, var(--noiseBg08_2) 33.3333%, var(--noiseBg08_4) 33.3333%, var(--noiseBg08_4) 66.6666%, var(--noiseBg08_2) 66.6666%, var(--noiseBg08_2) 100%);
  --noise08_07: linear-gradient(90deg, var(--noiseBg08_3) 0%, var(--noiseBg08_3) 33.3333%, var(--noiseBg08_1) 33.3333%, var(--noiseBg08_1) 66.6666%, var(--noiseBg08_3) 66.6666%, var(--noiseBg08_3) 100%);
  --noise08_08: linear-gradient(90deg, var(--noiseBg08_3) 0%, var(--noiseBg08_3) 33.3333%, var(--noiseBg08_2) 33.3333%, var(--noiseBg08_2) 66.6666%, var(--noiseBg08_3) 66.6666%, var(--noiseBg08_3) 100%);
  --noise08_09: linear-gradient(90deg, var(--noiseBg08_3) 0%, var(--noiseBg08_3) 33.3333%, var(--noiseBg08_4) 33.3333%, var(--noiseBg08_4) 66.6666%, var(--noiseBg08_3) 66.6666%, var(--noiseBg08_3) 100%);
  --noise08_10: linear-gradient(90deg, var(--noiseBg08_4) 0%, var(--noiseBg08_4) 33.3333%, var(--noiseBg08_1) 33.3333%, var(--noiseBg08_1) 66.6666%, var(--noiseBg08_4) 66.6666%, var(--noiseBg08_4) 100%);
  --noise08_11: linear-gradient(90deg, var(--noiseBg08_4) 0%, var(--noiseBg08_4) 33.3333%, var(--noiseBg08_2) 33.3333%, var(--noiseBg08_2) 66.6666%, var(--noiseBg08_4) 66.6666%, var(--noiseBg08_4) 100%);
  --noise08_12: linear-gradient(90deg, var(--noiseBg08_4) 0%, var(--noiseBg08_4) 33.3333%, var(--noiseBg08_3) 33.3333%, var(--noiseBg08_3) 66.6666%, var(--noiseBg08_4) 66.6666%, var(--noiseBg08_4) 100%);
  
/*about*/
  --noise09_01: linear-gradient(90deg, var(--noiseBg09_1) 0%, var(--noiseBg09_1) 33.3333%, var(--noiseBg09_2) 33.3333%, var(--noiseBg09_2) 66.6666%, var(--noiseBg09_1) 66.6666%, var(--noiseBg09_1) 100%);
  --noise09_02: linear-gradient(90deg, var(--noiseBg09_1) 0%, var(--noiseBg09_1) 33.3333%, var(--noiseBg09_3) 33.3333%, var(--noiseBg09_3) 66.6666%, var(--noiseBg09_1) 66.6666%, var(--noiseBg09_1) 100%);
  --noise09_03: linear-gradient(90deg, var(--noiseBg09_1) 0%, var(--noiseBg09_1) 33.3333%, var(--noiseBg09_4) 33.3333%, var(--noiseBg09_4) 66.6666%, var(--noiseBg09_1) 66.6666%, var(--noiseBg09_1) 100%);
  --noise09_04: linear-gradient(90deg, var(--noiseBg09_2) 0%, var(--noiseBg09_2) 33.3333%, var(--noiseBg09_1) 33.3333%, var(--noiseBg09_1) 66.6666%, var(--noiseBg09_2) 66.6666%, var(--noiseBg09_2) 100%);
  --noise09_05: linear-gradient(90deg, var(--noiseBg09_2) 0%, var(--noiseBg09_2) 33.3333%, var(--noiseBg09_3) 33.3333%, var(--noiseBg09_3) 66.6666%, var(--noiseBg09_2) 66.6666%, var(--noiseBg09_2) 100%);
  --noise09_06: linear-gradient(90deg, var(--noiseBg09_2) 0%, var(--noiseBg09_2) 33.3333%, var(--noiseBg09_4) 33.3333%, var(--noiseBg09_4) 66.6666%, var(--noiseBg09_2) 66.6666%, var(--noiseBg09_2) 100%);
  --noise09_07: linear-gradient(90deg, var(--noiseBg09_3) 0%, var(--noiseBg09_3) 33.3333%, var(--noiseBg09_1) 33.3333%, var(--noiseBg09_1) 66.6666%, var(--noiseBg09_3) 66.6666%, var(--noiseBg09_3) 100%);
  --noise09_08: linear-gradient(90deg, var(--noiseBg09_3) 0%, var(--noiseBg09_3) 33.3333%, var(--noiseBg09_2) 33.3333%, var(--noiseBg09_2) 66.6666%, var(--noiseBg09_3) 66.6666%, var(--noiseBg09_3) 100%);
  --noise09_09: linear-gradient(90deg, var(--noiseBg09_3) 0%, var(--noiseBg09_3) 33.3333%, var(--noiseBg09_4) 33.3333%, var(--noiseBg09_4) 66.6666%, var(--noiseBg09_3) 66.6666%, var(--noiseBg09_3) 100%);
  --noise09_10: linear-gradient(90deg, var(--noiseBg09_4) 0%, var(--noiseBg09_4) 33.3333%, var(--noiseBg09_1) 33.3333%, var(--noiseBg09_1) 66.6666%, var(--noiseBg09_4) 66.6666%, var(--noiseBg09_4) 100%);
  --noise09_11: linear-gradient(90deg, var(--noiseBg09_4) 0%, var(--noiseBg09_4) 33.3333%, var(--noiseBg09_2) 33.3333%, var(--noiseBg09_2) 66.6666%, var(--noiseBg09_4) 66.6666%, var(--noiseBg09_4) 100%);
  --noise09_12: linear-gradient(90deg, var(--noiseBg09_4) 0%, var(--noiseBg09_4) 33.3333%, var(--noiseBg09_3) 33.3333%, var(--noiseBg09_3) 66.6666%, var(--noiseBg09_4) 66.6666%, var(--noiseBg09_4) 100%);
  
	/* --row1_speed:5s;
  --row1_delay:1.5s;
  --row2_speed:5.5s;
  --row2_delay:1.25s;
  --row3_speed:6.0s;
  --row3_delay:1.0s;
  --row4_speed:6.5s;
  --row4_delay:0.75s;
  --row5_speed:7.0s;
  --row5_delay:0.25s;
  --row6_speed:7.5s;
  --row6_delay:0s; */
  --row1_speed:5s;
  --row1_delay:0s;
  --row2_speed:5.5s;
  --row2_delay:0.25s;
  --row3_speed:6.0s;
  --row3_delay:0.75s;
  --row4_speed:6.5s;
  --row4_delay:1s;
  --row5_speed:7.0s;
  --row5_delay:1.25s;
  --row6_speed:7.5s;
  --row6_delay:1.5s;
  /* --main5_easeing: cubic-bezier(0.190, 1.000, 0.220, 1.000);easeOutExpo */
  --easeing: cubic-bezier(0.165, 0.840, 0.440, 1.000); /* easeOutQuart */
}
@keyframes         noiseAni_start {
	0% {transform: translateX(-100%);}
	100% {transform: translateX(-66.6666%);}
}
@keyframes         noiseAni_loop {
	0% {transform: translateX(-66.6666%);}
	50% {transform: translateX(-33.3333%);}
  100% {transform: translateX(0%);}
}


.noiseArea{
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
  z-index: 10;
}
.noiseLines{
  width: 100%;
  height: 100%;
  position: relative;
  z-index: 10;
}
.noiseLines li{
  width: 100%;
  position: relative;
  overflow: hidden;
  
}
.noiseLines li.row1{flex:1 0 0;}
.noiseLines li.row2{flex:2 0 0;}
.noiseLines li.row3{flex:5 0 0;}
.noiseLines li.row4{flex:10 0 0;}
.noiseLines li.row5{flex:15 0 0;}
.noiseLines li.row6{flex:20 0 0;}

.noiseLines li.w_xxs{width: var(--w_xxs);}
.noiseLines li.w_xs{width: var(--w_xs);}
.noiseLines li.w_s{width: var(--w_s);}
.noiseLines li.w_m{width: var(--w_m);}
.noiseLines li.w_l{width: var(--w_l);}
.noiseLines li.w_xl{width: var(--w_xl);}
.noiseLines li.w_xxl{width: var(--w_xxl);}

.noiseLines.w75 li{width: 75%;}
.noiseLines.w75 li.w_xxs{width: calc(var(--w_xxs) * 0.75);}
.noiseLines.w75 li.w_xs{width: calc(var(--w_xs) * 0.75);}
.noiseLines.w75 li.w_s{width: calc(var(--w_s) * 0.75);}
.noiseLines.w75 li.w_m{width: calc(var(--w_m) * 0.75);}
.noiseLines.w75 li.w_l{width: calc(var(--w_l) * 0.75);}
.noiseLines.w75 li.w_xl{width: calc(var(--w_xl) * 0.75);}
.noiseLines.w75 li.w_xxl{width: calc(var(--w_xxl) * 0.75);}


.noiseLines.w90 li{width: 90%;}
.noiseLines.w90 li.w_xxs{width: calc(var(--w_xxs) * 0.9);}
.noiseLines.w90 li.w_xs{width: calc(var(--w_xs) * 0.9);}
.noiseLines.w90 li.w_s{width: calc(var(--w_s) * 0.9);}
.noiseLines.w90 li.w_m{width: calc(var(--w_m) * 0.9);}
.noiseLines.w90 li.w_l{width: calc(var(--w_l) * 0.9);}
.noiseLines.w90 li.w_xl{width: calc(var(--w_xl) * 0.9);}
.noiseLines.w90 li.w_xxl{width: calc(var(--w_xxl) * 0.9);}


.noiseLines.sp_w60 li{width: 60%;}
.noiseLines.sp_w60 li.w_xxs{width: calc(var(--w_xxs) * 0.60);}
.noiseLines.sp_w60 li.w_xs{width: calc(var(--w_xs) * 0.60);}
.noiseLines.sp_w60 li.w_s{width: calc(var(--w_s) * 0.60);}
.noiseLines.sp_w60 li.w_m{width: calc(var(--w_m) * 0.60);}
.noiseLines.sp_w60 li.w_l{width: calc(var(--w_l) * 0.60);}
.noiseLines.sp_w60 li.w_xl{width: calc(var(--w_xl) * 0.60);}
.noiseLines.sp_w60 li.w_xxl{width: calc(var(--w_xxl) * 0.60);}

.noiseLines.sp_w75 li{width: 75%;}
.noiseLines.sp_w75 li.w_xxs{width: calc(var(--w_xxs) * 0.75);}
.noiseLines.sp_w75 li.w_xs{width: calc(var(--w_xs) * 0.75);}
.noiseLines.sp_w75 li.w_s{width: calc(var(--w_s) * 0.75);}
.noiseLines.sp_w75 li.w_m{width: calc(var(--w_m) * 0.75);}
.noiseLines.sp_w75 li.w_l{width: calc(var(--w_l) * 0.75);}
.noiseLines.sp_w75 li.w_xl{width: calc(var(--w_xl) * 0.75);}
.noiseLines.sp_w75 li.w_xxl{width: calc(var(--w_xxl) * 0.75);}

.noiseLines.sp_w90 li{width: 90%;}
.noiseLines.sp_w90 li.w_xxs{width: calc(var(--w_xxs) * 0.9);}
.noiseLines.sp_w90 li.w_xs{width: calc(var(--w_xs) * 0.9);}
.noiseLines.sp_w90 li.w_s{width: calc(var(--w_s) * 0.9);}
.noiseLines.sp_w90 li.w_m{width: calc(var(--w_m) * 0.9);}
.noiseLines.sp_w90 li.w_l{width: calc(var(--w_l) * 0.9);}
.noiseLines.sp_w90 li.w_xl{width: calc(var(--w_xl) * 0.9);}
.noiseLines.sp_w90 li.w_xxl{width: calc(var(--w_xxl) * 0.9);}

.noiseLines li.noLine p{display: none!important;}

.noiseLines li p{
  width: 300%;
  height: 100%;
}
.noiseLines li.row1 p{animation: noiseAni_start var(--row1_speed) var(--easeing) var(--row1_delay) 1 both;}
.noiseLines li.row2 p{animation: noiseAni_start var(--row2_speed) var(--easeing) var(--row2_delay) 1 both;}
.noiseLines li.row3 p{animation: noiseAni_start var(--row3_speed) var(--easeing) var(--row3_delay) 1 both;}
.noiseLines li.row4 p{animation: noiseAni_start var(--row4_speed) var(--easeing) var(--row4_delay) 1 both;}
.noiseLines li.row5 p{animation: noiseAni_start var(--row5_speed) var(--easeing) var(--row5_delay) 1 both;}
.noiseLines li.row6 p{animation: noiseAni_start var(--row6_speed) var(--easeing) var(--row6_delay) 1 both;}



.bt_view{
  width: fit-content;
  min-width: 115px;
}
.bt_view a{
  display: block;
  font-size: 0.11rem;
  letter-spacing: 0.1em;
  padding: 1em 1.5em;
  border: 1px solid #000;
  text-align: center;
}


.bt_more{
  width: fit-content;
  min-width: 115px;
}
.bt_more a{
  display: block;
  font-size: 0.10rem;
  letter-spacing: 0.1em;
  padding: 1em 1.5em;
  border: 1px solid #000;
	text-align: center;
}

/*WP ULIKE
=============================*/
.wpulike{
	display: inline-block;
}
.wp_ulike_general_class{
	width: fit-content;
	display: flex;
	align-items: center;
	border-bottom: 1px solid #000;
}
.wp_ulike_general_class button{
	order: 2;
	background: none;
	border: none;
	cursor: pointer;
	padding: 0;
	font-size: 0.10rem;
  letter-spacing: 0.1em;
}
.areport.post #main .titArea .txtArea .wp_ulike_general_class button{font-size: 0.12rem;}
.areport.post #contents > .likeBt .wp_ulike_general_class button{font-size: 0.13rem !important;}

.wp_ulike_general_class .count-box{
	order: 1;
	margin-right: 0.5em;
	font-size: 0.10rem;
  letter-spacing: 0.1em;
}
.areport.post #main .titArea .txtArea .wp_ulike_general_class .count-box{font-size: 0.12rem;}
.areport.post #contents > .likeBt .wp_ulike_general_class .count-box{font-size: 0.13rem !important;}

/*deSVG
=============================*/
/*
.svgImg path{
	fill: #FFF;
}*/
/*=============================
  header
=============================*/
header{
	height: 46px;
}
header .logo{
	position: fixed;
	top:10px;
	left:8px;
	width: 135px;
	z-index: 500;
}
header .logo a{
	width: 100%;
	height: 100%;
	display: block;
}

header h1.pageTit{
	position: fixed;
	top:16px;
	right: 45px;
	z-index: 100;
}
header h1.pageTit span{
	display: block;
}
header h1.pageTit .fmin_zr{
	font-size: 0.12rem;
	letter-spacing: 0.2em;
	margin-bottom: 0.5em;
}


/*gnavBt
=============================*/
header #gnavBt {
	position: fixed;
	top:8px;
	right:0;
	z-index:500;
}
header #gnavBt a{
	display: block;
	width: 32px;
	height: 30px;
	position: relative;
	background: #000;
}
/*▼gnavBtアニメ*/
header #gnavBtBorder{
	z-index: 1;
	position: absolute;
	top: 50%;
	left: 50%;
	margin-left: -50%;
	margin-top: 2px;
	display: block;
	width: 100%;
	height: 1px;
	background-color: #FFF;
	/* transition: transform 0.3s ease, top 0.3s ease; */
}
header #gnavBtBorder:before {
	top: -7px;
	content: "";
	display: block;
	width: 100%;
	height: 3px;
	background-color: #FFF;
	position: absolute;
	z-index: -1;
	/* transition: transform 0.3s ease, top 0.3s ease, margin 0.2s ease; */
}
header #gnavBtBorder:after {
	top: 3px;
	content: "";
	display: block;
	width: 100%;
	height: 4px;
	background-color: #FFF;
	position: absolute;
	z-index: -1;
	/* transition: transform 0.3s ease, top 0.3s ease, margin 0.2s ease; */
}
/* header #gnavBt a:active #gnavBtBorder:before {margin-top: -3px;}
header #gnavBt a:active #gnavBtBorder:after {margin-top: 3px;}
header #gnavBt a.open #gnavBtBorder {background: none;}
header #gnavBt a.open #gnavBtBorder:before,
header #gnavBt a.open #gnavBtBorder:after {
	height: 2px!important;
	top:0 !important;
	margin-top: 0 !important;
}
header #gnavBt a.open #gnavBtBorder:before {transform:rotate(45deg);}
header #gnavBt a.open #gnavBtBorder:after {transform:rotate(-45deg);} */

/*gnav ani
=============================*/
nav#gnav {
	position: fixed;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	z-index: 200;
	/* backdrop-filter: blur(24px); 背景ぼかし */
	background: rgba(0,0,0,1);
	display: none;
	/*  togglemodal使う場合 */
	flex-direction: column;
}
nav#gnav #gnavClose{
	position: fixed;
	top:0;
	left:0;
	width: 100%;
	height: 100%;
	z-index: 1;
}
nav#gnav > .inner{
	width: fit-content;
	height: calc((600/800)*100%);
	padding: 90px 30px 100px;
	overflow: auto;
	margin-left: auto;
	position: relative;
	z-index: 2;
}
nav#gnav > .noiseArea{
	height: calc((200/800)*100%)!important;
	position: relative;
	z-index: 0;
}


nav#gnav.opening {
	display: flex;
	animation: opening 0.8s ease 0s 1 normal both;
}
nav#gnav.opened{display: flex;}

nav#gnav.closing {
	display: flex;
	animation: closing 0.25s ease 0s 1 normal both;
}
nav#gnav.closed{display: none;}



@keyframes opening {
	0% {
		opacity: 1.0;
	}
	100% {
		opacity: 1.0;
	}
}
@keyframes         closing {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 0;
	}
}

header:has(#gnav.opening) .logo svg *,
header:has(#gnav.opened) .logo svg * {
	fill:#FFF;
}

#gmenu {
	width: fit-content;
	margin-left: auto;
}
#gmenu li{text-align: right;}
#gmenu li:nth-child(n+2){margin-top: 0.5em;}
#gmenu li a{
	color: #FFF;
	font-size: 0.22rem;
	line-height: 1.5;
	letter-spacing: 0.05em;
}
#gmenu li a:active,
#gmenu li a.current{
	color: #8B8B8B;
}
/*=============================
  footer
=============================*/
footer .bt_contact{
	padding: 0 10px;
}
footer .bt_contact a{
	display: block;
	border: 1px solid #000;
	height: 96px;
	padding: 25px 15px 25px 15px;
}
footer .bt_contact a span{
	display: block;
	text-align: center;
}
footer .bt_contact a::after{transition: transform 1s ease!important;}
footer .bt_contact a .hovTxt{transition: color 1s ease!important;}


footer .bt_contact a span.fen_m{
	font-size: 0.18rem;
	letter-spacing: 0.1em;
	line-height: 1.35;
}
footer .bt_contact a span.jp{
	font-size: 0.14rem;
	letter-spacing: 0.1em;
	line-height: 1.35;
	margin-top: 0.35em;
}

footer .bgArea {
	background: #F2F2F2;
}


footer .bgArea > .inner{
	padding: 20px 10px 40px;
}
footer .bgArea > .inner > *{
}
footer .inner #fnav {min-height: 230px;}
footer .inner #fnav .logo{
	aspect-ratio: 186/35;
	width: 230px;
	transform: rotate(90deg);
	transform-origin: 0% 0%;
	margin-left: 45px;
}
footer .inner #fnav #fmenu{
	width: fit-content;
	margin-left: auto;
}
footer .inner #fnav #fmenu li{
	font-size: 0.14rem;
	line-height: 1.35;
	white-space: nowrap;
	text-align: right;
}
footer .inner #fnav #fmenu li:nth-child(n+2){
	margin-top: 0.75em;
}

footer .inner .addr{
	font-size: 0.18rem;
	letter-spacing: 0.1em;
	line-height: calc(29/18);
	padding-top: 1em;
	border-top: 1px solid #000;
	margin-top: 1.5em;
}
footer .inner .logoArea{
	order: 10;
	margin-top: 30px;
}
footer .inner .logoArea .logo_tanseisha{
	align-self: 114/25;
	width: 145px;
}
footer .inner .logoArea .copyRight{
	font-size: 0.11rem;
	letter-spacing: 0.1em;
	margin-top: 1.25em;
}

footer .inner .linkList {
	font-size: 0.11rem;
	letter-spacing: 0.1em;
	margin-top: 25px;
}
footer .inner .linkList li{
	margin-bottom: 1em;
	padding-bottom: 0.1em;
	padding-right: 1em;
	margin-right: 1em;
	border-right: 1px solid #000;
}
footer .inner .linkList li:last-child{
	padding-right: 0;
	margin-right: 0;
	border-right: none;
}
footer .noiseArea {
	aspect-ratio: 393/363;
	width: 100%;
	max-height: 363px;
}

/* =============================
   mobile
============================= */
.cmiHomeCards,
.cmiHomeCards * {
  box-sizing: border-box;
}

.cmiHomeCards {
  position: relative;
  z-index: 5;
  width: 100%;
  padding: 40px 0 24px;
  background: #f3f3f3;
}

.cmiHomeCards__inner {
  width: calc(100% - 20px);
  margin: 0 auto;
  padding-top: 36px;
}

.cmiHomeCards__section + .cmiHomeCards__section {
  margin-top: 40px;
}

.cmiHomeCards__head {
  display: block !important;
  width: 100% !important;
  margin: 0 0 18px !important;
  padding: 0 !important;
}

.cmiHomeCards__title {
  display: block !important;
  position: static !important;
  float: none !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #111 !important;
  font-size: 0.24rem !important;
  line-height: 1.1 !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-align: left !important;
}

.cmiHomeCards__grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 16px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.cmiHomeCards__item {
  display: block !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  overflow: hidden !important;
}

.cmiHomeCards__card {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  min-height: 100% !important;
  padding: 0 !important;
  border: 1px solid #dddddd !important;
  border-radius: 10px !important;
  background: #ffffff !important;
  color: #111111 !important;
  text-decoration: none !important;
  overflow: hidden !important;
}

.cmiHomeCards__imageWrap {
  display: block !important;
  width: 100% !important;
  aspect-ratio: 16 / 10 !important;
  background: #e8e8e8 !important;
  overflow: hidden !important;
}

.cmiHomeCards__image {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

.cmiHomeCards__image--placeholder {
  background: linear-gradient(135deg, #efefef 0%, #dadada 100%) !important;
}

.cmiHomeCards__body {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  padding: 14px 14px 16px !important;
}

.cmiHomeCards__meta {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px 10px !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #555555 !important;
  font-size: 0.11rem !important;
  line-height: 1.5 !important;
  letter-spacing: 0.02em !important;
}

.cmiHomeCards__cardTitle {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  color: #111111 !important;
  font-size: 0.18rem !important;
  line-height: 1.45 !important;
  font-weight: 700 !important;
  text-align: left !important;
  word-break: break-word !important;
}

.cmiHomeCards__excerpt {
  margin: 0 !important;
  padding: 0 !important;
  color: #444444 !important;
  font-size: 0.12rem !important;
  line-height: 1.7 !important;
  text-align: left !important;
}

.cmiHomeCards__tags {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.cmiHomeCards__tags li {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 24px !important;
  margin: 0 !important;
  padding: 4px 8px !important;
  border: 1px solid #bdbdbd !important;
  border-radius: 999px !important;
  background: #f7f7f7 !important;
  color: #444444 !important;
  font-size: 0.10rem !important;
  line-height: 1.3 !important;
  white-space: nowrap !important;
}

.cmiHomeCards__aboutBridge {
  /*margin-top: 40px;
  padding: 32px 0 40px;*/
  background: #fff;
}

.cmiHomeCards__aboutBridge #about {
  margin-top: 0;
  background: #fff;
}


/* =========================
   SP
   ========================= */
.cmiHomeCards__tags.cmiHomeCards__tags--common,
.cmiHomeCards__tags.cmiHomeCards__tags--article{
	gap: 4px !important;
	row-gap: 6px !important;
}

.cmiHomeCards__tagRows{
	gap: 4px !important;
}

.cmiHomeCards__tags.cmiHomeCards__tags--common li,
.cmiHomeCards__tags.cmiHomeCards__tags--article li{
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 24px !important;
	margin: 0 !important;
	padding: 2px 8px !important;
	border: 1px solid #9e9e9e !important;
	border-radius: 6px !important;
	background: #ffffff !important;
	color: #666666 !important;
	font-family: "Noto Sans JP", "Noto Sans", sans-serif !important;
	font-size: 11px !important;
	font-weight: 500 !important;
	line-height: 1.1 !important;
	white-space: nowrap !important;
	box-sizing: border-box !important;
}




/* =============================
   main catch / mobile
============================= */
.mainCatch {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  transform: translateY(-50%);
  z-index: 20;
  pointer-events: none;
}

.mainCatch__inner {
  width: calc(100% - 24px);
  padding: 0 12px;
  margin: 0 auto;
}

.mainCatch__sub {
  display: inline-block;
  margin: 0 0 10px;
  padding: 0;
  background: none;
  color: #fff;
  font-size: 0.14rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  text-shadow:
    0 0 6px rgba(0,0,0,0.25),
    0 2px 12px rgba(0,0,0,0.35);
}

.mainCatch__title {
  margin: 0;
  color: #fff;
  font-size: 0.24rem;
  letter-spacing: 0.03em;
  line-height: 1.15;
  text-shadow:
    0 0 6px rgba(0,0,0,0.25),
    0 2px 12px rgba(0,0,0,0.35);
  word-break: break-word;
}

.mainCatch__link {
  margin: 16px 0 0;
  pointer-events: auto;
}

.mainCatch__link a {
  display: inline-block;
  color: #fff;
  font-size: 0.14rem;
  letter-spacing: 0.08em;
  line-height: 1.4;
  text-decoration: underline;
  text-underline-offset: 0.15em;
  text-shadow: 0 2px 10px rgba(0,0,0,0.35);
}

#pcGnav{
	display: none !important;
}

/* タイトル */
.cmiHomeCards__head {
	display: block !important;
	width: 100vw !important;
	margin: 0 calc(50% - 50vw) 16px !important;
	padding: 8px 10px !important;
	background: #fff !important;
	text-align: center !important;
}

.cmiHomeCards__title {
	display: inline-block !important;
	margin: 0 !important;
	padding: 0 !important;
	font-size: 0.20rem !important;
	line-height: 1.1 !important;
	text-align: center !important;
}


/* =============================
   cmi scroll brand / mobile
============================= */
:root{
	--cmi-brand-h-sp: 38px;
}

@media screen and (max-width: 767px){

/* =============================
   cmi scroll brand / SP
   画像サイズ縮小
============================= */

@media screen and (max-width: 767px){


	.cmiScrollBrand{
		height: var(--cmi-brand-h-sp) !important;
	}

	.cmiScrollBrand.is-hidden,
	body.is-cmi-brand-hidden .cmiScrollBrand{
		transform: translateY(-100%);
		opacity: 0;
	}

	.cmiScrollBrand__inner{
		width: 100%;
		height: 100%;
		padding-left: 10px;
		padding-right: 10px;
		box-sizing: border-box;
		display: flex;
		justify-content: flex-start;
		align-items: center;
	}

	.cmiScrollBrand__logo{
		display: block !important;
		width: auto !important;
		height: 22px !important;
		max-height: 22px !important;
		margin: 0 !important;
	}

	.cmiScrollBrand__logo img,
	.cmiScrollBrand__logo svg{
		display: block !important;
		width: auto !important;
		height: 18px !important;
		max-height: 18px !important;
	}



	header .logo{
		top: calc(10px + var(--cmi-brand-h-sp));
		transition: top .35s ease;
	}

	header #gnavBt{
		top: calc(8px + var(--cmi-brand-h-sp));
		transition: top .35s ease;
	}

	header h1.pageTit{
		top: calc(16px + var(--cmi-brand-h-sp));
		transition: top .35s ease;
	}

	body.is-cmi-brand-hidden header .logo{
		top: 10px;
	}

	body.is-cmi-brand-hidden header #gnavBt{
		top: 8px;
	}

	body.is-cmi-brand-hidden header h1.pageTit{
		top: 16px;
	}
}

@media screen and (max-width: 782px){
	body.admin-bar .cmiScrollBrand{
		top: 46px;
	}

	body.admin-bar header .logo{
		top: calc(56px + var(--cmi-brand-h-sp));
	}

	body.admin-bar header #gnavBt{
		top: calc(54px + var(--cmi-brand-h-sp));
	}

	body.admin-bar header h1.pageTit{
		top: calc(62px + var(--cmi-brand-h-sp));
	}

	body.admin-bar.is-cmi-brand-hidden header .logo{
		top: 56px;
	}

	body.admin-bar.is-cmi-brand-hidden header #gnavBt{
		top: 54px;
	}

	body.admin-bar.is-cmi-brand-hidden header h1.pageTit{
		top: 62px;
	}
}

/* PDF icon / mobile */
.cmiHomeCards__item{
	position: relative;
}

.cmiHomeCards__card{
	position: relative;
	height: 100%;
}

.cmiHomeCards__mainLink{
	display: block;
	height: 100%;
	color: inherit;
	text-decoration: none;
}

.cmiHomeCards__pdf{
	position: absolute;
	right: 12px;
	bottom: 12px;
	left: auto;
	top: auto;
	z-index: 5;
}

.cmiHomeCards__pdfIcon{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}

.cmiHomeCards__pdfIcon .cmiPdfIcon__text{
	display: none;
}

.cmiHomeCards__pdfIcon .cmiPdfIcon__badge{
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	min-width: 32px;
	padding: 0;
	border-radius: 9999px;
	background: #ffffff;
	border: 1px solid #d9d9d9;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.14);
	font-size: 0;
	line-height: 1;
	box-sizing: border-box;
}

.cmiHomeCards__pdfIcon .cmiPdfIcon__badge::before{
	content: "";
	display: block;
	width: 16px;
	height: 16px;
	background-repeat: no-repeat;
	background-position: center;
	background-size: contain;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23111111' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3v11'/%3E%3Cpath d='m7 10 5 5 5-5'/%3E%3Cpath d='M5 21h14'/%3E%3C/svg%3E");
}

.cmiHomeCards__pdfIcon:focus .cmiPdfIcon__badge,
.cmiHomeCards__pdfIcon:focus-visible .cmiPdfIcon__badge{
	outline: 2px solid #111;
	outline-offset: 2px;
}



/* =============================
   CMI header mobile fixes
   - TOPのpageTit--frontをスマホでは出さない
   - PC用ヘッダー右側をスマホでは隠す
   - スマホ検索フォームをgnav内に表示
============================= */
#pcHeadRight{
	display: none !important;
}

header h1.pageTit.pageTit--front{
	display: none !important;
}

nav#gnav > .inner #pcSearch{
	display: flex !important;
	align-items: center;
	justify-content: flex-end;
	gap: 8px;
	width: min(260px, calc(100vw - 60px));
	margin: 28px 0 0 auto;
	padding: 0;
}

nav#gnav > .inner #pcSearch input[type="search"]{
	flex: 1 1 auto;
	min-width: 0;
	height: 36px;
	padding: 0 14px;
	border: 1px solid rgba(255,255,255,0.65);
	border-radius: 999px;
	background: rgba(255,255,255,0.08);
	color: #fff;
	font-size: 0.12rem;
	letter-spacing: 0.06em;
	outline: none;
	box-sizing: border-box;
}

nav#gnav > .inner #pcSearch input[type="search"]::placeholder{
	color: rgba(255,255,255,0.72);
}

nav#gnav > .inner #pcSearch button{
	display: inline-flex;
	align-items: center;
	justify-content: center;
	flex: 0 0 34px;
	width: 34px;
	height: 34px;
	padding: 0;
	border: 1px solid rgba(255,255,255,0.65);
	border-radius: 999px;
	background: transparent;
	color: #fff;
	cursor: pointer;
}

/* =============================
   ARCHIVE cards / SP
   ACTION REPORT / NEWS / SOLUTION / WORKS / ABOUT
   PCの h2.pc_flex.f_ac デザインに寄せる
============================= */

@media screen and (max-width: 767px){

	#container.cmiArchiveCardsPage{
		padding-top: 0 !important;
		background: #fff !important;
	}

	#container.cmiArchiveCardsPage #contents{
		padding-top: 0 !important;
	}

	#container.cmiArchiveCardsPage .cmiHomeCards--archive{
		padding: 0 0 56px !important;
		background: #fff !important;
	}

	#container.cmiArchiveCardsPage .cmiHomeCards--archive .cmiHomeCards__inner{
		width: calc(100% - 20px) !important;
		margin: 0 auto !important;
		padding-top: 34px !important;
	}

	/* 見出し：PCの pc_flex f_ac に近づける */
	#container.cmiArchiveCardsPage .cmiArchiveCardsSection > h2.pc_flex.f_ac{
		display: flex !important;
		align-items: flex-end !important;
		justify-content: flex-start !important;
		flex-wrap: wrap !important;
		gap: 8px 12px !important;
		position: static !important;
		top: auto !important;
		left: auto !important;
		z-index: auto !important;
		width: 100% !important;
		height: auto !important;
		margin: 0 0 18px !important;
		padding: 0 0 14px !important;
		background: #fff !important;
		border-bottom: 1px solid #111 !important;
		color: #111 !important;
		text-align: left !important;
		font-weight: 700 !important;
		line-height: 1.4 !important;
		letter-spacing: 0.08em !important;
		box-sizing: border-box !important;
	}

	#container.cmiArchiveCardsPage .cmiArchiveCardsSection > h2.pc_flex.f_ac .fen_sb{
		display: inline-block !important;
		margin: 0 !important;
		padding: 0 !important;
		color: #111 !important;
		font-family: 'Inter','Noto Sans JP', sans-serif !important;
		font-size: 0.26rem !important;
		font-weight: 600 !important;
		line-height: 1.05 !important;
		letter-spacing: 0.06em !important;
		white-space: nowrap !important;
	}

	#container.cmiArchiveCardsPage .cmiArchiveCardsSection > h2.pc_flex.f_ac .jp{
		display: inline-block !important;
		margin: 0 !important;
		padding: 0 0 0 1.2em !important;
		color: #111 !important;
		font-size: 0.12rem !important;
		font-weight: 700 !important;
		line-height: 1.5 !important;
		letter-spacing: 0.06em !important;
		white-space: normal !important;
	}

	/* カード一覧もPCの白背景・線あり構成に寄せる */
	#container.cmiArchiveCardsPage .cmiHomeCards__grid--archive{
		display: grid !important;
		grid-template-columns: 1fr !important;
		gap: 18px !important;
		width: 100% !important;
		margin: 0 !important;
		padding: 18px 0 0 !important;
		list-style: none !important;
		border-top: none !important;
	}

	#container.cmiArchiveCardsPage .cmiHomeCards__grid--archive > .cmiHomeCards__item{
		display: block !important;
		width: auto !important;
		max-width: none !important;
		min-width: 0 !important;
		margin: 0 !important;
		padding: 0 !important;
		list-style: none !important;
	}

	#container.cmiArchiveCardsPage .cmiHomeCards__grid--archive .cmiHomeCards__card{
		position: relative !important;
		width: 100% !important;
		max-width: none !important;
		min-width: 0 !important;
		height: auto !important;
		min-height: 0 !important;
		margin: 0 !important;
		background: #fff !important;
		border: 1px solid #dddddd !important;
		border-radius: 10px !important;
		overflow: hidden !important;
	}

	#container.cmiArchiveCardsPage .cmiHomeCards__grid--archive .cmiHomeCards__mainLink{
		display: flex !important;
		flex-direction: column !important;
		height: auto !important;
		color: #111 !important;
		text-decoration: none !important;
	}

	#container.cmiArchiveCardsPage .cmiHomeCards__grid--archive .cmiHomeCards__body{
		display: flex !important;
		flex-direction: column !important;
		gap: 10px !important;
		min-height: 0 !important;
		padding: 14px 14px 16px !important;
		background: #fff !important;
	}

	#container.cmiArchiveCardsPage .cmiHomeCards__grid--archive .cmiHomeCards__meta{
		min-height: 0 !important;
		margin: 0 !important;
		font-size: 0.11rem !important;
		line-height: 1.5 !important;
	}

	#container.cmiArchiveCardsPage .cmiHomeCards__grid--archive .cmiHomeCards__cardTitle{
		font-size: 0.18rem !important;
		line-height: 1.45 !important;
		letter-spacing: 0.04em !important;
	}

	#container.cmiArchiveCardsPage .cmiHomeCards__grid--archive .cmiHomeCards__excerpt{
		font-size: 0.12rem !important;
		line-height: 1.65 !important;
	}

	#container.cmiArchiveCardsPage .cmiHomeCards__grid--archive .cmiHomeCards__tagRows{
		margin-top: 4px !important;
		min-height: 0 !important;
		align-content: flex-start !important;
	}

	#container.cmiArchiveCardsPage .pnav{
		margin-top: 36px !important;
	}
}
/* =============================
   CMI SEARCH filter accordion / SP
   cmiSearchFilter__section だけをアコーディオン化
   cmiSearchFilter__actions は常時表示
============================= */

@media screen and (max-width: 767px) {

	#container.cmiSearch,
	.cmiSearchPage,
	.cmiSearchResults,
	.cmiSearchCards {
		background: #fff !important;
	}

	.cmiSearchPage {
		padding: 0 0 56px !important;
	}

	.cmiSearchFilter {
		position: static !important;
		z-index: 30 !important;
		margin: 0 0 22px !important;
		background: #fff !important;
	}

	.cmiSearchFilter__panel {
		width: 100% !important;
		margin: 0 !important;
		background: #fff !important;
		border-top: 1px solid #d9d9d9 !important;
		border-bottom: 1px solid #d9d9d9 !important;
		box-sizing: border-box !important;
	}

	.cmiSearchFilter__panelInner {
		width: 100% !important;
		margin: 0 auto !important;
		padding: 14px 10px 16px !important;
		box-sizing: border-box !important;
	}

	.cmiSearchFilter__searchRow {
		display: grid !important;
		grid-template-columns: minmax(0, 1fr) auto !important;
		gap: 8px !important;
		align-items: center !important;
		margin: 0 0 10px !important;
	}

	.cmiSearchFilter__searchField {
		position: relative !important;
		width: 100% !important;
	}

	.cmiSearchFilter__searchInput {
		display: block !important;
		width: 100% !important;
		height: 44px !important;
		padding: 0 48px 0 16px !important;
		border: 0 !important;
		border-radius: 999px !important;
		background: #d9d9d9 !important;
		color: #111 !important;
		font-size: 0.14rem !important;
		font-weight: 700 !important;
		line-height: 44px !important;
		letter-spacing: 0.04em !important;
		outline: none !important;
		box-sizing: border-box !important;
	}

	.cmiSearchFilter__searchInput::placeholder {
		color: #fff !important;
		font-weight: 700 !important;
		letter-spacing: 0.08em !important;
	}

	.cmiSearchFilter__searchButton {
		position: absolute !important;
		top: 50% !important;
		right: 10px !important;
		transform: translateY(-50%) !important;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: 32px !important;
		height: 32px !important;
		padding: 0 !important;
		border: 0 !important;
		background: transparent !important;
		color: #111 !important;
		cursor: pointer !important;
	}

	.cmiSearchFilter__searchButton svg {
		display: block !important;
		width: 18px !important;
		height: 18px !important;
	}

	.cmiSearchFilter__hint {
		font-size: 0.11rem !important;
		font-weight: 700 !important;
		color: #888 !important;
		line-height: 1.4 !important;
		white-space: nowrap !important;
		text-align: right !important;
	}

	.cmiSearchFilter__section {
		display: block !important;
		margin: 0 0 10px !important;
		padding: 0 !important;
		border: 1px solid #111 !important;
		background: #fff !important;
		box-sizing: border-box !important;
	}

	.cmiSearchFilter__accordionToggle {
		appearance: none !important;
		-webkit-appearance: none !important;
		display: flex !important;
		align-items: center !important;
		justify-content: space-between !important;
		gap: 10px !important;
		width: 100% !important;
		min-height: 46px !important;
		margin: 0 !important;
		padding: 10px 12px !important;
		border: 0 !important;
		border-radius: 0 !important;
		background: #fff !important;
		color: #111 !important;
		text-align: left !important;
		cursor: pointer !important;
		box-sizing: border-box !important;
	}

	.cmiSearchFilter__accordionText {
		display: flex !important;
		align-items: baseline !important;
		gap: 8px !important;
		min-width: 0 !important;
	}

	.cmiSearchFilter__accordionEn {
		display: inline-block !important;
		font-family: 'Inter','Noto Sans JP', sans-serif !important;
		font-size: 0.18rem !important;
		font-weight: 600 !important;
		line-height: 1 !important;
		letter-spacing: 0.08em !important;
		white-space: nowrap !important;
	}

	.cmiSearchFilter__accordionJa {
		display: inline-block !important;
		font-size: 0.11rem !important;
		font-weight: 700 !important;
		line-height: 1.4 !important;
		letter-spacing: 0.06em !important;
		white-space: nowrap !important;
	}

	.cmiSearchFilter__accordionCount {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: 22px !important;
		height: 22px !important;
		margin-left: auto !important;
		border-radius: 999px !important;
		background: #111 !important;
		color: #fff !important;
		font-size: 0.11rem !important;
		font-weight: 700 !important;
		line-height: 1 !important;
		letter-spacing: 0 !important;
	}

	.cmiSearchFilter__accordionIcon {
		position: relative !important;
		display: inline-block !important;
		width: 16px !important;
		height: 16px !important;
		flex: 0 0 16px !important;
	}

	.cmiSearchFilter__accordionIcon::before,
	.cmiSearchFilter__accordionIcon::after {
		content: "" !important;
		position: absolute !important;
		top: 50% !important;
		left: 50% !important;
		display: block !important;
		width: 14px !important;
		height: 1px !important;
		background: #111 !important;
		transform: translate(-50%, -50%) !important;
		transition: transform 0.2s ease !important;
	}

	.cmiSearchFilter__accordionIcon::after {
		transform: translate(-50%, -50%) rotate(90deg) !important;
	}

	.cmiSearchFilter__section.is-open .cmiSearchFilter__accordionIcon::after {
		transform: translate(-50%, -50%) rotate(0deg) !important;
	}

	.cmiSearchFilter__sectionContent {
		display: flex !important;
		flex-direction: column !important;
		gap: 12px !important;
		max-height: 0 !important;
		margin: 0 !important;
		padding: 0 12px !important;
		overflow: hidden !important;
		opacity: 0 !important;
		pointer-events: none !important;
		box-sizing: border-box !important;
		transition: max-height 0.28s ease, padding 0.28s ease, opacity 0.2s ease !important;
	}

	.cmiSearchFilter__section.is-open .cmiSearchFilter__sectionContent {
		max-height: 70svh !important;
		padding: 4px 12px 14px !important;
		overflow: auto !important;
		opacity: 1 !important;
		pointer-events: auto !important;
		-webkit-overflow-scrolling: touch !important;
	}

	.cmiSearchFilter__group {
		margin: 0 !important;
		padding: 0 !important;
	}

	.cmiSearchFilter__group + .cmiSearchFilter__group {
		padding-top: 10px !important;
		border-top: 1px solid #e1e1e1 !important;
	}

	.cmiSearchFilter__groupLabel {
		display: block !important;
		margin: 0 0 8px !important;
		padding: 0 !important;
		color: #111 !important;
		font-size: 0.12rem !important;
		font-weight: 700 !important;
		line-height: 1.4 !important;
		letter-spacing: 0.08em !important;
	}

	.cmiSearchFilter__chips {
		display: grid !important;
		grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
		gap: 7px !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	.cmiSearchFilter__chipWrap {
		position: relative !important;
		min-width: 0 !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	.cmiSearchFilter__chipInput {
		position: absolute !important;
		left: -9999px !important;
	}

	.cmiSearchFilter__chip {
		display: flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: 100% !important;
		min-height: 38px !important;
		margin: 0 !important;
		padding: 7px 8px !important;
		border: 1px solid #cfcfcf !important;
		border-radius: 0 !important;
		font-size: 0.115rem !important;
		font-weight: 700 !important;
		line-height: 1.35 !important;
		letter-spacing: 0.04em !important;
		text-align: center !important;
		word-break: break-word !important;
		cursor: pointer !important;
		box-sizing: border-box !important;
		transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease !important;
	}

	.cmiSearchFilter__group--space .cmiSearchFilter__chip {
		background: #8b4716 !important;
		border-color: #8b4716 !important;
		color: #fff !important;
	}

	.cmiSearchFilter__group--space .cmiSearchFilter__chipInput:checked + .cmiSearchFilter__chip {
		background: #fff !important;
		color: #8b4716 !important;
	}

	.cmiSearchFilter__group--solution .cmiSearchFilter__chip {
		background: #000 !important;
		border-color: #000 !important;
		color: #fff !important;
	}

	.cmiSearchFilter__group--solution .cmiSearchFilter__chipInput:checked + .cmiSearchFilter__chip {
		background: #fff !important;
		color: #000 !important;
	}

	.cmiSearchFilter__group--tech .cmiSearchFilter__chip {
		background: #fff !important;
		border-color: #000 !important;
		color: #000 !important;
	}

	.cmiSearchFilter__group--tech .cmiSearchFilter__chipInput:checked + .cmiSearchFilter__chip {
		background: #000 !important;
		border-color: #000 !important;
		color: #fff !important;
	}

	.cmiSearchFilter__actions {
		display: grid !important;
		grid-template-columns: 1fr !important;
		gap: 8px !important;
		align-items: stretch !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	.cmiSearchFilter__submit,
	.cmiSearchFilter__reset,
	.cmiPdfBulkDownloadButton.cmiSearchFilter__bulkDownload {
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		width: 100% !important;
		min-height: 44px !important;
		margin: 0 !important;
		padding: 10px 14px !important;
		box-sizing: border-box !important;
		font-size: 0.12rem !important;
		font-weight: 700 !important;
		line-height: 1.4 !important;
		letter-spacing: 0.08em !important;
		text-align: center !important;
		text-decoration: none !important;
		cursor: pointer !important;
	}

	.cmiSearchFilter__submit {
		appearance: none !important;
		-webkit-appearance: none !important;
		border: 1px solid #111 !important;
		background: #111 !important;
		color: #fff !important;
	}

	.cmiSearchFilter__reset {
		appearance: none !important;
		-webkit-appearance: none !important;
		border: 1px solid #111 !important;
		background: #fff !important;
		color: #111 !important;
	}

	.cmiPdfBulkDownloadButton.cmiSearchFilter__bulkDownload {
		border: 1px solid #111 !important;
		background: #111 !important;
		color: #fff !important;
		gap: 8px !important;
	}

	.cmiPdfBulkDownloadButton.cmiSearchFilter__bulkDownload::before {
		content: "" !important;
		display: inline-block !important;
		width: 15px !important;
		height: 15px !important;
		flex: 0 0 15px !important;
		background-repeat: no-repeat !important;
		background-position: center !important;
		background-size: contain !important;
		background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 3v11'/%3E%3Cpath d='m7 10 5 5 5-5'/%3E%3Cpath d='M5 21h14'/%3E%3C/svg%3E") !important;
	}

	.cmiPdfBulkDownloadButton.cmiSearchFilter__bulkDownload[disabled],
	.cmiPdfBulkDownloadButton.cmiSearchFilter__bulkDownload.is-disabled {
		opacity: 0.6 !important;
		cursor: not-allowed !important;
	}

	.cmiSearchResults {
		padding-top: 30px !important;
	}

	.cmiSearchCards {
		padding: 0 0 24px !important;
		background: #fff !important;
	}

	.cmiSearchCards .cmiHomeCards__inner {
		width: calc(100% - 20px) !important;
		margin: 0 auto !important;
		padding-top: 0 !important;
	}
}

/* =============================
   CMI Search page title
   ABOUT / ACTION REPORT などの一覧ページ見出しに合わせる
============================= */
#container.cmiSearch.cmiArchiveCardsPage{
	padding-top: 0 !important;
}

#container.cmiSearch .cmiSearchPageTitle{
	width: calc(100% - 20px) !important;
	margin: 34px auto 18px !important;
	padding: 0 !important;
	box-sizing: border-box !important;
}

#container.cmiSearch .cmiSearchPageTitle > h2.pc_flex.f_ac{
	display: flex !important;
	align-items: flex-end !important;
	justify-content: flex-start !important;
	flex-wrap: wrap !important;
	gap: 8px 12px !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 0 14px !important;
	border-bottom: 1px solid #111 !important;
	background: #fff !important;
	box-sizing: border-box !important;
}

#container.cmiSearch .cmiSearchPageTitle > h2.pc_flex.f_ac .fen_sb{
	font-size: 0.26rem !important;
	line-height: 1.05 !important;
	letter-spacing: 0.06em !important;
}

#container.cmiSearch .cmiSearchPageTitle > h2.pc_flex.f_ac .jp{
	margin: 0 !important;
	padding: 0 0 1px !important;
	font-size: 0.12rem !important;
	line-height: 1.5 !important;
	letter-spacing: 0.06em !important;
}

#container.cmiSearch .cmiSearchFilter{
	margin-top: 0 !important;
}

/* =============================
   SEARCH actions / SP
   絞り込む・条件クリア・一括DLを横並び
============================= */
	.cmiSearchFilter__actions{
		display: flex !important;
		flex-direction: row !important;
		align-items: stretch !important;
		justify-content: space-between !important;
		gap: 8px !important;
		width: 100% !important;
		margin: 16px 0 0 !important;
		padding: 0 !important;
	}

	.cmiSearchFilter__actions .cmiSearchFilter__submit,
	.cmiSearchFilter__actions .cmiSearchFilter__reset,
	.cmiSearchFilter__actions .cmiPdfBulkDownloadButton,
	.cmiSearchFilter__actions .cmiSearchFilter__bulkDownload{
		flex: 1 1 0 !important;
		width: auto !important;
		min-width: 0 !important;
		height: 48px !important;
		margin: 0 !important;
		padding: 0 6px !important;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		box-sizing: border-box !important;
		font-size: 0.11rem !important;
		font-weight: 700 !important;
		line-height: 1.25 !important;
		letter-spacing: 0.04em !important;
		text-align: center !important;
		white-space: normal !important;
	}

	.cmiSearchFilter__actions .cmiSearchFilter__submit{
		background: #111 !important;
		color: #fff !important;
		border: 1px solid #111 !important;
	}

	.cmiSearchFilter__actions .cmiSearchFilter__reset{
		background: #fff !important;
		color: #111 !important;
		border: 1px solid #111 !important;
	}

	.cmiSearchFilter__actions .cmiPdfBulkDownloadButton,
	.cmiSearchFilter__actions .cmiSearchFilter__bulkDownload{
		background: #111 !important;
		color: #fff !important;
		border: 1px solid #111 !important;
	}

	.cmiSearchFilter__actions .cmiPdfBulkDownloadButton svg,
	.cmiSearchFilter__actions .cmiSearchFilter__bulkDownload svg,
	.cmiSearchFilter__actions .cmiPdfBulkDownloadButton .icon,
	.cmiSearchFilter__actions .cmiSearchFilter__bulkDownload .icon{
		flex: 0 0 auto !important;
		width: 14px !important;
		height: 14px !important;
		margin-right: 4px !important;
	}

/* =============================
   SEARCH card controls / SP
   PC同様、PDFチェック＋DLアイコンをカード右下に配置
============================= */
	.cmiSearchCards__card{
		position: relative !important;
	}

	.cmiSearchCards__mainLink{
		display: flex !important;
		flex-direction: column !important;
		height: 100% !important;
	}

	.cmiSearchCards__body{
		position: relative !important;
		display: flex !important;
		flex-direction: column !important;
		min-height: 0 !important;
		padding-bottom: 52px !important;
		box-sizing: border-box !important;
	}

	.cmiSearchCards__controls{
		position: absolute !important;
		right: 14px !important;
		bottom: 14px !important;
		z-index: 5 !important;
		display: flex !important;
		align-items: center !important;
		justify-content: flex-end !important;
		gap: 10px !important;
		width: auto !important;
		height: auto !important;
		margin: 0 !important;
		padding: 0 !important;
		box-sizing: border-box !important;
	}

	.cmiSearchCards__check{
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		flex: 0 0 auto !important;
		width: auto !important;
		height: auto !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	.cmiSearchCards__check input[type="checkbox"],
	.cmiSearchCards__checkBox{
		display: block !important;
		width: 16px !important;
		height: 16px !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	.cmiSearchCards__pdf{
		position: static !important;
		display: inline-flex !important;
		align-items: center !important;
		justify-content: center !important;
		flex: 0 0 auto !important;
		width: auto !important;
		height: auto !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	.cmiSearchCards__pdf .cmiHomeCards__pdfIcon,
	.cmiSearchCards__pdf .cmiSearchCards__pdfIcon,
	.cmiSearchCards__pdf .cmiPdfIcon--download{
		margin: 0 !important;
	}



/* =============================
   CMI Search Filter Accordion
   PC/SP共通：開閉制御
============================= */

.cmiSearchFilter__sectionContent[aria-hidden="true"]{
	display: none !important;
}

.cmiSearchFilter__section.is-open .cmiSearchFilter__sectionContent{
	display: block !important;
}




/* =============================
   404 Page / SP
============================= */
@media screen and (max-width: 767px) {
	#container.error404 {
		padding-top: calc(var(--cmi-brand-h-sp) + 60px);
		padding-bottom: 80px;
		padding-left: 15px;
		padding-right: 15px;
		min-height: 60vh;
		box-sizing: border-box;
	}
	#container.error404 #main h1 {
		font-size: 28vw;
		line-height: 1;
		letter-spacing: 0.05em;
		font-weight: 700;
		margin: 0;
		text-align: center;
		width: 100%;
	}
	#container.error404 #contents {
		margin-top: 2em;
		text-align: center;
	}
	#container.error404 #contents h2 {
		font-size: 0.33rem;
		letter-spacing: 0.15em;
		font-weight: 700;
		margin-bottom: 1.25em;
		display: block;
	}
	#container.error404 #contents .inner {
		max-width: 100%;
	}
	#container.error404 #contents .txtBloc p {
		font-size: 0.15rem;
		line-height: 2;
		letter-spacing: 0.06em;
		color: #555;
		text-align: center;
	}
	#container.error404 .pnav {
		justify-content: center;
		margin-top: 2.5em;
	}
	#container.error404 .pnav .back a {
		font-size: 0.82em;
		letter-spacing: 0.12em;
	}
}

/* 外部リンクアイコン（SP） */
.cmiHomeCards__cardTitle .cmiHomeCards__externalIcon{
	display: inline-flex !important;
	width: 0.98em !important;
	height: 0.98em !important;
	margin-left: 0.3em !important;
	line-height: 1 !important;
	vertical-align: -0.06em !important;
}

.cmiHomeCards__cardTitle .cmiHomeCards__externalSvg{
	display: block !important;
	width: 100% !important;
	height: 100% !important;
	max-width: none !important;
	max-height: none !important;
	fill: currentColor !important;
}