@charset "UTF-8";

/* ==========================================================================//
//
// [流用]
//
// ========================================================================== */

/* -----------------------------------------------------------------
リセット
------------------------------------------------------------------ */
* {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	vertical-align: baseline;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
ol, ul {
	list-style: none;
}
img {
	width: 100%;
	height: auto;
	display: block;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
b, strong {
	font-weight: bold;
}

/* -----------------------------------------------------------------
プリセット
------------------------------------------------------------------ */
html, body {
	-webkit-backface-visibility: hidden;
}
html {
	font-size: 62.5%;
}
/*@media screen and (max-width: 767px) {
	html {
		font-size: 59.375%;
	}
}*/
body {
	background-color: #FFF;
	color: #222;
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.5;
	font-weight: 400;
	font-family: 'Inter', 'BIZ UDPGothic', sans-serif;
	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-smoothing: antialiased;
	padding-top: 0 !important;
}
@media screen and (min-width: 768px) {
	body {
		width: 100%;
		height: 100%;
		min-width: 1282px;
	}
}

h1, h2, h3, h4, h5 {
	margin: 0;
	padding: 0;
	line-height: 1.5;
	font-feature-settings: "palt";
}

p {
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.8;
	font-feature-settings: "palt";
}
@media screen and (max-width: 767px) {
	p {
		font-size: 16px;
		font-size: 1.6rem;
	}
}

a {
	color: inherit;
	text-decoration: none;
}
a:hover span,
a:hover {
	text-decoration: none;
}

/* -----------------------------------------------------------------
レスポンシブ
------------------------------------------------------------------ */
.container {
	width: 100%;
	max-width: 1282px;
	margin: 0 auto;
	padding: 0 30px;
	position: relative;
}
@media screen and (max-width: 767px) {
	.container {
		padding: 0 15px;
	}
}

/* -----------------------------------------------------------------
ヘッダー
------------------------------------------------------------------ */
.mod_headerarea {
	min-width: 1282px;
	width: 100%;
	margin: 0 auto;
	position: fixed;
	top: 0;
	right: 0;
	left: 0;
	z-index: 30;
	transition: transform 0.3s ease;
	background: #123C48;
	color: #FFF;
}
.mod_headerarea.hidden {
	transform: translateY(-90px);
}
.mod_header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
	position: relative;
	z-index: 30;
	width: 100%;
	padding: 15px 15px 15px 50px;
}
@media screen and (max-width: 1282px) {
	.mod_header {
		padding-left: 30px;
	}
}
.mod_logoarea {
	height: 50px;
}
.mod_logoarea img {
	height: 100%;
	width: auto;
}
.mod_logoarea a:hover img {
	opacity: 1;
}

/* .mod_gnavi */
.mod_gnavi_wrapper {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.mod_gnavi {
	display: flex;
	gap: 30px;
	align-items: center;
	font-size: 15px;
	font-size: 1.5rem;
	font-feature-settings: normal;
	position: relative;
}
.mod_gnavi * {
	box-sizing: border-box;
	-webkit-transition: all 0.35s ease;
	transition: all 0.35s ease;
}
.mod_gnavi > li {
	display: inline-block;
	list-style: outside none none;
	overflow: hidden;
}
.mod_gnavi > li > a {
	padding: 0.3em 0;
	position: relative;
	display: inline-block;
	margin: 0;
	text-decoration: none;
	outline-offset: -1px;
}
.mod_gnavi > li > a:hover,
.mod_gnavi > li > a:hover span {
	color: unset;
}
/* .mac .mod_gnavi > li > a:focus, .iphone .mod_gnavi > li > a:focus, .ipod .mod_gnavi > li > a:focus, .ipad .mod_gnavi > li > a:focus {
	outline: 4px solid #4d90fe;
	outline-offset: -2px;
} */
/* .mod_gnavi > li > a:focus {
	transform: none;
} */
.mod_gnavi > li > a:before, .mod_gnavi > li > a:after {
	position: absolute;
	-webkit-transition: all 0.35s ease;
	transition: all 0.35s ease;
}
.mod_gnavi > li > a:before {
	bottom: 100%;
	display: block;
	height: 2px;
	width: 100%;
	content: "";
	background-color: #F0C88F;
}
.mod_gnavi > li > a.icon:before {
	width: calc(100% - 16px);
}
.mod_gnavi > li > a:after {
	content: attr(data-hover);
	position: absolute;
	bottom: 100%;
	left: 0;
	padding: 5px 0;
	white-space: nowrap;
	color: #F0C88F;
	visibility: hidden;
}
.mod_gnavi > li > a:hover:after,
.mod_gnavi > li.current > a:after,
.nav-dropdown[aria-expanded="true"] > a:after,
.nav-dropdown:focus-visible > a:after {
	visibility: visible;
}
.mod_gnavi > li:hover > a,
.mod_gnavi .current > a,
.nav-dropdown[aria-expanded="true"] > a,
.nav-dropdown:focus-visible > a {
	transform: translateY(100%);
}
.mod_gnavi > li > a.icon:after {
	bottom: 100%;
	color: #F0C88F;
	content: attr(data-hover) "\00A0\e912";
	font-family: Inter,BIZ UDPGothic,メイリオ,Meiryo,游ゴシック,Yu Gothic,sans-serif, icomoon;
	left: 0;
	padding: 5px 0;
	position: absolute;
	white-space: nowrap;
}
.mod_gnavi .icon {
	margin: 0;
}
.mod_gnavi > li > a.icon_arrow .icon:before {
	content: "\00A0\e912";
}
.mod_gnavi > li > a.icon_win .icon {
	padding-left: 10px;
}
.mod_gnavi > li > a.icon_win .icon:before {
	content: "\e958";
}
.mod_gnavi > li > a.icon_win:after {
	content: attr(data-hover) "　\e958";
}
.mac .mod_gnavi > li > a.icon:after,
.iphone .mod_gnavi > li > a.icon:after,
.ipod .mod_gnavi > li > a.icon:after,
.ipad .mod_gnavi > li > a.icon:after {
	font-family: 'Inter', 'BIZ UDPGothic', -apple-system, BlinkMacSystemFont, 'Helvetica Neue', Helvetica, 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', sans-serif, icomoon;
}

.mod_btnarea {
	width: 190px;
}
.mod_btnarea .btn {
	font-size: 14px;
	font-size: 1.4rem;
	line-height: 1;
	padding: 18px;
}
@media screen and (max-width: 767px) {
	.mod_btnarea {
		display: none;
	}
}

.dropdown_menu {
	display: none;
	padding-top: 55px;
	position: absolute;
	top: 10px;
	right: 19%;
	opacity: 0;
	transition: opacity 0.3s ease, transform 0.3s ease;
}
#nav-outline .dropdown_menu {
	right: auto;
	left: 0;
}
.nav-dropdown[aria-expanded="false"] .dropdown_menu {
	display: none;
}
.nav-dropdown .dropdown_menu.is-visible,
.nav-dropdown:focus-visible .dropdown_menu {
	display: block;
	opacity: 1;
	transform: translateY(0);
}
.nav-dropdown .dropdown_menu a {
	tabindex: -1;
}
.mod_gnavi .border {
	position: relative;
	overflow: visible;
}
.mod_gnavi .border:before {
	content: "";
	width: 1px;
	height: 80px;
	background: #FFF;
	position: absolute;
	left: 0;
	top: -40px;
}

/* メニューが表示されたときにtabindexを0にしてタブ移動可能 */
.nav-dropdown .dropdown_menu.is-visible a {
	tabindex: 0;
}
.nav-dropdown .dropdown_menu.is-visible .icon_arrow:after {
	content: attr(data-hover) "\00A0\e91b";
}
.dropdown_menu_wrap {
	background: #FFF;
	border: 1px solid #E2E2E2;
	border-radius: 3px;
	padding: 5px 20px;
	font-size: 15px;
	min-width: 169px;
}
.dropdown_menu_list li {
	position: relative;
}
.dropdown_menu_list li > span,
.dropdown_menu_list li a {
	display: block;
	padding: 15px 0;
	padding-left: 18px;
	color: #999999;
}
.dropdown_menu_list li a:after,
.dropdown_menu_list li > span:after {
	content: "";
	position: absolute;
	left: 0;
	top: 24px;
	background: #074944;
	width: 8px;
	height: 2px;
}
.dropdown_menu_list li a span {
	color: #222;
}
.dropdown_menu_list > li + li {
	border-top: 1px solid #E2E2E2;
}
.submenu2 {
	margin-left: 20px;
}
.submenu2 li a:before {
	height: 1px;
	top: 10px;
}
.submenu2 li a {
	padding-top: 0;
}

/* @media screen and (max-width: 1280px) {
	.mod_header {
		padding: 15px 25px;
	}
	.mod_gnavi {
		gap: 23px;
	}
} */
@media screen and (max-width: 767px) {
	.mod_headerarea {
		min-width: auto;
	}
	.mod_header {
		padding: 10px 15px;
	}
	.mod_logoarea {
		height: 40px;
	}
	.mod_gnavi {
		display: none !important;
	}
}

/* -----------------------------------------------------------------
ドロワー
------------------------------------------------------------------ */
.drawer,
.drawer.hidden {
	display: none;
}
.drawer.hidden {
	transform: translateY(-90px);
}
.drawer {
	transition: transform 0.3s ease;
}
.drawer-hamburger {
	width: 57px;
	height: 50px;
	z-index: 2;
	padding: 0 18px;
	position: fixed;
	top: 5px;
	right: 0;
	display: block;
	transition: all .6s cubic-bezier(.19, 1, .22, 1);
	transform: translateZ(0);
	border-left: 1px solid #6C8E8B;
	background: transparent;
}
.drawer-hamburger-text {
	display: none;
}
.drawer-toggle[aria-expanded="false"] .drawer-open-text {
	display: inline;
}
.drawer-toggle[aria-expanded="true"] .drawer-close-text {
	display: inline;
}
.drawer-hamburger-icon {
	position: relative;
	display: block;
}
.drawer-hamburger-icon:after,
.drawer-hamburger-icon:before {
	content: " ";
	position: absolute;
	top: -10px;
	left: 0;
	background-color: #FFF;
}
.drawer-hamburger-icon,
.drawer-hamburger-icon:after,
.drawer-hamburger-icon:before {
	width: 100%;
	height: 2px;
	-webkit-transition: all .6s cubic-bezier(.19, 1, .22, 1);
	transition: all .6s cubic-bezier(.19, 1, .22, 1);
	background-color: #FFF;
}
.drawer-hamburger-icon:before {
	top: -7px;
}
.drawer-hamburger-icon:after {
	top: 7px;
}
.drawer-open .drawer-hamburger-icon {
	background-color: transparent;
}
.drawer-open .drawer-hamburger-icon:after,
.drawer-open .drawer-hamburger-icon:before {
	top: 0;
}
.drawer-open .drawer-hamburger-icon:before {
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.drawer-open .drawer-hamburger-icon:after {
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}
.drawer-nav {
	opacity: 0;
	transform: scale(0.9);
	top: 70px;
	left: 0;
	right: 0;
	width: 100%;
	height: 90vh;
	transform-origin: center;
	transition: all 0.4s ease;
	position: fixed;
	z-index: 2;
	overflow: auto;
	margin: 0 auto;
	visibility: hidden;
}
.drawer-open .drawer-nav {
	opacity: 1;
	transform: scale(1);
	z-index: 20;
	visibility: visible;
}
.drawer-nav-wrap {
	background: #FFF;
	border-radius: 3px;
	margin: 0 10px;
	padding: 0 30px;
}
.drawer-menu {
	
}
.drawer-btn {
	text-align: center;
	padding: 25px 0;
}
.drawer-btn .btn {
	max-width: 210px;
	font-size: 15px;
	font-size: 1.5rem;
}
.drawer-menu a {
	display: block;
	width: 100%;
}
.drawer-menu > li .drawer-menu-item {
	padding: 20px 5px;
	font-size: 16px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.drawer-menu > li p.drawer-menu-item {
	color: #999999;
	line-height: 1.4;
}
.drawer-menu .drawer-submenu {
	border-top: 1px solid #222;
	border-bottom: 1px solid #222;
	padding: 20px 0;
}
.drawer-menu .drawer-submenu > li > a {
	font-size: 16px;
	color: #222;
	padding-left: 5px;
}
.drawer-menu .drawer-submenu > li + li {
	margin-top: 15px;
}
.drawer-menu .drawer-submenu > li > a:first-child {
	margin-top: 0;
}
.drawer-menu .drawer-submenu2 {
	padding-left: 20px;
}
.drawer-menu .drawer-submenu2 > li > a {
	font-size: 15px;
}
.drawer-menu .drawer-submenu2 > li {
	border-top: 1px solid #E2E2E2;
}
.drawer-menu > li + li {
	border-top: 1px solid #222222;
}
.drawer-menu > li > a,
.drawer-menu > li > a:hover span {
	color: #222;
}
.drawer-menu #drawer-submenu-outline {
	border-bottom: 1px solid #E2E2E2;
}
.drawer-menu .drawer-dropdown {
	display: flex;
	justify-content: space-between;
	align-items: center;
	position: relative;
}
.drawer-dropdown:after {
	content: "";
	width: 1px;
	height: calc(100% - 20px);
	background: #E2E2E2;
	position: absolute;
	right: 40px;
	top: 10px;
}
.drawer-dropdown .icon {
	font-size: 16px;
	padding: 0 5px;
}
.drawer-dropdown-menu {
	margin-left: 25px;
	display: none;
}
.drawer-dropdown-menu[hidden] {
	display: none;
}
.drawer-dropdown-menu:not([hidden]) {
	display: block;
}
.drawer-dropdown .drawer-menu-item {
	flex: 1;
}
.drawer-dropdown-menu > li {
	border-top: 1px solid #E2E2E2;
}
.drawer-dropdown-menu-item {
	position: relative;
	padding: 15px 0;
	padding-left: 18px;
	font-size: 15px;
}
.drawer-dropdown-menu-item:before {
	content: "";
	width: 8px;
	height: 2px;
	background: #074944;
	position: absolute;
	left: 0;
	top: 24px;
}
.drawer-dropdown-list {
	margin-left: 15px;
}
.drawer-dropdown-list-item {
	padding-bottom: 15px;
	padding-left: 18px;
	position: relative;
	font-size: 15px;
}
.drawer-dropdown-list-item:before {
	content: "";
	width: 8px;
	height: 1px;
	background: #074944;
	position: absolute;
	left: 0;
	top: 10px;
}
.hovermenu-overlay {
	position: fixed;
	z-index: 15;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0,0,0,.5);
	transition: opacity 0.3s ease-in-out, visibility 0.3s ease-in-out;
	visibility: hidden;
	display: block;
	opacity: 0;
}
.is-hovermenu .hovermenu-overlay,
.is-hovermenu2 .hovermenu-overlay {
	visibility: visible;
	opacity: 1;
}
.is-hovermenu2 .hovermenu-overlay {
	z-index: 32;
}
body.is-hovermenu,
body.is-hovermenu2 {
	overflow: hidden;
}
@media screen and (max-width: 767px) {
	.drawer {
		display: block;
		position: fixed;
		z-index: 500;
	}
}

/* -----------------------------------------------------------------
フッター
------------------------------------------------------------------ */
#footer {
	background-color: #EFE9E2;
	padding: 70px 0;
}
@media screen and (max-width: 767px) {
	#footer {
		padding: 60px 0;
	}
}

