@charset "UTF-8";
@import url("reset.css");

/* ----------------------------------------
   common
---------------------------------------- */

@font-face {
  font-family: 'Material Symbols Outlined';
  font-style: normal;
  src: url(https://example.com/material-symbols.woff) format('woff');
}

/* ----------------------------------------
   カスタムプロパティ
---------------------------------------- */
:root {/*375-1180*/
	--font-size-45: clamp(2.5rem, 2.354rem + 0.62vw, 2.813rem);/*40-45*/
	--font-size-40: clamp(2rem, 1.767rem + 0.99vw, 2.5rem);/*32-40*/
	--font-size-36: clamp(2rem, 1.884rem + 0.5vw, 2.25rem);/*32-36*/
	--font-size-32: clamp(1.75rem, 1.634rem + 0.5vw, 2rem);/*28-32*/
	--font-size-28: clamp(1.5rem, 1.384rem + 0.5vw, 1.75rem);/*24-28*/
	--font-size-24: clamp(1.25rem, 1.134rem + 0.5vw, 1.5rem);/*20-24*/
	--font-size-20: clamp(1.125rem, 1.067rem + 0.25vw, 1.25rem);/*18-20*/
	--font-size-18: clamp(1rem, 0.942rem + 0.25vw, 1.125rem);/*16-18*/
	--font-size-16: clamp(0.875rem, 0.817rem + 0.25vw, 1rem);/*14-16*/
	--font-size-14: clamp(0.75rem, 0.692rem + 0.25vw, 0.875rem);/*12-14*/
	/*color*/
	--color-bg_gray: #f0f0f0;
	--color-base: #0e66c4;
	--color-grants: #2e9fe6;
	--color-movie: #f26870;
	--color-sympo: #25b8b6;
	--color-text_gray: #45474d;
	--color-btn_gray: #d3d7e0;
	/*テーマカラーの分類*/
	--theme: var(--color-base);
}
body.grants {
	--theme: var(--color-grants);
}
body.movie {
	--theme: var(--color-movie);
}
body.sympo {
	--theme: var(--color-sympo);
}
/* common --------------------------------- */
body {
	font-family: "zen-maru-gothic", "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	font-weight: 500;
	font-size: var(--font-size-16);
	color: var(--color-text_gray);
}
a {
	color: var(--color-base);
}
.width1180 {
	width: 95%;
	max-width: 1180px;
	margin-inline: auto;
}
.width1080 {
	width: 95%;
	max-width: 1080px;
	margin-inline: auto;
}

/* flex --------------------------------- */
.flex_start {
	display: flex;
	justify-content: flex-start;
}
.flex_between {
	display: flex;
	justify-content: space-between;
}
.flex_center {
	display: flex;
	justify-content: center;
}
.flex_around {
	display: flex;
	justify-content: space-around;
}
.flex_end {
	display: flex;
	justify-content: flex-end;
}



/* ----------------------------------------
   header
---------------------------------------- */

header {
	position: sticky;
	top: 0;
	z-index: 998;
	background-color: var(--color-bg_gray);
	color: var(--color-base);
}
.header_outer {
	background-color: var(--color-bg_gray);
	color: var(--color-base);
}
header.fixed {
	background-color: var(--color-bg_gray);
	border-bottom: 2px solid var(--color-base);
}
.header_inner {
	display: flex;
	justify-content: space-between;
	padding: 32px 24px 0;
}
header.fixed .header_inner {
	padding: 20px 24px 4px;
}
.header_logo img {
	width: 280px;
	height: auto;
}
header.fixed .header_logo img {
	width: 240px;
}
.global_navigation {
	display: flex;
}
.global_navigation .flex_end {
	gap: 40px;
	font-weight: bold;
	flex:1;
}
.global_navigation > ul > li {
	display: flex;
	align-items: flex-start;
}
.global_navigation > ul > li > a {
	display: block;
}
.global_navigation > ul > li:not(.contact) {
	padding-top: 12px;
}
.global_navigation > ul > li:last-child > a,
.menu .inner ul li.contact a {
	background: var(--color-base) url('../images/ico_contact.png') no-repeat right 10px center / 26px auto;
	color: #fff;
	padding: 10px 44px 12px 20px;
	border-radius: 999px;
}
.menu .inner ul li.contact a {
	width: fit-content;
	margin-inline: auto;
}


/* slider --------------------------------- */
.slider_item .flex_between {
	width: 100%;
	gap: 32px;
}
.slider_img {
	flex-basis: 45%;
	text-align: right;
	flex-shrink: 0;
}
.slider_text {
	flex: 1;
	padding-left: 10%;
	padding-top: 32px;
	letter-spacing: .3em;
	font-weight: bold;
}
.slider_l_midashi {
	font-family: "toppan-bunkyu-midashi-go-std", sans-serif;
	font-size: var(--font-size-40);
	color: var(--color-base);
	text-align: center;
	font-weight: 900;
	line-height: 1.1;
	margin-bottom: 16px;
}
.slider_m_midashi {
	width: 100%;
	max-width: 650px;
	border: solid 2px var(--color-base);
	padding: 12px;
	margin: 16px auto;
	text-align: center;
	border-radius: 8px;
}
.slider_m_text {
	font-size: var(--font-size-24);
	text-align: center;
	line-height: 1.2;
}
.slider_s_text {
	font-size: var(--font-size-18);
	line-height: 1.4em;
	text-align: left;
	margin-inline: auto;
	width: fit-content;
}
.slider_s_text p {
	display: flex;
}
.slider_s_text p::before {
	content: "・";
}
.grants_update {
	text-align: center;
	font-size: var(--font-size-18);
}
.grants_update .slider_s_text {
	width: fit-content;
	margin-inline: auto;
}

/* top_content --------------------------------- */

.top_content_wrap {
	padding: 44px 0 64px;
	position: relative;
	isolation: isolate;
}
.top_content_wrap::after {
	content: "";
	position: absolute;
	bottom: 0;
	width: 100%;
	height: 100%;
	background: url('../images/bg_wave_only.png') no-repeat left bottom / cover;
	z-index: 0;
}
.top_content {
	padding-top: 42px;
	text-align: right;
}
.h2_title_bg {
	position: absolute;
	z-index: 1;
	font-size: var(--font-size-40);
	color: #fff;
	line-height: 1;
	background-color: var(--theme);
	height: calc( 100% - 45px );
	padding: 40px 82px 0 calc( 50% - 590px );
	border-radius: 0 80px 0 0;
	font-weight: bold;
}
.h2_side_border {
	display: inline-flex;
	position: relative;
	font-weight: bold;
}
.h2_side_border::after {
	content: "";
	position: absolute;
	bottom: -8px;
	right: 0;
	width: 100%;
	height: 8px;
	background-color: var(--theme);
	border-radius: 999px;
}
.top_content_list {
	position: relative;
	padding-top: 40px;
	z-index: 2;
}
.top_content_list li {
	background-color: #fff;
	width: 31%;
	min-width: 320px;
	border-radius: 80px 24px 80px 24px;
	position: relative;
	text-align: center;
	overflow: hidden;
}
.top_content_list li a {
	display: block;
	padding: 90px 0 32px;
}
.top_content_list li::before {
	width: 72px;
	position: absolute;
	right: 0;
	left: 0;
	margin: auto;
	top: 86px;
}
.card {
	position: absolute;
	top: 0;
	right: 0;
	width: 90px;
	height: 90px;
	background: #ff6b6b;
	clip-path: polygon(100% 0, 0 0, 100% 100%);
	border-radius: 0 24px 0 0;
}
.top_content_list li.top_content_grants .card {
	background-color: var(--color-grants);
}
.top_content_list li.top_content_movie .card {
	background-color: var(--color-movie);
}
.top_content_list li.top_content_sympo .card {
	background-color: var(--color-sympo);
}
.card_text {
	width: 90px;
	text-align: center;
	position: absolute;
	top: 22px;
	right: -12px;
	transform: rotate(45deg);
	color: #fff;
	font-size: var(--font-size-20);
	font-weight: bold;
}
.top_content_ico {
	text-align: center;
	padding-bottom: 56px;
}
.top_content_ico img {
	width: 72px;
	height: auto
}
.top_title_border {
	color: var(--color-text_gray);
	font-weight: bold;
	font-size: var(--font-size-24);
	display: inline-flex;
	position: relative;
	margin-bottom: 56px;
	max-width: 100%;
	white-space: nowrap;
}
.top_title_border::after {
	content: "";
	position: absolute;
	bottom: -16px;
	left: 0;
	width: calc( 100% + 9999px ) ;
	height: 8px;
	border-radius: 999px;
}
.top_content_list li.top_content_grants .top_title_border::after {
	background-color: var(--color-grants);
}
.top_content_list li.top_content_movie .top_title_border::after {
	background-color: var(--color-movie);
}
.top_content_list li.top_content_sympo .top_title_border::after {
	background-color: var(--color-sympo);
}
.more_radius {
	width: 200px;
	margin-inline: auto;
	color: var(--color-text_gray);
	border: 1px solid var(--color-bg_gray);
	border-radius: 999px;
}

/*top_content_news*/
.top_content_news {
	position: relative;
	padding-top: 48px;
}
.top_content_sns {
	flex-basis: 256px;
	flex-shrink: 0;
}
.top_content_sns .link_fuchi {
	margin: 64px 0 88px;
}
.link_fuchi a {
	display: block;
	width: fit-content;
	padding: 4px 24px;
	border: 1px solid var(--color-btn_gray);
	color: var(--color-text_gray);
	border-radius: 999px;
	margin-inline: auto;
}
.link_bg_basecolor {
	margin-top: 24px;
	width: 100%;
}
.link_bg_basecolor a {
	display: block;
	width: 100%;
	max-width: 500px;
	margin-inline: auto;
	padding: 8px 0;
	background-color: var(--color-base);
	color: #fff;
	border-radius: 999px;
	text-align: center;
	font-weight: bold;
	font-size: var(--font-size-18);
}
.link_bg_themecolor {
	margin: 48px 0 60px;
	width: 100%;
}
.link_bg_themecolor a {
	display: block;
	color: #fff;
	border-radius: 999px;
	text-align: center;
	font-weight: bold;
	font-size: var(--font-size-20);
	background-color: var(--color-base);
	padding: 8px 32px;
	width: fit-content;
	margin-inline: auto;
}
.link_bg_themecolor a + .text_basecolor {
	font-size: var(--font-size-20);
}
.h2_title_border {
	color: var(--theme);
	font-size: var(--font-size-40);
	position: relative;
	text-align: center;
	font-weight: bold;
}
.h2_title_jn {
	position: absolute;
	top: 68px;
	left: 0;
	font-size: var(--font-size-20);
	width: 100%;
}
.h2_title_border::after {
	content: "";
	position: absolute;
	bottom: -8px;
	left: 0;
	width: 100%;
	height: 8px;
	background-color: var(--theme);
	border-radius: 999px;
}
.sns_list {
	padding-top: 64px;
}
.sns_list li a {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 32px;
	color: var(--color-text_gray);
}
.sns_icon img {
	width: 56px;
	height: auto;
}
.separate.flex_between {
	gap: 96px;
}
.top_content_information {
	flex: 1;
}
.top_content_information ul li {
	display: flex;
	align-items: center;
	gap: 24px;
	padding: 12px 0 24px;
}
.top_content_information ul li:not(:last-of-type) {
	border-bottom: 1px solid var(--color-btn_gray);
}
.date {
	color: var(--color-base);
	padding-bottom: 16px;
}
.date .new {
	display: inline-block;
	background-color: var(--theme);
	border-radius: 999px;
	color: #fff;
	font-size: var(--font-size-14);
	padding: 2px 8px;
	line-height: 1;
	margin-left: 24px;
}
.thumbnail {
	flex-shrink: 0;
}
.thumbnail img {
	width: 64px;
	height: 64px;
	object-fit: cover;
	border-radius: 50%;
}
.title {
	font-size: var(--font-size-20);
	color: var(--color-text_gray);
	font-weight: bold;
}
.content {
	padding-top: 16px;
}
.content a {
	display: block;
	margin-top: 10px;
	width: fit-content;
	border: 1px solid var(--theme);
	color: var(--theme);
	line-height: 1;
	padding: 2px 16px;
	border-radius: 999px;
	font-size: var(--font-size-14);
	position: relative;
	font-weight: bold;
}
.content a::after {
	content: '';
	width: 6px;
	height: 6px;
	border-top: solid 2px var(--theme);
	border-right: solid 2px var(--theme);
	position: absolute;
	right: 8px;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
}
body:not(.subpage) footer {
	margin-top: 120px;
}
footer::before {
	content: "";
	display: block;
	width: 100%;
	height: 8px;
	background-color: var(--color-base);
	border-radius: 999px;
}
.footer_logo {
	padding: 64px 0 48px;
	text-align: center;
}
.footer_logo img {
	width: 300px;
	height: auto;
}
.footer_address {
	text-align: center;
}
.footer_navigation {
	display: flex;
	justify-content: space-between;
	padding-top: 80px;
}
.footer_navigation li {
	flex-basis: 200px;
}
.footer_navigation_title dt {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--color-base);
	font-weight: bold;
	margin-bottom: 16px;
}
.footer_navigation_title dt::before,
.footer_navigation_title dt::after {
	content: "";
    height: 8px;
    flex-grow: 1;
    background-color: var(--color-base);
}
.footer_navigation_title dt::before {
	border-radius: 999px 0 0 999px;
}
.footer_navigation_title dt::after {
	border-radius: 0 999px 999px 0;
}
.footer_navigation_title dd a {
	color: var(--color-text_gray);
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 6px 0;
}
.footer_navigation_title dd a::before {
	content: "";
	display: block;
	width: 4px;
	height: 4px;
	background-color: var(--color-text_gray);
	border-radius: 50%;
	flex-shrink: 0;
}
.copyright {
	padding: 60px 0 32px;
	text-align: center;
	color: var(--color-base);
}