#footer .logobox {
	width: 100%;
}
#footer .logobox img {
	width: auto;
	height: 136px;
	margin: auto;
}
@media screen and (max-width: 767px) {
	#footer .logobox {
		margin-top: 40px;
	}
	#footer .logobox img {
		height: 90px;
	}
}

#footer .footer-box1 {
	position: relative;
}
#footer .linkbox {
	position: absolute;
	top: 0;
	right: 0;
}
#footer .linkbox p {
	font-size: 16px;
	font-size: 1.6rem;
	color: #5C5856;
}
#footer .linkbox ul {
	margin-top: 15px;
	color: #123C48;
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.5;
}
#footer .linkbox ul li + li {
	margin-top: 10px;
}
#footer .linkbox ul li .icon {
	font-size: inherit;
	transition: all .3s ease;
	margin: 0;
}
#footer .linkbox a {
	display: flex;
	align-items: center;
	gap: 10px;
}
#footer .linkbox a .c-link__icon {
	font-size: 18px;
	font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
	#footer .linkbox {
		position: static;
	}
	#footer .linkbox p {
		font-size: 15px;
		font-size: 1.5rem;
	}
	#footer .linkbox ul {
		font-size: 16px;
		font-size: 1.6rem;
	}
	#footer .linkbox a .c-link__icon {
		font-size: 16px;
		font-size: 1.6rem;
	}
}

#footer .footer-info {
	display: flex;
	justify-content: space-between;
	margin-top: 50px;
}
@media screen and (max-width: 767px) {
	#footer .footer-info {
		display: block;
		margin-top: 40px;
		text-align: center;
	}
}
#footer .footer-info ul {
	display: inline-flex;
}
#footer .footer-info ul li {
	display: inline-flex;
}
#footer .footer-info ul li + li {
	margin-left: 15px;
	padding-left: 15px;
	border-left: #D3CEC8 1px solid;
}
#footer .footer-info ul li a,
#footer .footer-info .footer-copyright {
	font-size: 12px;
	font-size: 1.2rem;
	line-height: 1.2;
}
/* #footer .footer-info ul li a:hover {
	text-decoration: underline;
} */
@media screen and (max-width: 767px) {
	#footer .footer-info .footer-copyright {
		margin-top: 20px;
	}
}

/* -----------------------------------------------------------------
調整
------------------------------------------------------------------ */
.mt0 {
	margin-top: 0 !important;
}
.mt10 {
	margin-top: 10px !important;
}
.mt20 {
	margin-top: 20px !important;
}
.mt30 {
	margin-top: 30px !important;
}
.mt40 {
	margin-top: 40px !important;
}
.mt50 {
	margin-top: 50px !important;
}
.mt3vw {
	margin-top: 3vw !important;
}
.pt0 {
	padding-top: 0 !important;
}
.pt20 {
	padding-top: 20px !important;
}

.text_center {
	text-align: center !important;
}
.text_right {
	text-align: right !important;
}

.fc_red {
	color: #F00 !important;
}

/* -----------------------------------------------------------------
パーツ
------------------------------------------------------------------ */

/* ========= メインエリア ========= */
.mod_mainarea {
	overflow: hidden;
	display: block;
	position: relative;
	padding-top: 80px;
}
@media screen and (max-width: 767px) {
	.mod_mainarea {
		padding-top: 60px;
	}
}

/* ========= ページトップボタン ========= */
.common-btn-top {
	display: none;
	position: fixed;
	bottom: 20px;
	right: 20px;
	z-index: 14;
	transition: bottom .4s ease;
}
.common-btn-top a {
	width: 48px;
	height: 48px;
	background: black no-repeat 14px 17px;
	color: #FFF !important;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 3px;
	opacity: 0.5;
}
.common-btn-top a:hover span {
	color: #FFF !important;
	opacity: 0.7;
}
.common-btn-top .icon {
	font-size: 30px;
	transform: rotate(90deg);
}

/*============== 動画用ソーシャルボタン =================*/
.sproutvideo-social-buttons > .social-buttons,
* + .social-buttons {
	margin-top: 0.8rem;
}
.social-buttons {
	display: none;
}
html.android .social-buttons,
html.ipod .social-buttons,
html.ipad .social-buttons,
html.iphone .social-buttons {
	display: block;
}
.social-buttons h4 {
	display: none;
	line-height: 1;
	margin-bottom: 1rem;
	margin-top: 0;
}
.share-group {
	list-style: none;
	margin: 0;
	padding: 0;
	overflow: hidden;
	display: flex;
	justify-content: flex-end;
	gap: 0.8rem;
}

.share-group li {
	float: left;
	margin-right: 0.8rem;
	margin: 0;
}

.share-group li button {
	border: none;
	background: none;
	cursor: pointer;
	text-align: left;
	margin: 0;
	padding: 0;
}
.share-group li button img {
	width: 3.2rem;
	height: 3.2rem;
}
.share-group li button span {
	display: none;
}

/* gsap */
.side-scroll__list-wrapper {
	position: relative;
	width: 100%;
	height: 500px;
	margin-top: 70px;
}
.side-scroll__list {
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	column-gap: 58px;
}
@media screen and (max-width: 767px) {
	.side-scroll__list-wrapper {
		margin-top: 50px;
	}
	.side-scroll__list {
		column-gap: 25px;
	}
	.mod_set2 {
		width: 78vw;
	}
}

/*============== モーダル =================*/
.mod_modal {
	display: none;
	position: fixed;
	top: 50%;
	transform: translateY(-50%);
	left: 0;
	right: 0;
	z-index: 35;
	max-width: 1118px;
	width: calc(100% - 50px);
	margin: 0 auto;
}
.mod_modal .modal-content {
		max-height: 80vh;
		overflow-y: auto;
	}
.mod_modal .close-btn {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: #074944;
	border: 1px solid #FFF;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background-color 0.3s ease, transform 0.3s ease;
	position: fixed;
	right: -16px;
	top: -16px;
	z-index: 40;
}
.mod_modal .close-x {
	position: relative;
	width: 13px;
	height: 13px;
}
.mod_modal .close-x:before, 
.mod_modal .close-x:after {
	content: "";
	position: absolute;
	width: 13px;
	height: 1px;
	background-color: #FFFFFF;
	top: 50%;
	left: 0;
	transform-origin: center;
}
.mod_modal .close-x:before {
	transform: translateY(-50%) rotate(45deg);
}
.mod_modal .close-x:after {
	transform: translateY(-50%) rotate(-45deg);
}
.mod_modal .mod_conarea2 .textbox {
	margin-top: 40px;
}
.mod_modal .mod_conarea2 .textbox .title {
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.4;
}
.mod_modal .mod_conarea2 .textbox .title + p {
	margin-top: 20px;
}
.mod_modal .mod_conarea2 .textbox p {
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.4;
}
@media screen and (max-width: 767px) {
	.mod_modal {
		text-align: left;
		width: calc(100% - 30px);
	}
	.mod_modal .mod_conarea2 {
		padding: 50px 30px;
	}
	.mod_modal .mod_conarea2 .textbox {
		margin-top: 30px;
	}
	.mod_modal .close-btn {
		right: -13px;
	}
	.mod_modal .mod_conarea2 .logo {
		height: auto;
	}
	.mod_modal .mod_conarea2 .textbox .title {
		font-size: 16px;
		font-size: 1.6rem;
	}
	.mod_modal .mod_conarea2 .textbox p {
		font-size: 15px;
		font-size: 1.5rem;
	}
}

/* ==========================================================================//
//
// [基本設定]
//
// ========================================================================== */

/* ==========================================================================//
//
// [デフォルトスタイル]
//
// ========================================================================== */
:lang(en) {
	font-family: "Frank Ruhl Libre", serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	line-height: 1;
}

/* ==========================================================================//
//
// [レイアウト]
//
// ========================================================================== */

.l-section {
	margin-top: -100px !important;
	padding-top: 100px !important;
}
.l-section#information {
	margin-top: 0;
	padding-top: 0;
}
@media screen and (max-width: 767px) {
	.l-section {
		margin-top: -80px !important;
		padding-top: 80px !important;
	}
}

.l-section__inner {
	position: relative;
}

/* --------------------------------------------------------------------------//
// セクション背景
// -------------------------------------------------------------------------- */
.l-section__bg {
	background-position: top center;
	background-repeat: no-repeat;
	background-size: calc(100% * 1600 / 1366);
}
@media screen and (max-width: 767px) {
	.l-section__bg {
		background-size: calc(100% * 768 / 406);
	}
}

/* メインビジュアル ~ 導入
----------------------------------------------------------------------------- */
.l-section-01 .l-section__bg-01 {
	background-image: url(/igc-harmonics-2026/r1/img/bg_main.webp);
	padding-bottom: 30px;
}
@media screen and (max-width: 767px) {
	.l-section-01 .l-section__bg-01 {
		padding-bottom: 13px;
	}
}