/*下層ページ*/
body.subpage main {
	background-color: var(--color-bg_gray);
	padding-bottom: 120px;
}
.main_item {
	width: 95%;
	max-width: 968px;
	margin-inline: auto;
	padding: 24px 46px 80px;
}
.page_title_wrap.flex_between {
	align-items: center;
	padding: 24px 0 40px;
}
.page_title {
	font-size: var(--font-size-32);
	color: var(--color-base);
	font-weight: bold;
}
.page_category {
	border: 2px solid var(--theme);
	color: var(--theme);
	padding: 2px 12px;
	letter-spacing: .2em;
	font-weight: bold;
	border-radius: 4px;
}
.main_content {
	background-color: #fff;
}
.main_content.width1180 {
	border-radius: 80px 24px 80px 24px;
	padding: clamp(1.25rem, -0.031rem + 5.47vw, 4rem);
}
.login_bar.flex_center {
	gap: 36px;
	padding: 10px 0 34px;
	text-align: center;
	background: url('../images/ico_grants.svg') no-repeat left center / 72px 72px;
}
.login_bar.flex_center div a {
	display: block;
	width: 280px;
	color: #fff;
	padding: 8px 0;
	border-radius: 999px;
	position: relative
}
.login_bar.flex_center div a::before {
	font-family: 'Material Symbols Outlined';
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	font-size: var(--font-size-28);
}
.btn_gray {
	color: var(--color-text_gray);
}
.btn_gray a {
	background-color: var(--color-text_gray);
	position: relative;
}
.btn_gray a::before {
	content: "account_circle";
	left: 8px;
}
.btn_blue {
	color: var(--color-base);
}
.btn_blue a {
	background-color: var(--color-base);
	position: relative;
}
.btn_blue a::before {
	content: "person_add";
	left: 8px;
}
.end_content {
	color: var(--color-base);
	text-align: center;
	font-size: var(--font-size-24);
	padding: 32px 0;
	position: relative;
	font-weight: bold;
}
.end_content p {
	font-size: var(--font-size-18);
}
.end_content::before,
.end_content::after {
	position: absolute;
	content: "";
	width: 100%;
	height: 8px;
	background-color: var(--color-base);
	border-radius: 999px;
	left: 0;
}
.end_content::before {
	top: 0;
}
.end_content::after {
	bottom: 0;
}
.h3_title_border {
	display: block;
	text-align: center;
	position: relative;
	font-size: var(--font-size-20);
	font-weight: bold;
	color: var(--color-base);
	margin-bottom: 40px;
}
* + .h3_title_border {
	margin-top: 60px;
}
.h3_title_border::after {
	position: absolute;
	content: "";
	width: 100%;
	height: 4px;
	background-color: var(--color-base);
	border-radius: 999px;
	bottom: -8px;
	left: 0;
}
.text_gray_border {
	padding-bottom: 20px;
	border-bottom: 1px solid var(--color-bg_gray);
}
.midashi_theme_color_border {
	padding: 28px 0 20px;
	border-bottom: 1px solid var(--color-bg_gray);
}
.midashi_theme_color_border dt {
	padding-bottom: 6px;
	color: var(--color-base);
	font-weight: bold;
}
.flex_start .region {
	width: 100px;
	flex-shrink: 0;
}
.flex_start .region .text {
	width: calc( 100% - 100px );
	flex: 1;
}
.caption_themecolor {
	padding-top: 20px;
	color: var(--color-base);
	font-size: var(--font-size-14);
}
.link_fuchi_gray_pdf {
	padding-top: 32px;
}
.link_fuchi_gray_pdf a {
	display: block;
	width: fit-content;
	margin-inline: auto;
	color: var(--color-text_gray);
	border: 2px solid var(--color-text_gray);
	border-radius: 999px;
	padding: 4px 24px 4px 48px;
	background: url('../images/ico_pdf.png') no-repeat left 14px center / 22px;
}
.link_border_basecolor {
	margin: 20px 0;
}
.link_border_basecolor a {
	display: flex;
	gap: 8px;
	border: 2px solid var(--color-base);
	padding: 14px 12px 10px;
	width: fit-content;
	margin-inline: auto;
	font-weight: bold;
	font-size: var(--font-size-24);
	border-radius: 8px;
}
.link_border_basecolor a::before {
	font-family: 'Material Symbols Outlined';
	content: "arrow_circle_right";
	font-size: var(--font-size-28);
	font-weight: normal;
}
.still .link_area,
.still .link_fuchi_gray_pdf,
.still .kikan,
.still_about {
	display: none!important;
}
.main_item {
	counter-reset: num;
}
.h4_maru_themecolor {
	counter-increment: num;
	font-weight: bold;
	font-size: var(--font-size-24);
	display: flex;
	align-items: center;
	gap: 8px;
	margin-bottom: 32px;
}
.h4_maru_themecolor::before {
	content: counter(num);
	display: flex;
	justify-content: center;
	align-items: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	color: #fff;
	font-size: var(--font-size-14);
}
.grants_color.h4_maru_themecolor::before {
	background-color: var(--color-grants);
}
.movie_color.h4_maru_themecolor::before {
	background-color: var(--color-movie);
}
.sympo_color.h4_maru_themecolor::before {
	background-color: var(--color-sympo);
}
.grants_list li {
	padding: 24px 32px;
	border-radius: 16px;
	margin-bottom: 32px;
	border: 2px solid var(--color-base);
}
.grants_list li:last-of-type {
	margin-bottom: 64px;
}
.grants_list.grants_color li {
	border: 2px solid var(--color-grants);
}
.grants_list.movie_color li {
	border: 2px solid var(--color-movie);
}
.grants_list.sympo_color li {
	border: 2px solid var(--color-sympo);
}
.grants_list_title {
	padding-bottom: 12px;
	position: relative;
	font-weight: bold;
	font-size: var(--font-size-24);
	margin-bottom: 24px;
	color: var(--color-base);
}
.grants_list.grants_color li .grants_list_title {
	color: var(--color-grants);
}
.grants_list.movie_color li .grants_list_title {
	color: var(--color-movie);
}
.grants_list.sympo_color li .grants_list_title {
	color: var(--color-sympo);
}
.grants_list_title::after {
	content: "";
	position: absolute;
	width: 100%;
	height: 4px;
	bottom: 0;
	left: 0;
	border-radius: 999px;
	background-color: var(--color-base);
}
.grants_list.grants_color li .grants_list_title::after {
	background-color: var(--color-grants);
}
.grants_list.movie_color li .grants_list_title::after {
	background-color: var(--color-movie);
}
.grants_list.sympo_color li .grants_list_title::after {
	background-color: var(--color-sympo);
}
.midashi_flex_border {
	padding-bottom: 20px;
	display: flex;
	gap: 24px;
	align-items: flex-start;
}
.midashi_flex_border + .midashi_flex_border:last-of-type + .link_area {
	border-top: 1px solid var(--color-btn_gray);
}
.midashi_flex_border dt {
	font-weight: bold;
	padding-right: 24px;
	position: relative;
	min-width: 120px;
	flex-shrink: 0;
}
.contact_content .midashi_flex_border dt {
	width: 240px;
	color: var(--color-base);
	font-size: var(--font-size-20);
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.contact_content .midashi_flex_border {
	margin: 12px 0;
}
.contact_content .midashi_flex_border dt span {
	font-size: var(--font-size-14);
	color: #f00;
}
.midashi_flex_border dt::after {
	position: absolute;
	content: "";
	top: 0;
	right: 0;
	display: block;
	width: 4px;
	height: 100%;
	border-radius: 999px;
}
.grants_list.grants_color li .midashi_flex_border dt::after {
	background-color: var(--color-grants);
}
.grants_list.movie_color li .midashi_flex_border dt::after {
	background-color: var(--color-movie);
}
.grants_list.sympo_color li .midashi_flex_border dt::after {
	background-color: var(--color-sympo);
}
.contact_content .midashi_flex_border dt::after {
	background-color: var(--color-base);
	top: 4px;
}
.midashi_flex_border dd {
	color: var(--color-text_gray);
	flex: 1;
}
.contact_content .midashi_flex_border dd input,
.contact_content .midashi_flex_border dd textarea {
	display: block;
	border: 1px solid var(--color-btn_gray);
	width: 100%;
	padding: 8px 10px;
	border-radius: 12px;
}
.contact_content .midashi_flex_border dd input::placeholder {
	color: var(--color-btn_gray);
}
.contact_content input[type="submit"] {
	padding: 10px 20px;
	background-color: var(--color-base);
	color: #fff;
	font-size: var(--font-size-20);
	margin: 40px auto;
	border-radius: 12px;
	display: block;
	cursor: pointer;
}
.link_area {
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
}
.global_navigation > ul > li {
	cursor: pointer;
}
.global_navigation .submenu {
	display: none;
	position: absolute;
	width: 100vw;
	top: 110px;
	left: 0;
	background-color: #fff;
	padding: 32px 0 48px;
	z-index: 999;
}
header.fixed .global_navigation .submenu {
	top: 96px;
}
.submenu .navigation_title {
	margin: 0 calc( 50% - 510px );
	position: relative;
	margin-bottom: 24px;
	font-size: var(--font-size-32);
}
.submenu .navigation_title::after {
	content: "";
	position: absolute;
	bottom: -4px;
	left: 0;
	width: 100%;
	height: 4px;
	background-color: var(--color-base);
	border-radius: 999px;
}
.inner_navigation {
	width: 100%;
	max-width: 1020px;
	margin-inline: auto;
	font-size: var(--font-size-20);
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
.global_navigation .inner_navigation li {
	flex-basis: 48%;
}
.menu .inner_navigation li {
	width: 100%;
}
.global_navigation .inner_navigation a {
	display: block;
	color: var(--color-base);
	padding: 16px 0;
	position: relative;
}
.global_navigation .inner_navigation a::after {
	content: '';
	width: 12px;
	height: 12px;
	border-top: solid 2px var(--theme);
	border-right: solid 2px var(--theme);
	position: absolute;
	right: 8px;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
}
/*財団概要*/
ol.maru_flex_list {
	counter-reset: num;
}
ol.maru_flex_list > li {
	display: flex;
	align-items: flex-start;
	gap: 88px;
	padding: 24px 0;
}
ol.maru_flex_list > li + li {
	border-top: 1px solid var(--color-btn_gray);
}
ol.maru_flex_list > li .h5_maru_basecolor {
	counter-increment: num;
	padding-left: 40px;
	position: relative;
	flex-shrink: 0;
	font-size: var(--font-size-20);
	font-weight: bold;
	color: var(--color-base);
	width: 200px;
	text-align: justify;
	text-align-last: justify;
}
ol.maru_flex_list > li .h5_maru_basecolor::before {
	content: counter(num);
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 28px;
	height: 28px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	font-size: var(--font-size-14);
	background-color: var(--color-base);
}
ol.maru_flex_list > li .text .h4_title:first-child {
	margin-top: 0;
}
.gaiyou_josei {
	font-size: var(--font-size-14);
	margin-bottom: 48px;
}
.gaiyou_josei tr:nth-of-type(n+3) {
	border-bottom: 1px solid var(--color-bg_gray);
}
.gaiyou_josei tr:last-of-type {
	border-top: 3px double var(--color-bg_gray);
}
.gaiyou_josei tr:nth-of-type(-n+2) th {
	background-color: var(--color-base);
	color: #fff;
	text-align: center;
	vertical-align: middle;
}
.gaiyou_josei tr:first-of-type th:first-of-type {
	border-radius: 12px 0 0 0;
}
.gaiyou_josei tr:first-of-type th:last-of-type {
	border-radius: 0 12px 0 0;
}
.gaiyou_josei tr:first-of-type th:not(:last-of-type),
.gaiyou_josei tr:nth-of-type(2) th:nth-of-type(2n):not(:last-of-type) {
	border-right: 1px solid #fff;
}
.gaiyou_josei tr:nth-of-type(n+3) td {
	border-right: 1px solid var(--color-btn_gray);
	text-align: center;
	padding: 4px 8px;
}
.gaiyou_josei tr:nth-of-type(n+3) td:first-of-type {
	border-left: 1px solid var(--color-btn_gray);
}
.link_fuchi_basecolor {
	margin: 16px 0;
}
.link_fuchi_basecolor a {
	display: block;
	width: fit-content;
	padding: 8px 20px 8px 16px;
	line-height: 1;
	border: 1px solid var(--color-base);
	border-radius: 999px;
	color: var(--color-base);
	position: relative;
}
.link_fuchi_basecolor a::before {
	content: "";
	width: 8px;
	height: 8px;
	border-top: solid 2px var(--color-base);
	border-right: solid 2px var(--color-base);
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
}
.grants_list li .text_basecolor {
	padding-top: 16px;
}
.column_list > li {
	display: grid;
	grid-template-columns: 120px 146px 1fr;
	gap: 16px;
	padding-bottom: 16px;
	padding-left: 48px;
	margin-bottom: 16px;
	align-items: center;
	border-bottom: 1px solid var(--color-btn_gray);
}
.column_list > li + li:last-of-type {
	border-bottom: none;
}
.column_list > li > div:not(:last-of-type) {
	border-right: 1px solid var(--color-btn_gray);
	line-height: 1;
	padding-right: 40px;
}
.column_list > li > .position,
.column_list > li > .name {
	text-align: justify;
	text-align-last: justify;
}
.pdf_list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.pdf_list li {
	flex: 0 0 48%;
	min-width: 250px;
}
.pdf_list:first-of-type li {
	min-width: 480px;
}
.pdf_list li a {
	display: block;
	color: var(--color-text_gray);
	padding: 24px 0 24px 40px;
	background: url(../images/ico_pdf.png) no-repeat left 10px center / 22px;
	border-bottom: 1px solid var(--color-btn_gray);
}
.pdf_list li.html a {
	display: flex;
	background: none;
	padding: 24px 0;
	align-items: center;
}
.pdf_list li.html a::before {
	font-family: 'Material Symbols Outlined';
	content: "tab_move";
	font-size: var(--font-size-20);
	line-height: 1;
	color: var(--color-text_gray);
}
.flex_container {
	display: flex;
	justify-content: space-between;
}
.flex_container:has(.flex_item_text > .grants_list_title) {
	gap: 32px;
}
.publications .flex_item {
	text-align: center;
}
.flex_item a {
	display: block;
	text-align: center;
}
.flex_item_text {
	flex: 1;
}
.flex_item_img {
	flex-basis: 25%;
}
.h4_title {
	color: var(--color-base);
	border-left: 4px solid var(--color-base);
	padding-left: 10px;
	margin-top: 48px;
	font-size: var(--font-size-20);
	font-weight: bold;
}
.grants_color.h4_title {
	color: var(--color-grants);
	border-left: 4px solid var(--color-grants);
}
.movie_color.h4_title {
	color: var(--color-movie);
	border-left: 4px solid var(--color-movie);
}
.sympo_color.h4_title {
	color: var(--color-sympo);
	border-left: 4px solid var(--color-sympo);
}
div:has(.faq_content) {
	padding-top: 32px;
}
.faq_content > dt {
	position: relative;
	padding: 16px 48px 16px 16px;
	cursor: pointer;
	margin-bottom: 16px;
	background-color: var(--color-bg_gray);
	border-radius: 12px;
}
.faq_content > dd {
	display: none;
	padding: 0 0 16px 32px;
}
.faq_content > dt::before,
.faq_content > dt::after {
    position: absolute;
    content: '';
    top: 1px;
    right: 20px;
    bottom: 0;
    width: 12px;
    height: 2px;
    margin: auto;
}
.faq_content > dt.active::after {
    transform: rotate(0deg);
}
.faq_content > dt::after {
    transform: rotate(-90deg);
    transition: transform 0.3s;
}
.text_basecolor + .faq_content_outer .faq_content dt::before,
.text_basecolor + .faq_content_outer .faq_content dt::after {
	background-color: var(--color-base);
}
.grants_color + .faq_content_outer .faq_content dt::before,
.grants_color + .faq_content_outer .faq_content dt::after {
	background-color: var(--color-grants);
}
.movie_color + .faq_content_outer .faq_content dt::before,
.movie_color + .faq_content_outer .faq_content dt::after {
	background-color: var(--color-movie);
}
.sympo_color + .faq_content_outer .faq_content dt::before,
.sympo_color + .faq_content_outer .faq_content dt::after {
	background-color: var(--color-sympo);
}
.faq_content_dt {
    width: 100%;
	font-size: var(--font-size-20);
	font-weight: bold;
}
.faq_content_dt a {
	display: block;
	position: relative;
	border: 2px solid var(--color-text_gray);
	color: var(--color-text_gray);
	border-radius: 12px;
	padding: 16px 48px;
	background: url(../images/ico_pdf.png) no-repeat left 14px center / 22px;
}
.faq_content_dt a::after {
	position: absolute;
	font-family: 'Material Symbols Outlined';
	content: "arrow_forward";
	right: 14px;
	top: 50%;
	transform: translateY(-50%);
}
.grants_list > li.flex_container .flex_item img {
	width: 141px;
	height: 200px;
	object-fit: cover;
}
.link_fuchi_gray_url a,
.link_fuchi_color_url a {
	display: block;
	position: relative;
	width: fit-content;
	margin-inline: auto;
	border-radius: 999px;
	padding: 4px 24px 4px 40px;
	font-size: var(--font-size-16);
	font-weight: normal;
	white-space: nowrap;
}
.link_fuchi_gray_url a {
	color: var(--color-text_gray);
	border: 2px solid var(--color-text_gray);
}
.link_fuchi_color_url.text_themecolor a {
	color: var(--color-base);
	border: 2px solid var(--color-base);
}
.link_fuchi_gray_url a::before,
.link_fuchi_color_url.text_themecolor a::before {
	font-family: 'Material Symbols Outlined';
	content: "tab_move";
	display: block;
	position: absolute;
	left: 10px;
	top: 50%;
	transform: translateY(-50%);
}
.h4_title:has( + ul) {
	margin-bottom: 40px;
}
.row2_list {
	padding-left: 40px;
}
.row2_list li {
	display: grid;
	grid-template-columns: 1fr 5fr;
	gap: 12px;
	margin-bottom: 24px;
	padding-bottom: 12px;
	border-bottom: 1px solid var(--color-btn_gray);
}
.row2_list li .name {
	font-size: var(--font-size-18);
	font-weight: bold;
}
.row2_list li .affiliation {
	display: flex;
	align-items: center;
	border-left: 1px solid var(--color-btn_gray);
	padding-left: 32px;
}
.themes {
	font-size: var(--font-size-18);
	font-weight: bold;
}
.row2_list li .themes,
.row2_list li .text {
	grid-column: span 2;
}
.themes::before {
	content: "受賞対象研究テーマ：";
	display: inline-block;
}
.kadomaru_list li {
	display: flex;
	gap: 12px;
}
.kadomaru_list li:first-of-type {
	background-color: var(--color-base);
	color: #fff;
	border-radius: 12px 12px 0 0;
	padding: 6px 0;
}
.kadomaru_list li:not(:first-of-type) {
	border-bottom: 1px solid var(--color-btn_gray);
	padding: 12px 0;
}
.kadomaru_list li div:not(:last-of-type) {
	padding-right: 32px;
	border-right: 1px solid var(--color-btn_gray);
}
.kadomaru_list li .name {
	width: 200px;
	flex-shrink: 0;
	padding-left: 12px;
}
.kadomaru_list li .affiliation {
	width: 300px;
}
.midashi_row_list li {
	margin-bottom: 36px;
	border-bottom: 1px solid var(--color-btn_gray);
}
.midashi_row_list li .name {
	background-color: var(--color-base);
	border-radius: 12px 12px 0 0;
	padding: 6px 24px;
}
.midashi_row_list li .name a {
	color: #fff;
}
.midashi_row_list li .affiliation,
.midashi_row_list li .themes {
	display: flex;
	padding: 12px 24px;
	gap: 12px;
}
.midashi_row_list li .affiliation::before,
.midashi_row_list li .themes::before {
	display: block;
	width: 180px;
	flex-shrink: 0;
	border-right: 1px solid var(--color-btn_gray);
}
.midashi_row_list li .affiliation::before {
	content: "所属機関";
}
.midashi_row_list li .themes::before {
	content: "受賞対象研究テーマ";
}
.movie_content {
	text-align: center;
}
.movie_content img {
	width: 100%;
	max-width: 600px;
	height: auto;
}
.pagenation {
	padding-top: 36px;
}
.nav-links {
	display: flex;
	gap: 8px;
}
.pagenation .page-numbers {
	display: flex;
	align-items: center;
	justify-content: center;
}
.pagenation .page-numbers:not(:is(.next, .prev, .dots)) {
	width: 32px;
	height: 32px;
	border: 1px solid var(--color-base);
	color: var(--color-base);
}
.pagenation .page-numbers.current {
	border: 1px solid var(--color-base);
	background-color: var(--color-base);
	color: #fff;
}
main.innovation {
	background-color: #fff!important;
	padding-top: 40px;
}
.link_innovation_area {
	display: flex;
	gap: 32px;
	flex-wrap: wrap;
	width: fit-content;
	margin: 0 auto 40px;
}
.h2_title_innovation {
	background: linear-gradient(rgb(0 0 0 / .4), rgb(0 0 0 / .4)),
					url('../images/thum_innovation04.jpg') no-repeat center top -500px / cover;
	padding: 80px 0;
	padding-left: calc( 50% - 590px );
	font-weight: bold;
	font-size: var(--font-size-32);
	display: flex;
	text-shadow: 1px 0 4px var(--color-text_gray);
	color: #fff;
	align-items: center;
}
.h2_title_innovation:nth-of-type(2) {
	background: linear-gradient(rgb(0 0 0 / .4), rgb(0 0 0 / .4)),
					url('../images/thum_innovation04.jpg') no-repeat center bottom -50px / cover;
}
.innovation .flex_container {
	margin: 24px auto;
	line-height: 2.2em;
}
.innovation .flex_container .flex_item_img {
	flex-basis: 35%;
	flex-shrink: 0;
}
.innovation_content {
	margin: 24px auto 60px;
	line-height: 2.2em;
}
.innovation_content .grants_list_title {
	display: inline-block;
	margin-top:clamp(1rem, 0.767rem + 0.99vw, 1.5rem);
	margin-bottom:clamp(1rem, 0.767rem + 0.99vw, 1.5rem);
}
/* アニメーション前 */
.u-fade-type-left{
    transform: translateX(-50px);
    opacity: 0;
}
.u-fade-type-right{
    transform: translateX(50px);
    opacity: 0;
}
/* トリガー発火でis-activeを付与 */
.u-fade-type-left.is-active,
.u-fade-type-right.is-active {
    transition: .8s;
    transform: translateX(0);
    opacity: 1;
}
.detail_list li {
	display: grid;
	gap: 12px;
	grid-template-columns: 1fr 5fr;
}
.detail_list li + li {
	border-top: 1px solid var(--color-btn_gray);
	margin-top: 24px;
	padding-top: 24px;
}
.detail_list li .name {
	display: flex;
	align-items: flex-end;
	font-weight: bold;
	font-size: var(--font-size-20);
}
.detail_list li .photo {
	grid-row: span 2;
}
.detail_list li div:nth-child(n+4) {
	grid-column: span 2;
}
ol {
	counter-reset: num;
}
ol > li > ol > li {
	margin-left: 1.4em;
}
ol:not(.maru_flex_list) > li {
	counter-increment: num;
}
ol > li:not(:has(> *)) {
	display: flex;
	gap: 8px;
}
body.others ol > li:not(:has(> *)) {
	margin-bottom: 16px;
}
ol > li::before {
	text-indent: 0;
	display: inline-block;
	width: 1.4em;
	flex-shrink: 0;
}
.dot_number_list > li::before {
	content: counter(num) '.';
}
.kakko_number_list > li::before {
	content: '（' counter(num) '）';
	width: 1.8em;
}
.award .flex_start.text {
	gap: 36px;
}
.accordion_outer dl dt::after {
  content: "";
  position: absolute;
  top: 50%;
  bottom: auto;
  transform: translateY(-50%) rotate(135deg);
  right: 20px;
  width: 13px;
  height: 13px;
  transition: all 0.3s;
}
.accordion_outer dl dt {
	background-color: transparent;
	font-size: var(--font-size-20);
	font-weight: bold;
}
.accordion_outer dl:nth-of-type(odd) dt {
	color: var(--color-grants);
	border: 2px solid var(--color-grants);
}
.accordion_outer dl:nth-of-type(odd) dt::after {
  border-top: 3px solid var(--color-grants);
  border-right: 3px solid var(--color-grants);
}
.accordion_outer dl:nth-of-type(even) dt {
	border: 2px solid #9fcbe6;
	color: #9fcbe6;
}
.accordion_outer dl:nth-of-type(even) dt::after {
  border-top: 3px solid #9fcbe6;
  border-right: 3px solid #9fcbe6;
}
.accordion_outer dl dt.active::after {
  transform: translateY(-50%) rotate(45deg);
}
.accordion_outer dl:first-of-type dt::after {
  transform: translateY(-50%) rotate(45deg);
}
.accordion_outer dl:first-of-type dt.active::after {
  transform: translateY(-50%) rotate(135deg);
}
.accordion_outer dl:first-of-type dd {
	display: block;
}
.report_preface a {
	display: inline-block;
	position: relative;
	color: var(--color-base);
	font-size: var(--font-size-28);
	font-weight: bold;
}
.report_content h3,
.lecture_title {
	display: inline-block;
	position: relative;
	color: var(--color-base);
	font-size: var(--font-size-24);
	font-weight: bold;
	margin: 24px 0;
}
.report_content h3:not(:has(+ .h4_title)) {
	margin-bottom: 16px;
}
.report_content h3::after,
.lecture_title::after {
	position: absolute;
	content: "";
	width: 100%;
	height: 4px;
	background-color: var(--color-base);
	border-radius: 999px;
	bottom: -8px;
	left: 0;
}
.report_content .h4_title {
	font-size: var(--font-size-24);
}
.report_content dt {
	font-size: var(--font-size-24);
	font-weight: bold;
	color: var(--color-base);
	margin-top: 16px;
	cursor: pointer;
	display: flex;
	gap: 8px;
	align-items: center;
}
.report_content dt::before {
	font-family: 'Material Symbols Outlined';
	content: "arrow_drop_down_circle";
	font-size: var(--font-size-28);
	font-weight: normal;
	transition: .8s;
}
.report_content dt.active::before {
	transform: rotate(-180deg);
}
.report_content dd {
	counter-reset: num;
	display: none;
}
.report_item {
	border: 2px solid var(--color-btn_gray);
	padding: 12px 18px;
	border-radius: 18px;
	font-size: var(--font-size-18);
	margin: 16px 0;
}
.report_item h5 {
	color: var(--color-grants);
	font-weight: bold;
	font-size: var(--font-size-20);
	padding-bottom: 12px;
}
.report_item .name {
	font-weight: bold;
	padding-left: 20px;
}
.report_item .affiliation {
	padding-left: 20px;
}
.report_item .link_area {
	margin-top: 24px;
}
.report_item .link_area .link_fuchi_gray_pdf {
	padding-top: 0;
}
.report_item .link_area .link_fuchi_gray_pdf a {
	border: 2px solid var(--color-btn_gray);
}
.nolink {
	background-color: var(--color-grants);
	width: fit-content;
	padding: 4px 24px;
	color: #fff;
}
.square_basecolor {
	border: 2px solid var(--color-base);
	border-radius: 18px 18px 0 0;
	margin-bottom: 24px;
}
.login_content .square_basecolor,
.top_content_login.square_basecolor {
	border-radius: 18px;
	padding: 16px;
}
body.others .square_basecolor {
	border-radius: 18px;
	padding: 48px;
}
.square_basecolor_content {
	width: fit-content;
	margin-inline: auto;
	padding: 8px 12px 12px;
}
.h3_title_nuri {
	background-color: var(--color-base);
	border: 2px solid var(--color-base);
	padding: 10px 0 8px;
	border-radius: 15px 15px 0 0;
	text-align: center;
	color: #fff;
	font-weight: bold;
	font-size: var(--font-size-24);
	position: relative;
	cursor: pointer;
}
.h3_title_nuri::before {
	position: absolute;
	font-family: 'Material Symbols Outlined';
	content: "keyboard_double_arrow_down";
	left: 10px;
	top: 50%;
	transform: translateY(-50%);
	color: #fff;
	font-size: var(--font-size-24);
}
.h3_title_nuri_link {
	position: absolute;
	right: 10px;
	top: 50%;
	transform: translateY(-50%);
}
.h3_title_nuri_link a {
	display: flex;
	padding: 6px 12px;
	background-color: #fff;
	color: var(--color-base);
	justify-content: center;
	align-items: center;
	font-size: var(--font-size-14);
}
.square_basecolor_content {
	display: none;
}
.midashi_flex {
	display: flex;
	gap: 24px;
	padding: 8px 0;
}
.midashi_flex dt {
	font-weight: bold;
	font-size: var(--font-size-18);
	position: relative;
	padding-right: 24px;
	flex-shrink: 0;
}
.midashi_flex dt::after {
	content: "";
	position: absolute;
	height: 80%;
	width: 3px;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	border-radius: 999px;
	background-color: var(--color-base);
}
a.icon_pdf {
	display: flex;
	align-items: center;
	gap: 10px;
}
a.icon_pdf::after {
	font-family: 'Material Symbols Outlined';
	content: "picture_as_pdf";
	font-size: var(--font-size-32);
	color: var(--color-base);
	font-weight: normal;
	padding-top: 6px;
}
.preface_conten {
	width: fit-content;
	margin-inline: auto;
}
.preface_content .flex_start {
	gap: 32px;
	margin: 8px 0 8px 60px;
}
.preface_content .flex_start div:first-child {
	flex-basis: 260px;
}
.page_report {
	line-height: 1.8em;
}
.indent01 {
	text-indent: 1em;
}
.indent03 {
	padding-left: 3em;
}
.slider_s_text .indent01 {
	display: inline-block;
	text-indent: 1em;
}
.midashi_theme_color_border.preface_content {
	margin-bottom: 24px;
}
.page_text .flex_start {
	margin-left: 60px;
}
.page_report .right:last-of-type{
	margin-top: 40px;
}
.pagetop {
	opacity: 0;
	transition: .4s;
	position: fixed;
	bottom: 80px;
	right: 36px;
	text-align: center;
	line-height: 1;
	z-index: 999;
}
.pagetop:has(+ .header.fixed) {
	opacity: 1;
	transition: .4s;
}
.pagetop a {
	display: flex;
	flex-direction: column;
	width: 72px;
	height: 72px;
	border-radius: 999px;
	background-color: var(--color-base);
	color: #fff;
	align-items: center;
	justify-content: center;
}
.pagetop a::before {
	font-family: 'Material Symbols Outlined';
	content: "keyboard_arrow_up";
	line-height: 1;
}
.abroad_title {
	cursor: pointer;
}
.abroad_title + .abroad_content {
	display: none;
}
.lecture_poster {
	text-align: center;
	margin: 40px 0;
}
.lecture_poster a {
	display: block;
}
.lecture_poster img {
	width: 80%;
	max-width: 400px;
}
.lecture_schedule {
	padding: 24px 0 0;
}
.step_content {
	counter-reset: num;
}
.h3_title_step {
	border: 1px solid var(--color-base);
	padding: 16px 32px;
	counter-increment: num;
	display: flex;
	gap: 16px;
	font-size: var(--font-size-24);
	color: var(--color-base);
	font-weight: bold;
}
.h3_title_step::before {
	content: 'STEP ' counter(num);
	flex-shrink: 0;
}
.step_list {
	padding: 24px 0 36px 24px;
	font-size: var(--font-size-18);
}
.step_list li {
	margin-bottom: 8px;
}
.step_list li {
	display: flex;
	gap: 8px;
}
.step_list li *:not(a, .link_fuchi, .text, form, .red, .bold) {
	padding-left: 1em;
}
.grants .link_fuchi {
	margin-bottom: 36px;
}
.step_list li::before {
	font-family: 'Material Symbols Outlined';
	content: "check_circle";
	color: var(--color-base);
}
.prospectus_content {
	font-size: var(--font-size-18);
}
.anchor_link {
	display: flex;
	gap: 8px;
	justify-content: space-around;
	font-size: var(--font-size-20);
	margin-bottom: 60px;
}
.anchor_link a {
	display: flex;
	align-items: center;
}
.anchor_link a::before {
	font-family: 'Material Symbols Outlined';
	content: "arrow_circle_down";
	color: var(--color-base);
}
.directors_list li .flex_start {
	gap: 16px;
	margin-bottom: 60px;
}
.directors_list li .photo {
	flex-basis: 180px;
	flex-shrink: 0;
}
.directors_list li .photo img {
	width: 100%;
}
.directors_list li .name {
	font-size: var(--font-size-24);
	font-weight: bold;
	margin-bottom: 32px;
	display: flex;
	align-items: center;
}
.directors_content .text {
	border-left: solid 1px var(--color-btn_gray);
	padding-left: 16px;
	margin-left: 16px;
}
.flex_start:has(> .reki_list) {
	align-items: flex-start;
	gap: 32px!important;
	margin-top: 40px;
	padding-bottom: 20px;
}
.flex_start:has(> .reki_list) .h4_title {
	margin: 0;
	flex-basis: 200px;
	flex-shrink: 0;
}
.reki_list {
	display: table;
	table-layout: fixed;
}
.reki_list li {
	display: table-row;
}
.reki_list li > * {
	display: table-cell;
}
.reki_list li .period {
	width: fit-content;
	padding-right: 48px;
}
.reki_list li .affiliation {
	padding-right: 48px;
}
.input_area {
	text-align: center;
	margin-bottom: 24px;
	display: flex;
	justify-content: center;
	gap: 24px;
}
.login_content input[type="text"],
.login_content input[type="password"] {
	border: solid 1px var(--color-base);
	padding: 6px 16px;
	width: 30%;
	border-radius: 8px;
	text-align: left;
}
.link_forget {
	padding-top: 16px;
	text-align: center;
	font-size: var(--font-size-20);
}
.link_forget a {
	color: var(--color-base);
}
#login_btn {
	display: block;
	width: fit-content;
	margin-inline: auto;
	background-color: var(--color-base);
	color: #fff;
	font-weight: bold;
	padding: 8px 24px;
	font-size: var(--font-size-24);
	border-radius: 12px;
}
.top_content_login.square_basecolor {
	margin-top: 42px;
	padding: 24px 16px;
}
.top_login_top.flex_start {
	align-items: center;
}
.login_heading {
	font-size: var(--font-size-18);
	padding-right: 20px;
	border-right: 2px solid var(--color-base);
	line-height: 1;
	margin-right: 20px;
}
.top_login_form.flex_start {
	align-items: center;
}
.top_login_form {
	padding-top: 16px;
}
.top_login_form input {
	width: 100%;
	height: 48px;
	border-radius: 25px;
	border: 1px solid var(--color-text_gray);
	padding: 0 15px;
}
.top_login_form div {
	width: 100%;
	max-width: 250px;
   margin-right: 24px;
}
.login_btn {
	padding-right: 20px;
	border-right: 2px solid var(--color-base);
	margin-right: 20px;
}
.login_btn a {
	display: block;
	text-align: center;
	border: solid 1px var(--color-text_gray);
	border-radius: 24px;
	background-repeat: no-repeat;
	background-position: right 20px center;
	background-size: 10px 10px;
	line-height: 44px;
	background-color: var(--color-text_gray);
	color: #fff;
}
.newmember_btn a {
	display: block;
	text-align: center;
	background-color: var(--color-base);
	border: solid 1px var(--color-base);
	color: #fff;
	line-height: 44px;
	border-radius: 24px;
	background-repeat: no-repeat;
	background-position: right 10px center;
	background-size: 30px 30px;
}





















































/* ----------------------------------------
   common
---------------------------------------- */

.bold {
	font-weight: bold;
}
.italic {
   font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	font-style: italic;
}
.red {
	color: #f00;
}
.small {
	font-size: var(--font-size-14);
}
.fs18 {
	font-size: var(--font-size-18);
}
.middle {
	font-size: var(--font-size-24);
}
.big {
	font-size: var(--font-size-32);
}
.text_themecolor {
	color: var(--theme);
}
.text_basecolor {
	color: var(--color-base);
}
.grants_color {
	color: var(--color-grants);
}
.movie_color {
	color: var(--color-movie);
}
.sympo_color {
	color: var(--color-sympo);
}
.text {
	width: 100%;
}
.center {
	text-align: center;
}
.left {
	text-align: left;
}
.right {
	text-align: right;
}
.page_text {
	margin-bottom: 1.5em;
}

@media (any-hover: hover) {
	a:hover {
		opacity: .4;
	}
	.menu .inner ul li a:hover {
	  background: var(--color-btn_gray);
	  color: #000;
	}
	.h3_title_nuri_link a:hover {
		background-color: #fbd544;
		opacity: 1;
	}
}