/* 特長
----------------------------------------------------------------------------- */
.l-section-01 .l-section__bg-02 {
	background-image: url(/igc-harmonics-2026/r1/img/bg_circle_white_r.svg), linear-gradient(#EFE9E2,#FFFFFF);
	padding-top: 195px;
	padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
	.l-section-01 .l-section__bg-02 {
		padding-top: 127px;
		padding-bottom: 80px;
	}
}

/* カンファレンス概要
----------------------------------------------------------------------------- */
.l-section-02 .l-section__bg-01 {
	padding-bottom: 100px;
}
@media screen and (max-width: 767px) {
	.l-section-02 .l-section__bg-01 {
		padding-bottom: 80px;
	}
}

/* グローバル登壇者情報
----------------------------------------------------------------------------- */
.l-section-03 .l-section__bg-01 {
	background-color: #EDF2F7;
	background-image: url(/igc-harmonics-2026/r1/img/bg_circle_white.svg);
}
@media screen and (max-width: 767px) {
	.l-section-03 .l-section__bg-01 {
		padding-bottom: 80px;
	}
}

/* 開催概要 ~ お問い合わせ
----------------------------------------------------------------------------- */
.l-section-04 .l-section__bg-01 {
	background-image: url(/igc-harmonics-2026/r1/img/bg_circle_blue.svg);
	background-position: top -9px center;	
	padding-top: 100px;
}
@media screen and (max-width: 767px) {
	.l-section-04 .l-section__bg-01 {
		padding-top: 0;
	}
}

/* ソーシャル
----------------------------------------------------------------------------- */
.l-section-05 .l-section__bg-01 {
	padding: 30px 0;
}
@media screen and (max-width: 767px) {
	.l-section-05 .l-section__bg-01 {
		padding: 20px 0;
	}
}

/* --------------------------------------------------------------------------//
// セクションアイテム
// -------------------------------------------------------------------------- */
*+.l-section__item {
	margin-top: 60px;
}
.p-mv+.l-section__item {
	margin-top: 0;
}
@media screen and (max-width: 767px) {
	*+.l-section__item {
		margin-top: 60px;
	}
	.p-mv+.l-section__item {
		margin-top: 70px;
	}
}

/* ==========================================================================//
//
// [コンポーネント]
//
// ========================================================================== */

/* --------------------------------------------------------------------------//
// 見出し
// -------------------------------------------------------------------------- */
/* 大見出し
----------------------------------------------------------------------------- */
.p-heading-01 .p-heading__text,
.p-heading-01 .p-heading__text__sub {
	display: block;
}
.p-heading-01 .p-heading__text {
	font-size: 50px;
	font-size: 5rem;
}
.p-heading-01 .p-heading__text__sub {
	color: #123C48;
	font-size: 26px;
	font-size: 2.6rem;
	font-weight: bold;
	line-height: 1.5;
}
.p-heading-01 *+.p-heading__text__sub {
	margin-top: 10px;
}
@media screen and (max-width: 767px) {
	.p-heading-01 .p-heading__text {
		font-size: 46px;
		font-size: 4.6rem;
	}
	.p-heading-01 .p-heading__text__sub {
		font-size: 22px;
		font-size: 2.2rem;
	}
}

/* 中見出し
----------------------------------------------------------------------------- */
.c-heading-02 {
	color: #123C48;
	font-size: 22px;
	font-size: 2.2rem;
}
/* --------------------------------------------------------------------------//
// リスト
// -------------------------------------------------------------------------- */
.c-list-01 .c-list__item {
	position: relative;
	padding-left: 19px;
}
.c-list-01 .c-list__item+.c-list__item {
	margin-top: 10px;
}
.c-list-01 .c-list__item:before {
	content: "";
	width: 9px;
	height: 9px;
	background-color: #00857C;
	border-radius: 50%;
	position: absolute;
	left: 0;
	top: 7px;
}
.c-list-01 .c-list__text {
	font-size: 15px;
	font-size: 1.5rem;
	line-height: 1.5;
}
@media screen and (max-width: 767px) {
	.c-list-01 .c-list__item:before {
		width: 8px;
		height: 8px;
	}
	.c-list-01 .c-list__text {
		font-size: 14px;
		font-size: 1.4rem;
	}
}

/* --------------------------------------------------------------------------//
// インデント
// -------------------------------------------------------------------------- */
.c-indent-01 {
	padding-left: 30px;
	border-left: 1px solid #00857C;
}
@media screen and (max-width: 767px) {
	.c-indent-01 {
		padding-left: 15px;
	}
}

/* --------------------------------------------------------------------------//
// テーブル
// -------------------------------------------------------------------------- */
.c-table-01 {
	width: 100%;
	table-layout: fixed;
}
.c-table-01 .c-table__text {
	font-weight: normal;
	line-height: 1.5;
	text-align: left;
}
.c-table-01 tr {
	display: flex;
	justify-content: space-between;
	gap: 0;
	padding: 20px 0;
	border-top: 1px solid #E2E2E2;
	border-bottom: 1px solid #E2E2E2;
}
.c-table-01 tr+tr {
	border-top: none;
}
.c-table-01 th {
	width: 80px;
}
.c-table-01 td {
	flex: 1;
}
@media screen and (max-width: 767px) {
	.c-table-01 .c-table__text {
		font-size: 16px;
		font-size: 1.6rem;
	}
	.c-table-01 tr {
		padding: 20px 0;
	}
	.c-table-01 th {
		width: 52px;
	}
}

.c-table-02 {
	width: 100%;
	table-layout: fixed;
}
.c-table-02 .c-table__text {
	font-weight: normal;
	line-height: 1.5;
	text-align: left;
}
.c-table-02 .c-table__text .c-table-text__note {
	font-size: 12px;
	font-size: 1.2rem;
}
.c-table-02 .c-table__text.c-table__text--emphasis {
	font-size: 24px;
	font-size: 2.4rem;
	font-weight: bold;
}
.c-table-02 .c-table__text.c-table__text--emphasis .c-table-text__note {
	font-size: 16px;
	font-size: 1.6rem;
}
.c-table-02 tr {
	display: flex;
	justify-content: space-between;
	gap: 0;
}
.c-table-02 tr+tr {
	padding-top: 10px;
}
.c-table-02 th {
	width: 208px;
}
.c-table-02 td {
	flex: 1;
}
@media screen and (max-width: 767px) {
	.c-table-02 .c-table__text {
		font-size: 15px;
		font-size: 1.5rem;
	}
	.c-table-02 .c-table__text .c-table_text__supplement {
		font-size: 10px;
		font-size: 1rem;
	}
	.c-table-02 .c-table__text.c-table__text--emphasis {
		font-size: 18px;
		font-size: 1.8rem;
	}
	.c-table-02 .c-table__text.c-table__text--emphasis .c-table_text__supplement {
		font-size: 12px;
		font-size: 1.2rem;
	}
	.c-table-02 tr+tr {
		padding-top: 15px;
	}
	.c-table-02 th {
		width: 168px;
	}
}

/* --------------------------------------------------------------------------//
// ボタン
// -------------------------------------------------------------------------- */
.c-button {
	color: #FFFFFF;
	font-size: 20px;
	font-size: 2rem;
	font-weight: bold;
	text-align: center;
	display: block;
	width: 100%;
	max-width: 586px;
	background-color: #00AA9E;
	border-radius: 40px;
	transition: background-color .3s ease;
	margin: 0 auto;
	padding: 25px;
}
.c-button.c-button--small {
	font-size: 15px;
	font-size: 1.5rem;
	max-width: 230px;
	padding: 16px;
}
@media screen and (max-width: 767px) {
	.c-button {
		font-size: 15px;
		font-size: 1.5rem;
		max-width: 335px;
		padding: 16px;
	}
	.c-button.c-button--small {
		max-width: 210px;
	}
}
a:hover .c-button,
a.c-button:hover {
	background-color: #28CEC2;
}

/* --------------------------------------------------------------------------//
// タグ
// -------------------------------------------------------------------------- */
.c-tag {
	display: flex;
	align-items: center;
	gap: 10px;
	flex-flow: row nowrap;
}
.c-tag__item {
	color: #222;
	font-size: 16px;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.5;
	background: #C9A655;
	background: linear-gradient(90deg,rgba(201, 166, 85, 1) 0%, rgba(255, 232, 178, 1) 50%, rgba(201, 166, 85, 1) 100%);
	border-radius: 3px;
	padding: 8px 12px;
}
@media screen and (max-width: 767px) {
	.c-tag__item {
		font-size: 15px;
		font-size: 1.5rem;
	}
}

/* --------------------------------------------------------------------------//
// 画像
// -------------------------------------------------------------------------- */
.c-image {
	border-radius: 5px;
	overflow: hidden;
}

/* --------------------------------------------------------------------------//
// 動画
// -------------------------------------------------------------------------- */
.c-movie {
	position: relative;
	display: block;
	max-width: 792px;
	border-radius: 5px;
	overflow: hidden;
	margin: 0 auto;
}

/* --------------------------------------------------------------------------//
// ソーシャル
// -------------------------------------------------------------------------- */
.c-social__list {
	display: flex;
	align-items: center;
	gap: 5px;
}
.c-social__item {
	line-height: 1;
}
.c-social__item > * {
	vertical-align: top;
}

/* --------------------------------------------------------------------------//
// リンク
// -------------------------------------------------------------------------- */
a[class*="c-link-0"] > .c-link__text,
a [class*="c-link-0"] > .c-link__text,
a[class*="c-link-0"] > .c-link__icon
a [class*="c-link-0"] > .c-link__icon {
	transition: color .3s ease;
}
a[class*="c-link-0"] > .c-link__icon-wrap,
a [class*="c-link-0"] > .c-link__icon-wrap {
	transition: background-color .3s ease;
}
a[class*="c-link-0"] > .c-link__text,
a [class*="c-link-0"] > .c-link__text {
	position: relative;
	text-decoration: none;
}
a[class*="c-link-0"] > .c-link__text:after,
a [class*="c-link-0"] > .c-link__text:after {
	content: "";
	height: 1px;
	background: currentColor;
	position: absolute;
	bottom: -3px;
	left: 0;
	right: 0;
	transition: width .3s ease;
	width: 0;
	pointer-events: none;
}
a.c-link-02 > .c-link__text:after,
a .c-link-02 > .c-link__text:after {
	left: auto;
	width: 100%;
}
a[class^="c-link-"]:hover > .c-link__text,
a:hover [class*="c-link-0"] > .c-link__text,
a[class^="c-link-"]:hover > .c-link__icon,
a:hover [class*="c-link-0"] > .c-link__icon {
	color: #00857C;
}
a[class^="c-link-"]:hover > .c-link__icon-wrap,
a:hover [class*="c-link-0"] > .c-link__icon-wrap {
	background-color: #00857C;
}
a.c-link-01:hover > .c-link__text:after,
a:hover .c-link-01 > .c-link__text:after {
	width: 100%;
}
a.c-link-02:hover > .c-link__text:after,
a:hover .c-link-02 > .c-link__text:after {
	width: 0;
}

/* ==========================================================================//
//
// [ユーティリティ]
//
// ========================================================================== */

/* -----------------------------------------------------------------
非表示
------------------------------------------------------------------ */
.u-visually-hidden {
	position: absolute !important;
	width: 1px !important;
	height: 1px !important;
	margin: -1px !important;
	padding: 0 !important;
	overflow: hidden !important;
	clip: rect(0 0 0 0) !important;
	white-space: nowrap !important;
	border: 0 !important;
}

/* -----------------------------------------------------------------
表示
------------------------------------------------------------------ */
.u-db {
	display: block !important;
}
.u-dn {
	display: none !important;
}
@media screen and (max-width: 767px) {
	.u-db-md--down {
		display: block !important;
	}
	.u-dn-md--down {
		display: none !important;
	}
}
@media screen and (max-width: 1282px) {
	.u-db-lg--down {
		display: block !important;
	}
	.u-dn-lg--down {
		display: none !important;
	}
}
@media screen and (min-width: 768px) {
	.u-db-md {
		display: block !important;
	}
	.u-dn-md {
		display: none !important;
	}
}
@media screen and (min-width: 1283px) {
	.u-db-lg {
		display: block !important;
	}
	.u-dn-lg {
		display: none !important;
	}
}

/* ==========================================================================//
//
// [アニメーション]
//
// ========================================================================== */

/* -----------------------------------------------------------------
inview
------------------------------------------------------------------ */
.animate-inview {
	opacity: 0;
	transition: opacity var(--animate-inview-duration, 1s) ease, transform var(--animate-inview-duration, 1s) ease;
	transform: translateY(var(--animate-inview-offset, 50px));
	transition-delay: var(--animate-inview-delay, 0);
}
.animate-inview.is-animated {
	transform: translateY(0);
	opacity: 1;
}

/* -----------------------------------------------------------------
文字
------------------------------------------------------------------ */
.animate-char.is-animated {
	--animate-char-x: 0;
}
.animate-char .char-wrap {
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
.animate-char .char {
	overflow: hidden;
}
.animate-char .char-text {
	display: inline-block;
	transform: translateX(var(--animate-char-x, -101%));
	transition: transform var(--animate-char-duration, .3s) cubic-bezier(.77, 0, .175, 1);
	transition-delay: calc(var(--animate-char-delay-offset, 0s) + var(--animate-char-delay-delta, .03s) * var(--animate-char-index, 1));
}

/* -----------------------------------------------------------------
ボックス
------------------------------------------------------------------ */
.animate-box .animate-box-item {
	opacity: 0;
	transition: opacity var(--animate-box-duration, .3s) ease, transform calc(2 * var(--animate-box-duration, .3s)) ease;
	transform: translateY(var(--animate-box-offset, 30px));
}
.animate-box .animate-box-item {
	transition-delay: calc(var(--animate-box-delay-offset, 0s) + var(--animate-box-delay-delta, .15s) * var(--animate-box-index, 1));
}
.animate-box.is-animated .animate-box-item {
	transform: translateY(0);
	opacity: 1;
}
.animate-box-x .animate-box-item {
	opacity: 0;
	transition: opacity var(--animate-box-duration, .3s) ease, transform calc(2 * var(--animate-box-duration, .3s)) ease;
	transform: translateX(var(--animate-box-offset, -50px));
}
.animate-box-x .animate-box-item {
	transition-delay: calc(var(--animate-box-delay-offset, 0s) + var(--animate-box-delay-delta, .15s) * var(--animate-box-index, 1));
}
.animate-box-x.is-animated .animate-box-item {
	transform: translateX(0);
	opacity: 1;
}

/* -----------------------------------------------------------------
フェードイン
------------------------------------------------------------------ */
.animate-fade .animate-fade-item {
	opacity: 0;
	transition: opacity var(--animate-fade-duration, .3s) ease;
}
.animate-fade .animate-fade-item {
	transition-delay: calc(var(--animate-fade-delay-offset, 0s) + var(--animate-fade-delay-delta, .15s) * var(--animate-fade-index, 1));
}
.animate-fade.is-animated .animate-fade-item {
	opacity: 1;
}

/* ==========================================================================//
//
// [プロジェクト]
//
// ========================================================================== */

/* --------------------------------------------------------------------------//
// メインビジュアル
// -------------------------------------------------------------------------- */
.p-mv {
	height: 630px;
}
@media screen and (max-width: 767px) {
	.p-mv {
		height: auto;
	}
}
@media screen and (min-width: 1537px) {
	.p-mv .container {
		max-width: 1380px;
	}
}
.p-mv__inner {
	padding-top: 236px;
}
@media screen and (max-width: 767px) {
	.p-mv__inner {
		padding-top: 138px;
	}
}
.p-mv__contents {
	position: relative;
}
.p-mv-heading__text,
.p-mv-heading__image {
	display: block;
}
.p-mv-heading__text {
	color: #123C48;
	font-size: 32px;
	font-size: 3.2rem;
	font-weight: bold;
	line-height: 1.5;
}
*+.p-mv-heading__image {
	margin-top: 30px;
}
.p-mv-heading-image__image {
	width: auto;
	height: 60px;
}
@media screen and (max-width: 767px) {
	.p-mv-heading__text {
		font-size: 20px;
		font-size: 2rem;
	}
	*+.p-mv-heading__image {
		margin-top: 20px;
	}
	.p-mv-heading-image__image {
		width: 100%;
		max-width: 375px;
		height: auto;
	}
}
*+.p-mv__information {
	margin-top: 50px;
}
.p-mv-information__row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-flow: row-reverse nowrap;
	gap: 20px;
}
.p-mv-information__head {
	flex: 1;
}
.p-mv-information__date,
.p-mv-information__place {
	color: #123C47;
	font-weight: bold;
	line-height: 1;
}
.p-mv-information__date {
	font-size: 22px;
	font-size: 2.2rem;
}
.p-mv-information__date span {
	font-size: 34px;
	font-size: 3.4rem;
}
.p-mv-information__place {
	font-size: 18px;
	font-size: 1.8rem;
}
*+.p-mv-information__place {
	margin-top: 10px;
}
.p-mv-information__body {
	width: 230px;
}
@media screen and (min-width: 768px) {
	.p-mv-information__button.c-button {
		padding-top: 20px;
		padding-bottom: 20px;
	}
}
@media screen and (max-width: 767px) {
	*+.p-mv__information {
		margin-top: 20px;
	}
	.p-mv-information__row {
		flex-flow: column wrap;
		align-items: flex-start;
	}
	.p-mv-information__body {
		width: 100%;
	}
	.p-mv-information__date {
		font-size: 20px;
		font-size: 2rem;
	}
	.p-mv-information__date span {
		font-size: 30px;
		font-size: 3rem;
	}
	.p-mv-information__place {
		font-size: 16px;
		font-size: 1.6rem;
	}
	.p-mv-information__body {
		width: 100%;
	}
	.p-mv-information__button {
		margin-left: 0;
	}
}
.p-mv__logo {
	position: absolute;
	top: 0;
	right: 0;
}
.p-mv-logo__image {
	width: 238px;
}
@media screen and (max-width: 767px) {
	.p-mv__logo {
		position: absolute;
		top: -8px;
		right: 0;
	}
	.p-mv-logo__image {
		width: auto;
		height: 96px;
	}
}
.p-mv__social-list {
	position: absolute;
	right: 0;
	bottom: 0;
}
@media screen and (max-width: 767px) {
	.p-mv__social-list {
		position: relative;
	}
	*+.p-mv__social-list {
		margin-top: 50px;
	}
}

/* --------------------------------------------------------------------------//
// 導入
// -------------------------------------------------------------------------- */
.p-introduction__row {
	display: flex;
	align-items: center;
	flex-flow: row-reverse nowrap;
	gap: 40px 50px;
}
.p-introduction__images {
	width: 374px;
	display: flex;
	justify-content: flex-end;
	position: relative;
}
.p-introduction__main {
	flex: 1;
}
@media screen and (max-width: 767px) {
	.p-introduction__row {
		flex-flow: column wrap;
	}
	.p-introduction__images {
		width: 100%;
		justify-content: space-between;
		gap: 25px;
	}
}
.p-introduction__image {
	width: 322px;
	border-radius: 5px;
	overflow: hidden;
}
.p-introduction__image-01 {
	position: absolute;
	left: -322px;
	top: 150px;
}
.p-introduction__heading {
	color: #123C48;
	font-size: 30px;
	font-size: 3rem;
}
*+.p-introduction__text {
	margin-top: 30px;
}
.p-introduction__text+.p-introduction__text {
	margin-top: 15px;
}
@media screen and (max-width: 767px) {
	.p-introduction__image {
		width: 100%;
	}
	.p-introduction__image-01 {
		position: static;
		margin-top: 82px;
	}
	.p-introduction__heading {
		font-size: 24px;
		font-size: 2.4rem;
	}
	.p-introduction__text {
		font-size: 16px;
		font-size: 1.6rem;
	}
	*+.p-introduction__text {
		margin-top: 25px;
	}
	.p-introduction__text+.p-introduction__text {
		margin-top: 10px;
	}
}

/* --------------------------------------------------------------------------//
// 特長
// -------------------------------------------------------------------------- */
.p-feature {
	position: relative;
}
*+.p-feature__row {
	margin-top: 40px;
}
.p-feature__list {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px 50px;
}
@media screen and (max-width: 767px) {
	.p-feature__list {
		grid-template-columns: 1fr;
	}
}
.p-feature__item:nth-child(2) {
	margin-top: 80px;
}
.p-feature__item:nth-child(3) {
	margin-top: 160px;
}
@media screen and (max-width: 767px) {
	.p-feature__item {
		margin-top: 0 !important;
	}
}
.p-feature-heading__text,
.p-feature-heading__text__sub {
	display: block;
}
.p-feature-heading__text {
	font-size: 48px;
	font-size: 4.8rem;
}
.p-feature-heading__text__sub {
	color: #123C48;
	font-size: 22px;
	font-size: 2.2rem;
	font-weight: bold;
	line-height: 1.5;
}
*+.p-feature-heading__text__sub {
	margin-top: 15px;
}
@media screen and (max-width: 767px) {
	.p-feature .text {
		font-size: 16px;
		font-size: 1.6rem;
	}
	*+.p-feature-heading__text__sub {
		margin-top: 10px;
	}
}
.p-feature .text {
	font-size: 18px;
	font-size: 1.8rem;
}
*+.p-feature__text {
	margin-top: 20px;
}
@media screen and (max-width: 767px) {
	.p-feature .text {
		font-size: 16px;
		font-size: 1.6rem;
	}
	*+.p-feature__text {
		margin-top: 15px;
	}
}
@media screen and (max-width: 767px) {
	.p-feature__item {
		margin-top: 0 !important;
	}
	.p-feature-heading__text {
		font-size: 40px;
		font-size: 4rem;
	}
	.p-feature-heading__text__sub {
		font-size: 19px;
		font-size: 1.9rem;
	}
	.p-feature__text {
		font-size: 16px;
		font-size: 1.6rem;
	}
}
.p-feature__box {
	width: 100%;
	max-width: 898px;
	border: 1px solid #CEBEAA;
	border-radius: 5px;
	padding: 30px 40px;
	margin: 0 auto;
}
@media screen and (max-width: 767px) {
	.p-feature__box {
		padding: 25px 30px;
	}
	.p-feature_box__text {
		font-size: 16px;
		font-size: 1.6rem;
	}
}
.p-feature__decorations {
	position: absolute;
	top: -165px;
	right: 50px;
}
.p-feature-decoration__image {
	border-radius: 5px;
	overflow: hidden;
}
.p-feature__decoration-01 .p-feature-decoration__image {
	width: 368px;
}
.p-feature__decoration-02 {
	position: absolute;
	top: -68px;
	right: -178px;
}
.p-feature__decoration-02 .p-feature-decoration__image {
	width: 228px;
}
.p-feature__decoration-03 {
	position: absolute;
	top: 0;
	right: 0;
}
.p-feature-decoration__line:before {
	content: '';
	width: 330px;
	height: 600px;
	background-image: url(/igc-harmonics-2026/r1/img/bg_line_2.webp);
	background-position: center right;
	background-size: cover;
	background-repeat: no-repeat;
	position: absolute;
	top: 24px;
	right: -293px;
	z-index: 1;
}
@media screen and (max-width: 767px) {
	*+.p-feature__decorations {
		margin-top: 40px;
	}
	.p-feature__decorations {
		position: relative;
		top: 0;
		right: 0;
		padding-top: calc((100vw - 30px) * 47 / 375);
	}
	.p-feature__decoration-01 .p-feature-decoration__image {
		width: calc((100vw - 30px) * 253 / 375);
	}
	.p-feature__decoration-02 {
		top: 0;
		right: 0;
	}
	.p-feature__decoration-02 .p-feature-decoration__image {
		width: calc((100vw - 30px) * 157 / 375);
	}
	.p-feature-decoration__line:before {
		width: 220px;
		height: 400px;
		top: calc((100vw - 30px) * 111 / 375);
		right: calc((100vw - 30px) * 73 / 375 * -1);
	}
}

/* --------------------------------------------------------------------------//
// 日程
// -------------------------------------------------------------------------- */
.p-schedule {
	--p-schedule__color: #00857C;
	--p-schedule__background-color: #E9F5F3;
	--p-schedule__border-color: #D2E5E3;
}
.p-schedule__contents {
	position: absolute;
	right: 0;
	top: 0;
}
@media screen and (max-width: 767px) {
	*+.p-schedule {
		margin-top: 50px;
	}
	.p-schedule__contents {
		position: relative;
		right: 0;
	}
}
.p-schedule__list {
	display: flex;
	gap: 30px;
	flex-flow: column nowrap;
	align-items: flex-end;
}
@media screen and (max-width: 767px) {
	.p-schedule__list {
		position: relative;
	}
}
.p-schedule__item {
	width: 100%;
	max-width: 510px;
}
@media screen and (max-width: 767px) {
	.p-schedule__item {
		max-width: none;
	}
}
.p-schedule__item-02 {
	--p-schedule__color: #7D6BAD;
	--p-schedule__background-color: #EFECF8;
	--p-schedule__border-color: #E0DBED;
	position: relative;
	right: 182px;
}
@media screen and (max-width: 767px) {
	.p-schedule__item-02 {
		right: 0;
	}
}
.p-schedule-heading__box {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	flex-flow: row nowrap;
	background-color: var(--p-schedule__background-color);
	border: 1px solid var(--p-schedule__border-color);
	border-radius: 5px;
	padding: 25px 30px;
}
@media screen and (max-width: 767px) {
	.p-schedule-heading__box {
		align-items: flex-start;
		flex-flow: column wrap;
		gap: 20px;
	}
}
.p-schedule-heading__datetime {
	width: 111px;
}
.p-schedule-heading__contents {
	flex: 1;
	width: 100%;
	display: flex;
	align-items: center;
	border-color: var(--p-schedule__border-color);
	border-style: solid;
	border-left-width: 1px;
	padding-left: 30px;
}
@media screen and (max-width: 767px) {
	.p-schedule-heading__contents {
		border-left-width: 0;
		border-top-width: 1px;
		padding-left: 0;
		padding-top: 20px;
	}
}
.p-schedule-heading__date,
.p-schedule-heading__time {
	display: block;
}
.p-schedule-heading__date {
	color: #123C48;
	font-size: 42px;
	font-size: 4.2rem;
}
.p-schedule-heading__time {
	color: var(--p-schedule__color);
	font-size: 20px;
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.5;
}
.p-schedule-heading__time span {
	font-size: 16px;
	font-size: 1.6rem;
}
*+.p-schedule-heading__time {
	margin-top: 5px;
}
.p-schedule-heading__text {
	color: #123C48;
	font-size: 20px;
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.5;
}

/* --------------------------------------------------------------------------//
// カンファレンス概要
// -------------------------------------------------------------------------- */
*+.p-overview {
	margin-top: 270px;
}
@media screen and (max-width: 767px) {
	*+.p-overview {
		margin-top: 50px;
	}
}
.p-overview {
	position: relative;
}
.p-overview__list {
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	gap: 10px;
}
.p-overview__item {
	grid-column: span 2;
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 1;
	gap: 0;
	z-index: 1;
}
.p-overview__box {
	width: 100%;
	height: 100%;
	background-color: #EDF2F7;
	border-radius: 5px;
	overflow: hidden;
}
.p-overview__image {
	overflow: hidden;
}
a .p-overview__image {
	transition: transform .3s ease;
}
a:hover .p-overview__image {
	transform: scale(1.05);
}
.p-overview__main {
	padding: 0 40px 30px;
}
.p-overview-heading__text,
.p-overview-heading__text__sub {
	display: block;
}
.p-overview-heading__text {
	font-size: 32px;
	font-size: 3.2rem;
}
.p-overview-heading__text__sub {
	color: #123C48;
	font-size: 20px;
	font-size: 2rem;
	font-weight: bold;
	line-height: 1.5;
	display: flex;
	align-items: center;
	gap: 10px;
}
*+.p-overview-heading__text__sub {
	margin-top: 10px;
}
.p-overview__heading .c-link__icon-wrap {
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #123C48;
	width: 22px;
	height: 22px;
	border-radius: 50%;
}
.p-overview__heading .c-link__icon {
	color: #FFFFFF;
	font-size: 16px;
	font-size: 1.6rem;
}
.p-overview__text {
	font-size: 18px;
	font-size: 1.8rem;
	line-height: 1.5;
}
*+.p-overview__text {
	margin-top: 15px;
}
.p-overview__text.p-overview__text--note {
	font-size: 14px;
	font-size: 1.4rem;
	text-align: right;
}
*+.p-overview__text.p-overview__text.p-overview__text--note {
	margin-top: 10px;
}
@media screen and (min-width: 768px) {
	.p-overview__item:nth-child(-n+2) {
		grid-column: span 3;
	}
	.p-overview__item:nth-child(-n+2) .p-overview-heading__text {
		font-size: 40px;
		font-size: 4rem;
	}
	.p-overview__item:nth-child(-n+2) .p-overview-heading__text__sub {
		font-size: 22px;
		font-size: 2.2rem;
	}
	.p-overview__item:nth-child(-n+2) .p-overview__heading .c-link__icon-wrap {
		width: 24px;
		height: 24px;
	}
	.p-overview__item:nth-child(-n+2) .p-overview__heading .c-link__icon {
		font-size: 16px;
		font-size: 1.6rem;
	}
}
@media screen and (max-width: 767px) {
	.p-overview__list {
		grid-template-columns: 1fr;
		gap: 20px;
	}
	.p-overview__main {
		padding: 0 20px 30px;
	}
	.p-overview-heading__text {
		font-size: 28px;
		font-size: 2.8rem;
	}
	.p-overview-heading__text__sub {
		font-size: 18px;
		font-size: 1.8rem;
	}
	.p-overview__heading .c-link__icon-wrap {
		width: 20px;
		height: 20px;
	}
	.p-overview__heading .c-link__icon {
		font-size: 14px;
		font-size: 1.4rem;
	}
	.p-overview__text {
		font-size: 16px;
		font-size: 1.6rem;
	}
	.p-overview__text.p-overview__text--note {
		font-size: 12px;
		font-size: 1.2rem;
	}
}
.p-overview__decorations {
	position: absolute;
	top: 0;
	left: 0;
}
.p-overview__decoration-01:before {
	content: '';
	width: 524px;
	height: 618px;
	background-image: url(/igc-harmonics-2026/r1/img/bg_line.webp);
	background-position: center right;
	background-size: cover;
	background-repeat: no-repeat;
	position: absolute;
	top: -245px;
	left: -368px;
}
@media screen and (max-width: 767px) {
	.p-overview__decoration-01 {
		display: none;
	}
}

/* --------------------------------------------------------------------------//
// グローバル登壇者情報
// -------------------------------------------------------------------------- */
*+.p-speaker {
	margin-top: 80px;
}
@media screen and (max-width: 767px) {
	*+.p-speaker {
		margin-top: 60px;
	}
}
.p-speaker__list {
	display: flex;
	flex-flow: column nowrap;
	align-items: flex-end;
	gap: 50px;
}
@media screen and (max-width: 767px) {
	.p-speaker__list {
		gap: 40px;
	}
}
.p-speaker__item {
	max-width: 1060px;
	padding-top: 25px;
}
@media screen and (max-width: 767px) {
	.p-speaker__item {
		padding-top: 19px;
	}
}
.p-speaker__box {
	color: #FFFFFF;
	background-color: #123C48;
	border-radius: 5px;
	padding: 40px 50px 50px;
	position: relative;
}
@media screen and (max-width: 767px) {
	.p-speaker__box {
		padding: 35px 20px 40px;
	}
}
.p-speaker__tag {
	position: absolute;
	top: -20px;
}
@media screen and (max-width: 767px) {
	.p-speaker__tag {
		top: -19px;
		left: 50%;
		transform: translateX(-50%);
	}
}
.p-speaker__head {
	border-bottom: 1px solid #657C83;
}
.p-speaker-head__row {
	display: flex;
	justify-content: space-between;
	width: 100%;
	gap: 30px;
	flex-flow: row nowrap;
}
.p-speaker-head__col {
	position: relative;
}
@media screen and (max-width: 767px) {
	.p-speaker-head__row {
		flex-flow: column wrap;
	}
}
.p-speaker__name {
	font-size: 30px;
	font-size: 3rem;
	line-height: 1.5;
	font-weight: bold;
}
*+.p-speaker__company {
	margin-top: 10px;
}
.p-speaker__company {
	font-size: 22px;
	font-size: 2.2rem;
	line-height: 1.5;
	font-weight: bold;
}
*+.p-speaker__position {
	margin-top: 0;
}
.p-speaker__position {
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.5;
}
.p-speaker__logo {
	position: absolute;
	left: 0;
	bottom: 30px;
}
.p-speaker-logo__image {
	width: auto;
	height: 48px;
}
.p-speaker__item-01 .p-speaker-logo__image {
	height: 40px;
}
@media screen and (max-width: 767px) {
	.p-speaker__name {
		font-size: 24px;
		font-size: 2.4rem;
		text-align: center;
	}
	.p-speaker__company {
		font-size: 19px;
		font-size: 1.9rem;
		text-align: center;
	}
	.p-speaker__position {
		font-size: 15px;
		font-size: 1.5rem;
		text-align: center;
	}
	.p-speaker__logo {
		position: static;
	}
	*+.p-speaker__logo {
		margin-top: 20px;
	}
	.p-speaker-logo__image {
		height: 38px;
		margin: 0 auto;
	}
	.p-speaker__item-01 .p-speaker-logo__image {
		height: 32px;
	}
}
.p-speaker-head__image {
	display: flex;
	justify-content: flex-end;
}
.p-speaker__image {
	margin-top: -75px;
	margin-right: 50px;
}
.p-speaker-image__image {
	width: auto;
	height: 300px;
}
.p-speaker__social {
	position: absolute;
	right: 0;
	bottom: 30px;
}
.p-speaker-social__list {
	display: flex;
	align-items: center;
	gap: 20px;
	flex-flow: row nowrap;
}
.p-speaker-socail__image {
	width: auto;
	height: 36px;
}
.p-speaker-social__link .p-speaker-socail__image {
	transition: opacity .3s ease;
}
.p-speaker-social__link:hover .p-speaker-socail__image {
	opacity: .7;
}
@media screen and (max-width: 767px) {
	.p-speaker-head__image {
		justify-content: center;
	}
	.p-speaker__image {
		margin: 0;
	}
	.p-speaker-image__image {
		width: auto;
		height: 200px;
	}
	.p-speaker__social {
		bottom: 20px;
	}
	.p-speaker-socail__image {
		height: 30px;
	}
}
*+.p-speaker__body {
	margin-top: 30px;
}
@media screen and (max-width: 767px) {
	*+.p-speaker__body {
		margin-top: 20px;
	}
}
.p-speaker__text {
	font-size: 18px;
	font-size: 1.8rem;
}
@media screen and (max-width: 767px) {
	.p-speaker__text {
		font-size: 18px;
		font-size: 16px;
		font-size: 1.6rem;
	}
}
*+.p-speaker__comment {
	margin-top: 40px;
}
.p-speaker__comment {
	background-color: #24515D;
	border-radius: 3px;
	padding: 38px 40px 30px;
	position: relative;
}
.p-speaker__comment:before {
	content: '';
	position: absolute;
	top: -10px;
	left: 40px;
	mask-image: url(/igc-harmonics-2026/r1/img/icon_quotation.svg);
	mask-repeat: no-repeat;
	mask-position: top left;
	mask-size: contain;
	width: 32px;
	height: 28px;
	background-color: #00857C;
}
.p-speaker-comment__from,
.p-speaker-comment__heading {
	font-size: 18px;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.5;
}
*+.p-speaker-comment__from,
*+.p-speaker-comment__heading {
	margin-top: 10px;
}
.p-speaker-comment__text {
	font-size: 16px;
	font-size: 1.6rem;
}
@media screen and (max-width: 767px) {
	*+.p-speaker__comment {
		margin-top: 30px;
	}
	.p-speaker__comment {
		padding: 43px 20px 25px;
	}
	.p-speaker__comment:before {
		left: 20px;
	}
	.p-speaker-comment__from,
	.p-speaker-comment__heading {
		font-size: 16px;
		font-size: 1.6rem;
	}
	.p-speaker-comment__text {
		font-size: 15px;
		font-size: 1.5rem;
	}
}
.p-speaker__item-02 .p-speaker-logo__image {
	height: 40px;
}
@media screen and (max-width: 767px) {
	.p-speaker__item-02 .p-speaker-logo__image {
		height: 32px;
	}
}

/* --------------------------------------------------------------------------//
// 開催概要
// -------------------------------------------------------------------------- */
*+.p-information {
	margin-top: 60px;
}
@media screen and (max-width: 767px) {
	*+.p-information {
		margin-top: 50px;
	}
}
.p-information {
	position: relative;
}
.p-information__row {
	display: flex;
	justify-content: space-between;
	width: 100%;
	gap: 40px 50px;
	flex-flow: row nowrap;
}
.p-information__col {
	width: 100%;
}
@media screen and (max-width: 767px) {
	.p-information__row {
		flex-flow: column wrap;
	}
}
.p-information-overview-heading__image,
.p-information-overview-heading__text {
	display: block;
}
.p-information-overview-heading-image__image {
	width: auto;
	height: 28px;
}
.p-information-overview-heading__text {
	color: #123C48;
	font-weight: bold;
	line-height: 1.5;
}
*+.p-information-overview-heading__text {
	margin-top: 20px;
}
@media screen and (max-width: 767px) {
	.p-information-overview-heading-image__image {
		height: 24px;
	}
	.p-information-overview-heading__text {
		font-size: 16px;
		font-size: 1.6rem;
	}
	*+.p-information-overview-heading__text {
		margin-top: 20px;
	}
}
*+.p-information-overview__table {
	margin-top: 30px;
}
@media screen and (max-width: 767px) {
	*+.p-information-overview__table {
		margin-top: 30px;
	}
}
.p-information-participation__box {
	background-color: #E9F5F3;
	border: 1px solid #D2E5E3;
	border-radius: 5px;
	padding: 35px 40px 40px;
}
@media screen and (max-width: 767px) {
	.p-information-participation__box {
		padding: 25px 20px 30px;
	}
}
.p-information-participation__heading {
	font-size: 16px;
	font-size: 1.6rem;
	color: #00857C;
}
*+.p-information-participation__heading {
	margin-top: 20px;
}
@media screen and (max-width: 767px) {
	.p-information-participation__heading {
		font-size: 15px;
		font-size: 1.5rem;
	}
}
*+.p-information-participation__indent {
	margin-top: 15px;
}
*+.p-information-participation__button {
	margin-top: 25px;
}
.p-information__decorations {
	position: absolute;
	top: 0;
	right: 0;
}
.p-information__decoration-01:before {
	content: '';
	width: 330px;
	height: 600px;
	background-image: url(/igc-harmonics-2026/r1/img/bg_line_2.webp);
	background-position: center right;
	background-size: cover;
	background-repeat: no-repeat;
	position: absolute;
	top: -175px;
	right: -237px;
	z-index: 1;
}
@media screen and (max-width: 767px) {
	.p-information__decorations { 
		display: none;
	}
}

/* --------------------------------------------------------------------------//
// ダイジェストムービー
// -------------------------------------------------------------------------- */
*+.p-movie {
	margin-top: 30px;
}
@media screen and (max-width: 767px) {
	*+.p-movie {
		margin-top: 30px;
	}
}
.p-movie__list {
	display: flex;
	justify-content: space-between;
	width: 100%;
	gap: 40px 50px;
	flex-flow: row nowrap;
}
.p-movie__item {
	width: 100%;
}
@media screen and (max-width: 767px) {
	.p-movie__list {
		flex-flow: column wrap;
	}
}

/* --------------------------------------------------------------------------//
// お問い合わせ
// -------------------------------------------------------------------------- */
.p-inquiry__box {
	color: #FFFFFF;
	text-align: center;
	background: url(/igc-harmonics-2026/r1/img/bg_cta.webp) no-repeat center / cover;
	border-radius: 5px;
	padding: 60px 70px 70px;
}
.p-inquiry__heading {
	font-size: 24px;
	font-size: 2.4rem;
}
.p-inquiry__text {
	font-size: 16px;
	font-size: 1.6rem;
	line-height: 1.5;
}
*+.p-inquiry__text {
	margin-top: 30px;
}
*+.p-inquiry__button {
	margin-top: 40px;
}
@media screen and (max-width: 767px) {
	.p-inquiry__box {
		padding: 35px 20px 40px;
	}
	.p-inquiry__heading {
		font-size: 184px;
		font-size: 1.8rem;
	}
	.p-inquiry__text {
		font-size: 15px;
		font-size: 1.5rem;
		text-align: left;
	}
	*+.p-inquiry__text {
		margin-top: 15px;
	}
	*+.p-inquiry__button {
		margin-top: 20px;
	}
}

/* --------------------------------------------------------------------------//
// ソーシャル
// -------------------------------------------------------------------------- */
.p-social {
	display: flex;
	justify-content: center;
}
