@charset "utf-8";
/* CSS関数設定 */
:root {
	/* カラーパレット */
	--WHITE: #FFFFFF;
	--WHITE_OP40: rgba(255, 255, 255, 0.4);
	--WHITE_OP50: rgba(255, 255, 255, 0.5);
	--WHITE_OP80: rgba(255, 255, 255, 0.8);
	--BLACK: #2E2E2E;
	--BLACK_OP70: rgba(0, 0, 0, 0.7);
	--BLUE: #306FB7;

	--GRAY01: #F5F5F5;
	--GRAY02: #DEDEDE;
	--GRAY03: #A7A7A7;
	--GRAY04: #414549;
	--GRAY05: #505a64;
	--GRAY06: #4d4d4d;
	--GRAY07: #808080;

	--DARK01: #2E2E2E;

	--RED01: #dc3b3b;

	--PINK01: #ee8899;
	--PINK02: #E6BEB4;
	--PINK03: #D7B9B4;

	--YELLOW01: #FFD700;
	--YELLOW02: #F0F046;
	--YELLOW03: #DCE666;

	--ORANGE01: #c8a08c;
	--ORANGE02: #DC6736;

	--BEIGE01: #f7f5f0;
	--BEIGE01_OP50: rgba(247, 245, 240, 0.5);
	--BEIGE02: #C8A08C;

	--BLUE01: #5EA1AC;
	
	--GREEN01: #C3FD50;

	/* テキストカラー */
	--TXT_COLOR_BASE: var(--DARK01);
	--TXT_COLOR_WHITE: var(--WHITE);

	/* ボーダーカラー */
	--BDCOLOR_GRAY_1: var(--GRAY02);

	/* 背景カラー */
	--BGCOLOR_GRAY_1: var(--GRAY01);

	/* ランキングカラー */
	--RANKING_1ST: #BA9700;
	--RANKING_2ND: #A7A7A7;
	--RANKING_3RD: #B75400;
	--RANKING_OTHER: #002C1B;

	/* 共通角丸 */
	--COMMON_BDRS_S: 5px;
	--COMMON_BDRS_M: 10px;
	--COMMON_BDRS_L: 20px;

	/* 共通ボックス影 */
	--COMMON_BXSD: 0px 0px 15px -5px var(--GRAY03);
	--COMMON_BXSD_BTM: 0px 5px 15px -5px var(--GRAY03);

	/* ベース文字間隔 */
	--LETTER_SPACING: 0.1em;
      
	/* フォント */
	--FF_BASE: var(--FF_BASE_M);
	--FF_BASE_H:  "MFW-YuGoStdN-Heavy";
	--FF_BASE_E:  "MFW-YuGoStdN-ExtraBold";
	--FF_BASE_B:  "MFW-YuGoPr6N-Bold";
	--FF_BASE_D:  "MFW-YuGoPr6N-Demi";
	--FF_BASE_M:  "MFW-YuGoPr6N-Medium";
	--FF_YUGOTHIC: YuGothic, "游ゴシック Medium", 游ゴシック, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, メイリオ, Meiryo, "ＭＳ Ｐゴシック", sans-serif;

	/* 英数字フォント */
	--FF_EN: "Poppins", serif;
	--FF_NUM:"Poppins", serif;

	/* フォントウェイト */
	--FF_WEIGHT_BASE: 500;
	
	/* アニメーション */
	--ANIME_FADEIN: fadeIn .5s ease-in-out 0s forwards;
	--ANIME_FADEOUT: fadeOut .5s ease-in-out 0s forwards;

	/* フォトサイズ */
	--FZ_9: clamp(8px, 0.8vw, 9px);
	--FZ_10: clamp(8px, 0.8vw, 10px);
	--FZ_11: clamp(10px, 1.1vw, 11px);
	--FZ_12: clamp(10px, 1.1vw, 12px);
	--FZ_13: clamp(11px, 1vw, 13px);
	--FZ_14: clamp(12px, 1.2vw, 14px);
	--FZ_15: clamp(13px, 1.4vw, 15px);
	--FZ_16: clamp(14px, 1.5vw, 16px);
	--FZ_18: clamp(15px, 1.6vw, 18px);
	--FZ_19: clamp(16px, 1.7vw, 19px);
	--FZ_20: clamp(16px, 1.8vw, 20px);
	--FZ_22: clamp(18px, 2vw, 22px);
	--FZ_25: clamp(20px, 2vw, 25px);
	--FZ_28: clamp(22px, 2.5vw, 28px);
	--FZ_30: clamp(25px, 3vw, 30px);
	--FZ_35: clamp(25px, 3vw, 35px);
	--FZ_38: clamp(30px, 3.5vw, 38px);
	--FZ_40: clamp(30px, 3.5vw, 40px);
	--FZ_43: clamp(30px, 4vw, 43px);
	--FZ_45: clamp(30px, 4vw, 45px);
	--FZ_50: clamp(30px, 4vw, 50px);
	--FZ_60: clamp(40px, 5vw, 60px);
	--FZ_70: clamp(42px, 5vw, 70px);
	--FZ_90: clamp(60px, 7vw, 90px);
	--FZ_10_CONST: 10px;
	--FZ_12_CONST: 12px;
	--FZ_14_CONST: 14px;
	--FZ_15_CONST: 15px;
	--FZ_16_CONST: 16px;
	--FZ_18_CONST: 18px;
	--FZ_20_CONST: 20px;

	/* ブロック間 */
	--GAP_10: clamp( 5px, 1.1vw, 10px);
	--GAP_15: clamp( 10px, 1.2vw, 15px);
	--GAP_20: clamp( 15px, 1.7vw, 20px);
	--GAP_25: clamp( 15px, 1.7vw, 25px);
	--GAP_35: clamp( 20px, 2.5vw, 35px);
	--GAP_30: clamp( 20px, 2.5vw, 30px);
	--GAP_40: clamp( 30px, 3.5vw, 40px);
	--GAP_45: clamp( 30px, 3.5vw, 45px);
	--GAP_50: clamp( 30px, 3.5vw, 50px);
	--GAP_60: clamp( 40px, 4.5vw, 60px);
	--GAP_65: clamp( 50px, 5.5vw, 65px);
	--GAP_75: clamp( 60px, 6.5vw, 75px);
	--GAP_80: clamp( 50px, 5.5vw, 80px);
	--GAP_90: clamp( 60px, 6.5vw, 90px);
	--GAP_100: clamp( 70px, 7.5vw, 100px);
	--GAP_120: clamp( 80px, 8.5vw, 120px);
	--GAP_200: clamp( 100px, 10.5vw, 200px);
	--GAP_5_CONST: 5px;
	--GAP_10_CONST: 10px;
	--GAP_15_CONST: 15px;
	--GAP_20_CONST: 20px;
	--GAP_30_CONST: 30px;
	--GAP_40_CONST: 40px;

	/* PCマックス幅 */
	--PC_MAX_WIDTH: var(--PC_MAX_WIDTH_M);
	--PC_MAX_WIDTH_SS: 800px;
	--PC_MAX_WIDTH_S: 1000px;
	--PC_MAX_WIDTH_SM: 1080px;
	--PC_MAX_WIDTH_M: 1250px;
	--PC_MAX_WIDTH_L: 1500px;

	/* 親要素を超えて幅100% */
	--FULL_WIDTH: calc(50% - 50vw);

	/* セクション間隔半分 */
	--GENERALSEC_HALF: calc(var(--GENERALSEC) / 2);

	/* data_uri */
	--data_uri-yajirushi: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHN2ZyBpZD0iX+ODrOOCpOODpOODvF8yIiBkYXRhLW5hbWU9IiDjg6zjgqTjg6Tjg7wgMiIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB2aWV3Qm94PSIwIDAgMzAwIDEwMC45Ij4KICA8ZGVmcz4KICAgIDxzdHlsZT4KICAgICAgLmNscy0xIHsKICAgICAgICBmaWxsOiAjZmZmOwogICAgICAgIHN0cm9rZS13aWR0aDogMHB4OwogICAgICB9CiAgICA8L3N0eWxlPgogIDwvZGVmcz4KICA8ZyBpZD0iX+ODhuOCreOCueODiCIgZGF0YS1uYW1lPSIg44OG44Kt44K544OIIj4KICAgIDxnPgogICAgICA8cG9seWdvbiBjbGFzcz0iY2xzLTEiIHBvaW50cz0iMjQzLjU2IDcwLjc1IDI0My41NiAwIDMwMCAzNS41NyAyNDMuNTYgNzAuNzUiLz4KICAgICAgPHBhdGggY2xhc3M9ImNscy0xIiBkPSJNMy44NywxMDAuOXMtMS45MywwLTIuNzEtMS4xNmMtMS41NS0xLjU1LTEuNTUtMy44NywwLTUuNDEsMzEuNy0zMS43LDU2LjA2LTQ5LjQ4LDEwMi40NS01OS4xNSwyMi40Mi00LjY0LDYxLjA4LTguNTEsNzQuNjEsMy40OCw0MS43NS05LjY2LDc4Ljg3LTcuMzUsODEuMTktNy4zNXMzLjg3LDEuOTMsMy40OCw0LjI1YzAsMS45My0yLjMyLDMuODctNC4yNSwzLjQ4LS4zOSwwLTM1Ljk1LTEuOTMtNzYuMTYsNi41NywxLjkzLDcuMzUtMi43MSwxNi4yNC0xMy41MywyNy4wNi0yMy41OCwyMi44MS01NS42NywzMC4xNS02OC40MywyNS41Mi01LjgtMS45My02Ljk2LTYuMTktNy4zNS04LjEyLS43Ny03LjM1LDcuMzUtMTYuNjIsMjQuMzYtMjcuNDUsMTUuNDYtOS42NiwzMi44Ni0xNi42Miw0OS44Ny0yMS4yNi0xMS45OC00LjI1LTM2LjM0LTMuODctNjIuMjQsMS41NS00MC4yMSw4LjUxLTYzLjQsMjEuNjUtOTguNTgsNTYuODMtLjc3Ljc3LTEuOTMsMS4xNi0yLjcxLDEuMTZaTTE3NS4xMyw0Ny41NWMtMTguMTcsNC42NC0zNi43MywxMS42LTUzLjM1LDIxLjY1LTE3LjAxLDEwLjgyLTIxLjI2LDE3Ljc4LTIwLjg4LDIwLjEsMCwuNzcsMS4xNiwxLjU1LDIuMzIsMS45MywxMC40NCwzLjg3LDM5LjgyLTMuODcsNjAuMzEtMjMuOTcsOC41MS04LjUxLDEyLjc2LTE1LjQ2LDExLjYtMTkuNzJaIi8+CiAgICA8L2c+CiAgPC9nPgo8L3N2Zz4=);
	--data_uri-kakko: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDI3LjkuNiwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDkuMDMgQnVpbGQgNTQ5ODYpICAtLT4KPHN2ZyB2ZXJzaW9uPSIxLjEiIGlkPSLjg6zjgqTjg6Tjg7xfMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeD0iMHB4IgoJIHk9IjBweCIgdmlld0JveD0iMCAwIDgwIDMwMCIgc3R5bGU9ImVuYWJsZS1iYWNrZ3JvdW5kOm5ldyAwIDAgODAgMzAwOyIgeG1sOnNwYWNlPSJwcmVzZXJ2ZSI+CjxzdHlsZSB0eXBlPSJ0ZXh0L2NzcyI+Cgkuc3Qwe2ZpbGw6IzMzMzMzMzt9Cjwvc3R5bGU+CjxnPgoJPHBhdGggY2xhc3M9InN0MCIgZD0iTTQ1LjQxNCwyOTlsLTIuMDIyLTMuMzAxYy0xMy4yNDQtMjEuNjQtMjMuNjk3LTQ0LjUzLTMxLjA2NS02OC4wNDNDNC45MjksMjA0LjA3MSwxLjE4LDE3Ny45OTEsMS4xOCwxNTAuMTM4CgkJYzAtMjguMDM3LDMuNzQ5LTU0LjIxLDExLjE0OC03Ny43OThjNy4zNjYtMjMuNTAyLDE3LjgxOC00Ni4zOTUsMzEuMDY1LTY4LjAzNkw0NS40MTQsMWwzMy4zODYsMTQuMzA5bC0yLjQ5Nyw0LjM2MgoJCWMtMTEuMzc1LDE5Ljg2Mi0xOS44MzgsNDEuMTgtMjUuMTUzLDYzLjM2MmMtNS4zNDEsMjIuMjYtOC4wNSw0NC44MzYtOC4wNSw2Ny4xMDVjMCwyMi4yNjcsMi43MDksNDQuODQyLDguMDQ4LDY3LjEwMQoJCWM1LjMxNywyMi4xOCwxMy43NzgsNDMuNDAyLDI1LjE0Niw2My4wNzhsMi41MjUsNC4zNjhMNDUuNDE0LDI5OXogTTQ5LjAzLDEyLjI5MkMzNy4xMTEsMzIuMzI3LDI3LjY0NCw1My40MDksMjAuODcxLDc1LjAxOAoJCWMtNy4xMjUsMjIuNzItMTAuNzM3LDQ3Ljk5My0xMC43MzcsNzUuMTJjMCwyNi45NDEsMy42MTIsNTIuMTIzLDEwLjczNyw3NC44NGM2Ljc3NSwyMS42MTYsMTYuMjQyLDQyLjcwMiwyOC4xNTksNjIuNzMyCgkJbDE3LjAzNS03LjMwMmMtMTAuNTYtMTkuMTc4LTE4LjUtMzkuNzAyLTIzLjYyNS02MS4wODJjLTUuNTAzLTIyLjk0LTguMjk1LTQ2LjIyLTguMjk1LTY5LjE4OGMwLTIyLjk3MSwyLjc5Mi00Ni4yNSw4LjI5Ny02OS4xOTMKCQljNS4xMjUtMjEuMzg4LDEzLjA2OS00MiwyMy42NC02MS4zNDRMNDkuMDMsMTIuMjkyeiIvPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+CjxnPgo8L2c+Cjwvc3ZnPgo=);
}

@media screen and (min-width: 768px){
	:root{
		--INNER_WIDTH: 95%;
		--GENERALSEC: clamp(70px, 8vw, 100px);
	}
}
@media screen and (max-width: 767px){
	:root{
	--INNER_WIDTH: 85%;
	--GENERALSEC: 60px;
	}
}
/* フェードインアニメーション */
@keyframes fadeIn {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
@keyframes fadeOut {
	0% {
		opacity: 1;
	}
	100% {
		opacity: 0;
	}
}
/* リセットCSS */
*{margin:0;padding:0;min-height: 0;min-width: 0;-webkit-box-sizing: border-box;-moz-box-sizing: border-box;box-sizing: border-box;}
html {height:100%;scroll-behavior: smooth;}
ul li ,ol li{list-style:none;}
h1,h2,h3,h4,h5,h6{font-weight: var(--FF_WEIGHT_BASE);font-size: 100%;margin: 0;}
p{margin: 0;}
strong{font-weight: inherit;}
a:focus, *:focus{ outline:none; }
article, header, footer, aside, figure, figcaption, nav, section,main{ 
  display:block;
}
body{
	font-family: var(--FF_BASE);
	font-weight: var(--FF_WEIGHT_BASE);
	font-feature-settings: "palt" 1;
	letter-spacing: var(--LETTER_SPACING);
	width:100%;
	color: var(--TXT_COLOR_BASE);
	position:relative;
	z-index: 0;
	overflow-x: clip;
}
a{
	text-decoration: none;
	outline: none;
	word-wrap: break-word;
	color: var(--TXT_COLOR_BASE);
}
a img,a{
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all  0.5s;
}
img{
	height: auto;
	max-width: 100%;
	box-sizing: unset;
	vertical-align: bottom;
}
iframe{
	vertical-align: bottom;
}
.formReset button,
.formReset input[type="button"],
.formReset input[type="submit"],
.formReset input[type="text"],
.formReset input[type="image"],
.formReset select{
	background-color: unset;
	color: var(--TXT_COLOR_BASE);
	-webkit-appearance: none;
	border-radius: 0;
	border: none;
}
.formReset input[type="text"],
.formReset input[type="text"]::placeholder{
	font-family: var(--FF_BASE);
}
.formReset input[type="text"]{
	color: var(--TXT_COLOR_BASE);
}
.formReset input[type="text"]::placeholder{
	color: var(--GRAY03);
}
time{
	font-family: var(--FF_NUM);
}
/* フォントCSS */
.ff-mincho{
	font-family: 'Yu Mincho Light','YuMincho','Yu Mincho','游明朝体','ヒラギノ明朝 ProN','Hiragino Mincho ProN','ヒラギノ明朝 ProN','Hiragino Mincho ProN',sans-serif;
}
/* imgリセット */
.imgauto{
	height: auto;
	width: 100%;
	box-sizing: unset;
	line-height: 1rem;
	display: block;
}
/* セクション間隔*/
.g-mgt{
	margin-top: var(--GENERALSEC);
}
.g-mgb{
	margin-bottom: var(--GENERALSEC);
}
.g-pd{
	padding-block: var(--GENERALSEC);
}
.g-pdt{
	padding-top: var(--GENERALSEC);
}
.g-pdb{
	padding-bottom: var(--GENERALSEC);
}
.g-mgt--half{
	margin-top: var(--GENERALSEC_HALF);
}
.g-mgb--half{
	margin-bottom: var(--GENERALSEC_HALF);
}
.g-pd--half{
	padding-block: var(--GENERALSEC_HALF);
}
.g-pdt--half{
	padding-top: var(--GENERALSEC_HALF);
}
.g-pdb--half{
	padding-bottom: var(--GENERALSEC_HALF);
}
/* グリッド、フレックス */
.grid{
	display: grid;
}
.flex{
	display: flex;
}
/* スライダー読み込みまで非表示 */
.slick{
	opacity: 0;
	transition: opacity .3s linear;
}
.slick.slick-initialized{
	opacity: 1;
}
.swiper{
	overflow: hidden;
  opacity: 0;
	transition: opacity .3s linear;
}
.swiper.swiper-initialized{
	opacity: 1;
}
/* 縦書き */
.tategaki{
	writing-mode: vertical-rl;
}
/* 文字間 */
::placeholder,
input[type="text"],
[class*="ttl"],
[class*="lead"],
[class*="heading"],
a{
	letter-spacing: var(--LETTER_SPACING);
}
/* テキスト行間文字間 */
[class*="txt"]{
	letter-spacing: var(--LETTER_SPACING);
}
/* スクロールバー消す */
.noscrollbar,
.noscrollbar{
	-ms-overflow-style: none;/* IE, Edge 対応 */
	scrollbar-width: none;/* Firefox 対応 */
}
.noscrollbar::-webkit-scrollbar,
.noscrollbar::-webkit-scrollbar{/* Chrome, Safari 対応 */
	display: none;
}
/* youtube */
.youtubeContainer iframe {
  display: block;
  width: 100%;
	height: auto;
	aspect-ratio: 10000/5625;
}
/* 改行用 */
.dib{
	display: inline-block;
}
/* 非表示 */
.displaynone{
	display: none;
}
/* 親要素超えて幅100% */
.widthOverParent{
	width: 100vw;
	--OYA: calc(50% - 50vw);;
	margin-left: var(--OYA);
	margin-right: var(--OYA);
}
@media (hover: hover){
	.formReset button:hover,
	.formReset input[type="button"]:hover,
	.formReset input[type="submit"]:hover,
	.formReset input[type="image"]:hover,
	.formReset select:hover{
		cursor: pointer;
	}
	a:hover{
		opacity: 0.7;
		text-decoration: none;
	}
	a:hover img{
		opacity:0.75 !important;
	}
}
html.no-smooth-scroll {
	scroll-behavior: auto;
}
.g-inner,
.g-inner--l,
.g-inner--m,
.g-inner--s,
.g-inner--sm,
.g-inner--ss{
	width: var(--INNER_WIDTH);
	margin-inline: auto;
}
.g-maxWrapper{
	position: relative;
}
@media screen and (min-width: 768px){
	html{
		scroll-padding-top: 120px;
	}
	body{
		font-size: var(--FZ_15_CONST);
		line-height: 1.7;
		-ms-text-size-adjust: 100%;
		-webkit-text-size-adjust: 100%;
	}
	a[href^="tel:"] {
		pointer-events: none;
	}
	.g-maxWrapper{
		max-width: 1440px;
		margin-inline: auto;
		position: relative;
	}
	.g-inner--pc{
		width: var(--INNER_WIDTH);
		margin-inline: auto;
	}
	.g-inner,
	.g-inner--m,
	.g-inner--pc{
		max-width: var(--PC_MAX_WIDTH_M);
	}
	.g-inner--l{
		max-width: var(--PC_MAX_WIDTH_L);
	}
	.g-inner--s{
		max-width: var(--PC_MAX_WIDTH_S);
	}
	.g-inner--sm{
		max-width: var(--PC_MAX_WIDTH_SM);
	}
	.g-inner--ss{
		max-width: var(--PC_MAX_WIDTH_SS);
	}
	.g-inner--pcHasSlickGap{
		--INNER_ADJUST: calc(var(--SLICK_GAP) * 2);
    width: calc(var(--INNER_WIDTH) + var(--INNER_ADJUST));
    max-width: calc(var(--PC_MAX_WIDTH_M) + var(--INNER_ADJUST));
		margin-inline: auto;
	}
	.g-pd--halfPcOnly{
		padding-block: var(--GENERALSEC_HALF);
	}
	.sp{
		display: none !important;
	}
	.tategaki--pc{
		writing-mode: vertical-rl;
	}
	/* pc順番付与 */
	.orderPc-1st { order: 1; }
	.orderPc-2nd { order: 2; }
	.orderPc-3rd { order: 3; }
	.orderPc-4th { order: 4; }
	.orderPc-5th { order: 5; }
	.orderPc-6th { order: 6; }
	.orderPc-7th { order: 7; }
	.orderPc-8th { order: 8; }
	.orderPc-9th { order: 9; }
	.orderPc-10th { order: 10; }
	.orderPc-11th { order: 11; }
	.orderPc-12th { order: 12; }
	.orderPc-13th { order: 13; }
	.orderPc-14th { order: 14; }
	.orderPc-15th { order: 15; }
	.orderPc-16th { order: 16; }
	.orderPc-17th { order: 17; }
	.orderPc-18th { order: 18; }
	.orderPc-19th { order: 19; }
	.orderPc-20th { order: 20; }
	.orderPc-21th { order: 21; }
	.orderPc-22th { order: 22; }
	.orderPc-23th { order: 23; }
	.orderPc-24th { order: 24; }
	.orderPc-25th { order: 25; }
	.orderPc-26th { order: 26; }
	.orderPc-27th { order: 27; }
	.orderPc-28th { order: 28; }
	.orderPc-29th { order: 29; }
	.orderPc-30th { order: 30; }
	.orderPc-31th { order: 31; }
	.orderPc-32th { order: 32; }
	.orderPc-33th { order: 33; }
	.orderPc-34th { order: 34; }
	.orderPc-35th { order: 35; }
	.orderPc-36th { order: 36; }
	.orderPc-37th { order: 37; }
	.orderPc-38th { order: 38; }
	.orderPc-39th { order: 39; }
	.orderPc-40th { order: 40; }
}
@media screen and (max-width: 767px){
	html{
		scroll-padding-top: 50px;
	}
	body{
		font-size: var(--FZ_14_CONST);
		line-height: 1.6;
	}
	.g-inner--sp{
		width: var(--INNER_WIDTH);
		margin-inline: auto;
	}
	.g-pd--halfPcOnly{
		padding-block: var(--GENERALSEC);
	}
	.pc{
		display: none !important;
	}
	.sp-scroll--y{
		overflow-y: scroll;
		overflow-x: auto;
	}
	.sp-scroll--x{
		overflow-x: scroll;
		overflow-y: auto;
		padding-inline: calc((100% - var(--INNER_WIDTH)) / 2);
	}
	.tategaki--sp{
		writing-mode: vertical-rl;
	}
	.formReset input[type="text"],
	.formReset input[type="text"]::placeholder{
		font-size: 16px;
	}
}
/* ■■■■■■■■■■■■■■■■■■■■■■header■■■■■■■■■■■■■■■■■■■■■■ */
@media (hover: hover){
	.hd-btnContainer .g-btn--small a{
		overflow: hidden;
	}
	.hd-btnContainer .g-btn--small a::before{
		content: '';
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		z-index: -1;
		background: var(--ORANGE02);
		transform: scaleX(0);
		transform-origin: right;
		transition: transform 0.3s;
	}
	.hd-btnContainer .g-btn--small a:hover::before{
		transform: scaleX(1);
		transform-origin: left;
	}
	.hd-btnContainer .g-btn--small a:hover{
		transform: scale(1);
	}
}
@media screen and (min-width: 768px){
	:root{
		--HEADER_HEIGHT: 90px;
	}
	body{
		padding-top: var(--HEADER_HEIGHT);
	}
	#headerarea{
		position: fixed;
		width: 100%;
		top: 0;
		left: 0;
		height: var(--HEADER_HEIGHT);
		z-index: 99;
		background-color: var(--WHITE_OP80);
	}
		#headerarea__contents{
		display: flex;
		align-items: center;
	}
	.header-news{
		text-align: center;
		font-family: var(--FF_BASE_B);
		padding: 3px 0 2px;
		border-bottom: 1px solid #000;
		margin-bottom: 8px;
		background: #f6f6f6;
	}
	.hd-container{
		width: var(--INNER_WIDTH);
		max-width: 1368px;
		margin-inline: auto;
		display: grid;
		grid-template-columns: auto 1fr;
		align-items: center;
	}
	.hd-logo{
		width: 211px;
	}
	.hd-btnContainer.g-btnContainer{
		margin-top: 0;
		gap: 10px;
		justify-content: flex-end;
		padding-right: 50px;
	}
	.hd-btnContainer .g-btn--small{
		max-width: unset;
		width: fit-content;
	}
	.hd-btnContainer .g-btn--small a{
		padding-inline: 20px;
	}
}
@media screen and (max-width: 767px){
	#headerarea{
		padding-block: 20px;
		padding-top: 0px;
	}
	.hd-logo{
		width: 165px;
	}
	.header-news{
		background: #3c3c3c;
		padding:6px 10px;
		margin-bottom: 10px;
		text-align: center;
	}
	.header-news a{
		color:#fff;
		font-size:14px;
	}
}
/* -------------------g-solepro-------------------- */
.g-solepro{
  background: no-repeat center center / cover;
  position: relative;
  z-index: 0;
}
.g-solepro::before{
  content: "";
  display: inline-block;
  background: var(--WHITE);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.g-solepro::after{
  content: "";
  display: inline-block;
  background: #838383ed;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.g-solepro article{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}
@media screen and (min-width: 768px){
  .g-solepro{
    background-image: url(/asset2025/images/common/contact.jpg);
    display: flex;
  }
  .g-solepro::before{
    height: calc(100% - var(--GAP_60));
    width: 1px;
  }
  .g-solepro article{
    flex: 1;
    padding-block: var(--GAP_100);
    padding-inline: var(--GAP_30);
  }
  .g-solepro__lead{
    color: var(--WHITE);
    margin-block: var(--GAP_10) var(--GAP_30);
    font-size: var(--FZ_16);
    font-family: var(--FF_BASE_D);
    text-align: center;
		letter-spacing: 0;
  }
  .g-solepro .g-btn{
    max-width: 300px;
  }
  .g-solepro .g-btn a{
    justify-content: center;
  }
}
@media screen and (max-width: 767px){
  .g-solepro{
    background-image: url(/asset2025/images/common/sp/contact.jpg);
  }
  .g-solepro article{
    padding-block: var(--GENERALSEC);
  }
  .g-solepro::before{
    width: calc(100% - 20px);
    height: 1px;
  }
  .g-solepro .g-btn{
    margin-top: 30px;
  }
}

/* ■■■■■■■■■■■■■■■■■■■■■■footer■■■■■■■■■■■■■■■■■■■■■■ */
#footerarea{
	background-color: var(--BEIGE01);
}
.ft-office{
	font-weight: bold;
	letter-spacing: 0.02em;
}
.ft-office dt{
	font-family: var(--FF_EN);
}
.ft-office dd{
	font-family: var(--FF_BASE_E);
}
.ft-link a{
	display: inline-block;
	position: relative;
}
.ft-link a::after{
	content: "";
	display: inline-block;
	--MASK: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDI3LjkuNiwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDkuMDMgQnVpbGQgNTQ5ODYpICAtLT4KPHN2ZyB2ZXJzaW9uPSIxLjEiIGlkPSLjg6zjgqTjg6Tjg7xfMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeD0iMHB4IgoJIHk9IjBweCIgdmlld0JveD0iMCAwIDMwMCAzMDAiIHN0eWxlPSJlbmFibGUtYmFja2dyb3VuZDpuZXcgMCAwIDMwMCAzMDA7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPGc+Cgk8Zz4KCQk8cG9seWdvbiBwb2ludHM9IjQ1LjkzLDI5OSAxNi43NDEsMjUyLjUwOCAxODAuMDEsMTQ5Ljk5NyAxNi43NDEsNDcuNDkyIDQ1LjkzLDEgMjgzLjI1OSwxNDkuOTk3IAkJIi8+Cgk8L2c+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPGc+CjwvZz4KPC9zdmc+Cg==) no-repeat center center / 100%;
	mask: var(--MASK);
	-webkit-mask: var(--MASK);
	background-color: var(--BLACK);
	aspect-ratio: 1/1;
	position: absolute;
	right: 0;
}
.ft-link a span{
	display: inline-block;
	position: relative;
}
.ft-link a span::after{
	content: "";
	display: inline-block;
	background-color: var(--TXT_COLOR_BASE);
	width: 100%;
	height: 2px;
	position: absolute;
	bottom: 0;
	left: 0;
	transform: scaleX(1);
	transform-origin: left;
	transition: transform .3s;
}
.ft-sns{
	display: flex;
}
.ft-sns li a{
	display: block;
	aspect-ratio: 1/1;
	background: no-repeat center center / 100%;
}
.ft-goTop a{
	display: block;
	aspect-ratio: 22/30;
	background: url(/asset2025/images/common/up.svg) no-repeat center center / 100%;
}
.ft-terms a{
	font-family: var(--FF_BASE_E);
	letter-spacing: 0.02em;
}
.ft-copy{
	font-family: var(--FF_EN);
	font-weight: 400;
	letter-spacing: 0.02em;
}
@media (hover: hover){
	.ft-link a:hover{
		opacity: 1;
	}
	.ft-link a:hover span{
		color: var(--ORANGE02);
	}
	.ft-link a span,
	.ft-link a::after{
		transition: .5s;
	}
	.ft-link a:hover::after{
		background-color: var(--ORANGE02);
	}
	.ft-menu a:hover{
		opacity: 1;
		color: var(--ORANGE02);
	}
	.ft-link a:hover span::after{
		transform: scaleX(0);
		transform-origin: right;
	}
}
@media screen and (min-width: 1201px){
	.ft-container{
		gap: var(--GAP_200);
	}
	.ft-bdoy{
		grid-template-columns: clamp( 400px, 45vw, 530px) 1fr;
	}
}
@media screen and (min-width: 768px) and (max-width: 1200px){
	.ft-container{
		gap: var(--GAP_100);
	}
	.ft-bdoy{
		width: 80%;
		max-width: 500px;
		gap: 30px;
	}
	.ft-links{
		grid-template-columns: repeat(2,1fr);
	}
}
@media screen and (min-width: 768px){
	#footerarea{
		padding-block: var(--GENERALSEC) calc(var(--GENERALSEC) + var(--GAP_30));
	}
	.ft-container{
		display: grid;
		grid-template-columns: auto 1fr;
		position: relative;
		padding-bottom: var(--GAP_100);
	}
	.ft-logo{
		width: clamp( 100px, 14vw, 200px);
		margin-bottom: var(--GAP_40);
	}
	.ft-office{
		font-size: var(--FZ_13);
	}
	.ft-office dd{
		margin-block: 3px var(--GAP_30);
	}
	.ft-office .ft-link a::after{
		width: 10px;
		bottom: 5px;
		transform: translateX(130%);
	}
	.ft-link a span{
		line-height: 1.2;
	}
	.ft-office .ft-link a span{
		line-height: 1.5;
	}
	.ft-sns{
		gap: var(--GAP_15);
		margin-top: var(--GAP_60);
	}
	.ft-sns li{
		width: clamp( 30px, 3.5vw, 40px);
	}
	.ft-sns li:first-child{
		margin-right: calc(0px - var(--GAP_10));
	}
	.ft-bdoy{
		display: grid;
		align-items: flex-start;
	}
	.ft-menu{
		display: grid;
		grid-template-columns: repeat(2,1fr);
	}
	.ft-menu > li > p{
		font-family: var(--FF_EN);
		font-size: var(--FZ_20);
		font-weight: 700;
	}
	.ft-menu > li > ul{
		border-left: 3px solid var(--BLACK);
		padding-left: var(--GAP_20);
	}
	.ft-menu > li > ul{
		display: grid;
		gap: var(--GAP_10);
		margin-top: var(--GAP_10);
	}
	.ft-menu > li > ul li a{
		font-family: var(--FF_BASE_E);
		font-size: var(--FZ_15);
	}
	.ft-links{
		display: grid;
		gap: var(--GAP_20);
	}
	.ft-links a{
		font-family: var(--FF_EN);
		font-weight: 700;
		font-size: var(--FZ_16);
	}
	.ft-links a::after{
		width: 10px;
		bottom: 10px;
		transform: translateX(130%);
	}
	.ft-links a span{
		line-height: 1.8;
		width: 130px;
	}
	.ft-goTop{
		width: clamp( 100px, 15vw, 180px);
		position: absolute;
		bottom: 0;
		right: 0;
	}
	.ft-btm{
		display: flex;
		flex-direction: column;
		align-items: flex-end;
		margin-top: var(--GAP_60);
		gap: var(--GAP_10);
	}
	.ft-terms a{
		font-size: var(--FZ_14);
	}
	.ft-copy{
		font-size: var(--FZ_18);
	}
}
@media screen and (max-width: 767px){
	#footerarea{
		padding-block: var(--GENERALSEC) calc(var(--GENERALSEC) + 10px);
	}
	.ft-logo{
		width: 200px;
		margin-bottom: 30px;
	}
	.ft-office dd{
		margin-block: 3px 25px;
	}
	.ft-sns{
		gap: 10px;
	}
	.ft-sns li{
		width: 32px;
	}
	.ft-sns li:first-child{
		margin-right: -5px;
	}
	.ft-link a::after{
		width: 10px;
		bottom: 5px;
		transform: translateX(130%);
	}
	.ft-link a span{
		line-height: 1.2;
	}
	.ft-goTop{
		width: 150px;
		margin: -30px 5% 50px auto;
	}
	.ft-terms{
		text-align: center;
		margin-bottom: 5px;
	}
	.ft-copy{
		font-size: 12px;
		text-align: center;
	}
}

/* -------------------g-works-------------------- */
.g-works__list__mockupContainer{
  position: relative;
  overflow-x: clip;
}
.g-works__list__mockup{
  position: relative;
}
.g-works__list__mockup__sp{
  position: absolute;
  right: 5%;
  bottom: 0;
  transform: translateY(10%);
  z-index: 2;
}
[class*="g-works__list__mockup__"]{
  overflow: hidden;
  border: 2px solid var(--BLACK);
}
[class*="g-works__list__mockup__"] img{
  object-fit: cover;
}
.g-works__list__mockup__pc{
	border-radius: var(--BDRS_PC);
}
.g-works__list__mockup__sp{
	border-radius: var(--BDRS_SP);
}
.g-works__list__mockup__pc img{
	border-radius: calc(var(--BDRS_PC) - 2px);
}
.g-works__list__mockup__sp img{
	border-radius: calc(var(--BDRS_SP) - 2px);
}
.g-works__list__siteName{
	letter-spacing: 0;
}
.g-works__list__siteName small{
  display: block;
}
.g-works__list__tags{
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}
.g-works__list__tag a{
  display: block;
  font-weight: bold;
	background-color: var(--WHITE);
  border: 1px solid var(--BLACK);
  border-radius: 2px;
	letter-spacing: 0;
}
.g-works__list__tag--industry a{
  background-color: var(--BEIGE01);
  border-color: var(--BEIGE01);
}
.g-interviews .g-works__list__tag--industry a{
  background-color: var(--WHITE);
  border-color: var(--BLACK);
}
.g-works__list__tag--kinds a{
  background-color: var(--GRAY05);
  border-color: var(--GRAY05);
  color: var(--WHITE);
}
[class*="g-works__list__button--"]{
	aspect-ratio: 1/2;
  position: absolute;
  z-index: 2;
}
.g-works__list__button--prev{
  left: 0;
}
.g-works__list__button--next{
  transform: rotate(180deg) scale(1, -1);
  right: 0;
}
[class*="g-works__list__button--"]::after{
	content: "";
	display: inline-block;
	--MASK: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDI3LjkuNiwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDkuMDMgQnVpbGQgNTQ5ODYpICAtLT4KPHN2ZyB2ZXJzaW9uPSIxLjEiIGlkPSLjg6zjgqTjg6Tjg7xfMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeD0iMHB4IgoJIHk9IjBweCIgdmlld0JveD0iMCAwIDE1MCAzMDAiIHN0eWxlPSJlbmFibGUtYmFja2dyb3VuZDpuZXcgMCAwIDE1MCAzMDA7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCS5zdDB7ZmlsbDojRkZGRkZGO30KPC9zdHlsZT4KPGc+Cgk8Zz4KCQk8Zz4KCQkJPHBhdGggY2xhc3M9InN0MCIgZD0iTTcyLDE5NC43Yy0yLjMsMC00LjctMS02LjItM0wzNi4zLDE1NWMtMi40LTIuOS0yLjQtNy4xLDAtMTBsMjkuNS0zNi43YzIuOC0zLjQsNy44LTQsMTEuMi0xLjIKCQkJCWMzLjQsMi44LDQsNy44LDEuMiwxMS4yTDUyLjgsMTUwbDI1LjUsMzEuN2MyLjgsMy40LDIuMiw4LjUtMS4yLDExLjNDNzUuNSwxOTQuMSw3My44LDE5NC43LDcyLDE5NC43eiIvPgoJCTwvZz4KCTwvZz4KPC9nPgo8L3N2Zz4K) no-repeat center center / 100%;
	mask: var(--MASK);
	-webkit-mask: var(--MASK);
	background-color: var(--WHITE);
	width: 100%;
	aspect-ratio: 1/2;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
}
[class*="g-works__list__button--"]::before{
	content: "";
	display: inline-block;
	background: var(--BLACK);
	width: 70px;
	aspect-ratio: 1;
	border-radius: 50%;
	position: absolute;
	top: 0;
	z-index: -1;
}
.g-works__list__button--next::before{
	right: 0;
}
.g-works__list__button--prev::before{
	right: 0;
}
.g-works__list__scrollbar{
  display: none;
}
@media (hover: hover){
  [class*="g-works__list__mockup__"] img{
    transition: .2s;
  }
  .g-works__list__mockupContainer a:hover [class*="g-works__list__mockup__"] img{
    transform: scale(1.2);
  }
  .g-works__list__mockupContainer a:hover,
  .g-works__list__mockupContainer a:hover img{
    opacity: 1 !important;
  }
  [class*="g-works__list__button--"]:hover{
    cursor: pointer;
  }
	[class*="g-works__list__button--"]::before{
		transition: .3s;
	}
	[class*="g-works__list__button--"]:hover::before{
		transform: scale(1.2);
	}
  .g-works__list__scrollbar .swiper-scrollbar-drag:hover{
    cursor: pointer;
  }
  .g-works__list__tag--industry a:hover{
    opacity: 1;
    color: var(--WHITE);
    background-color: var(--ORANGE02);
  }
	.g-interviews .g-works__list__tag--industry a:hover{
		opacity: 1;
		color: var(--WHITE);
		background-color: var(--BLACK);
	}
  .g-works__list__tag--kinds a:hover{
    opacity: 1;
    color: var(--GRAY05);
    background-color: var(--WHITE);
  }
  .g-works__list__tag--interviewLink a:hover{
    opacity: 1;
    background-color: var(--BLACK);
    color: var(--WHITE);
  }
  .g-works__list__scrollbar .swiper-scrollbar-drag::after{
    transition: .3s;
  }
  .g-works__list__scrollbar .swiper-scrollbar-drag:hover::after{
    background-color: var(--ORANGE02);
  }
}
@media screen and (min-width: 768px){
  .g-works{
    padding-block: var(--GAP_30) var(--GAP_200);
  }
  .g-works__list{
    overflow: hidden;
    opacity: 0;
    transition: opacity .3s linear;
    position: relative;
  }
  .g-works__list.swiper-initialized{
    opacity: 1;
  }
  [class*="g-works__list__button--"]{
    width: 35px;
    top: 35%;
  }
  .g-works__list__mockupContainer{
    margin-bottom: 30px;
  }
	.g-works__list__mockup__sp{
		width: 40%;
	}
  .g-works__list__siteName{
    font-size: var(--FZ_16);
    margin-bottom: 10px;
  }
  .g-works__list__scrollbar{
    position: relative;
    width: 95%;
    max-width: 700px;
    height: 30px;
    margin: var(--GAP_20) auto 0;
  }
  .g-works__list__scrollbar::before{
    content: "";
    display: inline-block;
    background: var(--GRAY07);
    width: 100%;
    height: 2px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .g-works__list__scrollbar .swiper-scrollbar-drag{
    width: 50px;
    top: 0;
    height: 30px;
    position: absolute;
    background: unset;
  }
  .g-works__list__scrollbar .swiper-scrollbar-drag::after{
    content: "";
    display: inline-block;
    background: var(--BLACK);
    width: 100%;
    height: 5px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
  }
  .g-works__list__tag a{
    font-size: 12px;
    padding: 2px 7px;
  }
	[class*="g-works__list__mockup__"]{
		--BDRS_PC: 10px;
		--BDRS_SP: 10px;
	}
}
@media screen and (max-width: 767px){
  .g-works{
    padding-block: 30px var(--GENERALSEC);
    overflow-x: clip;
  }
  .g-works span[class*="g-heading__"]{
    text-align: center;
  }
  .g-works__list{
    display: flex;
    overflow-x: auto;
    white-space: nowrap;
    padding-left: calc((100% - var(--INNER_WIDTH)) / 2);
    -ms-overflow-style: none;/* IE, Edge 対応 */
    scrollbar-width: none;/* Firefox 対応 */
  }
  .g-works__list::-webkit-scrollbar{
    display: none;
  }
  .g-works__list .swiper-wrapper{
    display: contents;
  }
  .g-works__list article{
    --WIDTH: 123px;
    min-width: var(--WIDTH);
    max-width: var(--WIDTH);
    flex: 0 0 auto;
    margin-right: 23px;
  }
  .g-works__list__mockupContainer{
    margin-bottom: 20px;
  }
  .g-works__list__siteName{
    font-size: 12px;
    margin-bottom: 10px;
		white-space: wrap;
  }
  .g-works__list__siteName small{
    font-size: 10px;
  }
  .g-works__list__tag a{
    font-size: 9px;
    padding: 1px 5px;
    letter-spacing: 0.05em;
  }
	.g-works__list__mockup__sp{
		width: 40%;
	}
	[class*="g-works__list__mockup__"]{
		--BDRS_PC: 8px;
		--BDRS_SP: 5px;
	}
}

/* ■■■■■■■■■■■■■■■■■■■■■■全ページ共通部分■■■■■■■■■■■■■■■■■■■■■■ */
/* -------------------見出し-------------------- */
.g-headingContainer{
	position: relative;
}
.g-heading--center > span{
	text-align: center;
}
.g-heading__ja{
	display: block;
	font-family: var(--FF_BASE_E);
	letter-spacing: 0.2em;
}
.g-heading__en{
	display: block;
	font-family: var(--FF_EN);
	font-weight: 700;
	letter-spacing: 0.05em;
}
.g-heading--white span{
	color: var(--WHITE);
}
@media screen and (min-width: 768px){
  .g-headingContainer{
		margin-bottom: var(--GAP_60);
	}
	.g-heading__ja{
		font-size: var(--FZ_14);
	}
	.g-heading__en{
		font-size: var(--FZ_40);
		line-height: 1.5;
	}
}
@media screen and (max-width: 767px){
	.g-headingContainer{
		margin-bottom: 20px;
	}
	.g-heading__ja{
		font-size: 14px;
	}
	.g-heading__en{
		font-size: 32px;
		line-height: 1.2;
	}
}
/*  ボタンあり */
@media screen and (min-width: 768px){
	.g-headingContainer--hasBtn{
		display: flex;
		justify-content: space-between;
		align-items: flex-end;
	}
}
/* 見出し横並び */
.g-heading--flex{
	display: flex;
	align-items: center;
}
@media screen and (min-width: 768px){
	.g-heading--flex .g-heading__en{
		font-size: var(--FZ_30);
	}
	.g-heading--flex{
		margin-bottom: 20px;
	}
}
@media screen and (max-width: 767px){
	.g-heading--flex{
		margin-bottom: 15px;
	}
	.g-heading--flex{
		white-space: nowrap;
		margin-bottom: 15px;
	}
	.g-heading--flex .g-heading__en{
		font-size: 24px;
	}
}
/* -------------------ボタン-------------------- */
/* コンテナベース */
.g-btnContainer{
	display: grid;
}
@media screen and (min-width: 768px){
	.g-btnContainer{
		margin-top: var(--GAP_50);
	}
}
@media screen and (max-width: 767px){
	.g-btnContainer{
		margin-top: 30px;
	}
}
/* コンテナベース - 横並び */
.g-btnContainer--horizontal{
	display: flex;
	justify-content: center;
}
@media screen and (min-width: 768px){
	.g-btnContainer--horizontal{
		gap: var(--GAP_30);
	}
}
@media screen and (max-width: 767px){
	.g-btnContainer--horizontal{
		gap: 10px;
	}
}
/* コンテナベース - PCのみ横並び */
@media screen and (min-width: 768px){
	.g-btnContainer--horizontalPc{
		display: flex;
		gap: var(--GAP_30);
	}
}
@media screen and (max-width: 767px){
	.g-btnContainer--horizontalPc{
		gap: 20px;
	}
	.g-btnContainer--horizontalPc .g-btn{
		margin-inline: auto;
	}
}
/* コンテナベース - 縦並び */
@media screen and (min-width: 768px){
	.g-btnContainer--vertical{
		gap: var(--GAP_20);
	}
}
@media screen and (max-width: 767px){
	.g-btnContainer--vertical{
		gap: var(--GAP_20);
	}
	.g-btnContainer--vertical .g-btn{
		margin-inline: auto;
	}
}
/* ボタンベース */
.g-btn{
	width: 100%;
}
.g-btn > a{
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-weight: 600;
	border-radius: 2px;
	position: relative;
	border-radius: 60px;
	transition: .3s;
}
@media screen and (min-width: 768px){
	.g-btn{
		max-width: 330px;
	}
	.g-btn > a{
		min-height: 50px;
	}
}
@media screen and (max-width: 767px){
	.g-btn{
		max-width: 290px;
	}
	.g-btn > a{
		min-height: 50px;
	}
}
/* ボタンベース_フォントサイズ */
.g-btn__label{
	font-family: var(--FF_BASE_E);
}
.g-btn__label--en{
	font-family: var(--FF_EN);
}
@media screen and (min-width: 768px){
	.g-btn__label{
		font-size: var(--FZ_16);
	}
}
@media screen and (max-width: 767px){
	.g-btn__label{
		font-size: 14px;
	}
}
/* カラーバリエーション */
.g-btn--white > a{
	background-color: var(--WHITE);
}
.g-btn--black > a{
	background-color: var(--BLACK);
	color: var(--WHITE);
}
.g-btn--blue > a{
	background-color: var(--BLUE);
	color: var(--WHITE);
}
.g-btn--green > a{
	background-color: var(--GREEN01);
}
@media (hover: hover){
	.g-btn > a:hover{
		opacity: 1;
		transform: scale(1.1);
	}
}
/* 大きさ - long */
.g-btn--long{
	width: var(--INNER_WIDTH);
	max-width: 388px;
}
/* 大きさ - small */
@media screen and (min-width: 768px){
	.g-btn--small{
		max-width: 150px;
	}
	.g-btn--small > a{
		padding: 7px 0;
		min-height: 40px;
	}
	.g-btn--small .g-btn__label{
		font-size: 12px;
	}
}
@media screen and (max-width: 767px){
	.g-btn--small{
		max-width: 128px;
	}
	.g-btn--small > a{
		padding: 7px 0;
		min-height: 30px;
	}
	.g-btn--small .g-btn__label{
		font-size: 10px;
	}
}
/* タイプ - center */
.g-btn--center{
	margin-inline: auto;
}
/* タイプ - arrow */
.g-btn--arrow > a{
	position: relative;
}
.g-btn--arrow > a::after{
	content: "";
	display: inline-block;
	--MASK: var(--data_uri-yajirushi) no-repeat center center / 100%;
	mask: var(--MASK);
	-webkit-mask: var(--MASK);
	aspect-ratio: 3/1;
	position: absolute;
}
.g-btn--arrow.g-btn--white > a::after{
	background-color: var(--BLACK);
}
.g-btn--arrow.g-btn--black > a::after{
	background-color: var(--WHITE);
}
.g-btn--arrow.g-btn--green > a::after{
	background-color: var(--DARK01);
}
@media (hover: hover){
	.g-btn--arrow > a::after{
		transition: .3s;
	}
	.g-btn--arrow > a:hover::after{
		right: 8px;
	}
}
@media screen and (min-width: 768px){
	.g-btn--arrow > a::after{
		width: 33px;
		top: 35%;
		right: 15px;
	}
}
@media screen and (max-width: 767px){
	.g-btn--arrow > a::after{
		width: 28px;
		top: 37%;
		right: 20px;
	}
}
/* タイプ - return */
.g-btn--arrow.g-btn--return a::after{
	transform: rotate(180deg) translateX(5px);
	right: unset;
}
@media screen and (min-width: 768px){
	.g-btn--arrow.g-btn--return a::after{
		left: 10px;
	}
}
@media screen and (max-width: 767px){
	.g-btn--arrow.g-btn--return a::after{
		left: 10px;
	}
}
/* タイプ - anchor */
.g-btn--arrow.g-btn--anchor > a::after{
	transform: rotate(90deg);
}
@media screen and (min-width: 768px){
	.g-btn--arrow.g-btn--anchor > a::after{
		font-size: 12px;
		top: 35%;
		right: 10px;
	}
}
@media screen and (max-width: 767px){
	.g-btn--arrow.g-btn--anchor > a::after{
		font-size: 10px;
		top: 37%;
		right: 10px;
	}
}
/* -----------------タブ切り替え共通css----------------- */
.tab-nav{
	display: flex;
}
.tab-btn{
	flex: 1;
}
.tab-contents {
  height: 0;
  overflow: hidden;
  opacity: 0;
}
.tab-contents.show {
	cursor: auto;
  height: auto;
  overflow: unset;
  opacity: 1;
  transition: .5s opacity;
}
@media screen and (min-width: 768px){
	.tab-btn:hover{
		cursor: pointer;
	}
	.tab-btn.show{
		cursor: auto;
	}
}
/* -----------------ポップアップ共通css----------------- */
body.fixed {
	position: fixed;
	width: 100%;
	overflow: hidden;
}
.popup-overlay{
  display: none; 
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.4);
}
.popup-overlay.fixed{
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9998;
}
.popup-content{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: var(--WHITE);
}
.popup-overlay .popup-box{
	overflow-y: scroll;
}
.popup-overlay button.closePopup{
	position: absolute;
	width: fit-content;
	display: flex;
	align-items: center;
	z-index: 999;
}
.popup-overlay button.closePopup::after{
	content: "";
	display: inline-block;
	--ICON: url(../images/common/popup-close.svg);
	--MASK: var(--ICON) no-repeat center center / 100%;
	mask: var(--MASK);
	-webkit-mask: var(--MASK);
	background-color: var(--BLACK);
	aspect-ratio: 1/1;
}
@media screen and (min-width: 768px){
	.popup-overlay .popup-content{
		width: 95%;
		max-width: 900px;
	}
	.popup-overlay .popup-box{
		padding: 50px 30px;
		max-height: 90vh;
	}
	.popup-overlay button.closePopup{
		top: 16px;
		right: 12px;
		font-size: 14px;
		gap: 10px;
	}
	.popup-overlay button.closePopup::after{
		width: 20px;
	}
}
@media (hover: hover){
	.popup-overlay button.closePopup:hover{
		cursor: pointer;
	}
}
@media screen and (max-width: 767px){
	.popup-overlay .popup-content{
		width: 90%;
	}
	.popup-overlay .popup-box{
		padding: 30px 15px;
		max-height: 80vh;
	}
	.popup-overlay button.closePopup{
		top: 10px;
		right: 10px;
		font-size: 11px;
		gap: 3px;
	}
	.popup-overlay button.closePopup::after{
		width: 15px;
	}
}

/* -------------------g-slickArrow---------------------- */
[class*="g-slickArrow--"]{
	width: var(--SLICK_ARROW_SIZE);
  background-image: unset;
  border-radius: 50%;
  aspect-ratio: 1/1;
  display: inline-block;
	position: absolute;
	z-index: 2;
}
[class*="g-slickArrow--"]::before{
  content: "";
  display: inline-block;
  --ICON: url(/asset2025/images/common/slide-parts.svg);
  --MASK: var(--ICON) no-repeat center center;
  mask: var(--MASK);
  -webkit-mask: var(--MASK);
  aspect-ratio: 1/1;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.g-slickArrow--prev{
	left: var(--SLICK_ARROW_TO_BODY);
}
.g-slickArrow--next{
	right: var(--SLICK_ARROW_TO_BODY);
	transform: rotate(180deg);
}
.g-slickArrow--white{
  background-color: var(--WHITE);
}
.g-slickArrow--white::before{
  background-color: var(--BLACK);
}
.g-slickArrow--black{
  background-color: var(--BLACK);
}
.g-slickArrow--black::before{
  background-color: var(--WHITE);
}
@media (hover: hover){
  [class*="g-slickArrow--"]{
    transition: .3s;
  }
	[class*="g-slickArrow--"]:hover{
		cursor: pointer;
	}
  .g-slickArrow--white:hover{
    background-color: var(--BLACK);
  }
  .g-slickArrow--white:hover::before{
    background-color: var(--WHITE);
  }
  .g-slickArrow--black:hover{
    background-color: var(--BLACK);
  }
  .g-slickArrow--black:hover::before{
    background-color: var(--WHITE);
  }
}
@media screen and (min-width: 768px){
	.g-hasSlickArrow{
		--SLICK_ARROW_SIZE: clamp( 30px, 3.2vw, 40px);
		--SLICK_ARROW_TO_BODY: calc(0px - var(--SLICK_ARROW_SIZE) + var(--SLICK_GAP) - 5px);
	}
	[class*="g-slickArrow--"]::before{
		mask-size: 35%;
	}
}
@media screen and (max-width: 767px){
	.g-hasSlickArrow{
		--SLICK_ARROW_SIZE: 30px;
		--SLICK_ARROW_TO_BODY: calc(0px - var(--SLICK_ARROW_SIZE) + var(--SLICK_GAP) - 5px);
	}
	[class*="g-slickArrow--"]::before{
		mask-size: 40%;
	}
}
/* -------------------g-slickDots-------------------- */
.slick:has(.g-slickDots){
	margin-bottom: 0;
}
.g-slickDots{
	display: flex;
	justify-content: center;
	gap: 15px;
}
.g-slickDots li{
	aspect-ratio: 1/1;
	position: relative;
}
.g-slickDots button{
	font-size: 0;
	background-color: var(--GRAY02);
	aspect-ratio: 1/1;
	border-radius: 50%;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.g-slickDots .slick-active button{
	background-color: var(--BLACK)
}
@media screen and (min-width: 768px){
	.g-slickDots li{
		width: 15px;
		margin-top: 10px;
	}
	.g-slickDots button{
		width: 8px;
	}
}
@media screen and (max-width: 767px){
	.g-slickDots li{
		width: 15px;
		margin-top: 10px;
	}
	.g-slickDots button{
		width: 8px;
	}
}
/* -------------------bgcolor-------------------- */
.bgcolor--beige{
	background-color: var(--BEIGE01);
}
/* -------------------is-targetBlank-------------------- */
.is-targetBlank{
	display: inline-block;
	position: relative;
	padding-right: 17px;
}
.is-targetBlank::after{
	content: "";
	display: inline-block;
	--ICON: url(../images//common/icon_targerBlank.svg);
	--MASK: var(--ICON) no-repeat center center / 100%;
	mask: var(--MASK);
	-webkit-mask: var(--MASK);
	aspect-ratio: 1/1;
	width: 13px;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
}
.is-targetBlank--brown::after{
	background-color: var(--TXT_COLOR_BASE);
}
.is-targetBlank--white::after{
	background-color: var(--TXT_COLOR_WHITE);
}



/* --------------------g-customizeLink-------------------- */
.g-customizeLink{
	max-width: 650px;
	margin-inline: auto;
	position: relative;
	z-index:1;
}
@media (hover: hover){
	.g-customizeLink a:hover,
	.g-customizeLink a:hover img{
		opacity: 1 !important;
	}
	.g-customizeLink a img{
		transition: .3s;
	}
	.g-customizeLink a:hover img{
		transform: scale(1.1);
	}
}
@media screen and (min-width: 768px){
	.t-fv+.g-customizeLink{
		margin-block: var(--GAP_60) calc(0px - var(--GAP_30));
	}
}
@media screen and (max-width: 767px){
	.t-fv+.g-customizeLink{
		width: 95%;
		margin-block: 30px;
	}
}

/* .ft-fixedBnr__link調整 */
@media screen and (min-width: 768px){
	.ft-fixedBnr__link{
		padding: 4px 15px !important;
	}
}



/* g-interviews レイアウト変更 */
.g-interviews__list__thumb img{
	aspect-ratio: 3/2;
	object-fit: cover;
	border-radius: 10px;
}
.g-interviews__list__siteName{
	letter-spacing: 0;
	font-family: var(--FF_BASE_E);
}
.g-interviews__list__siteName small{
  display: block;
}
.g-interviews__list__button--prev{
  left: 0;
}
.g-interviews__list__button--next{
  transform: rotate(180deg) scale(1, -1);
  right: 0;
}
[class*="g-interviews__list__button--"]{
	aspect-ratio: 1/2;
  position: absolute;
  z-index: 2;
}
[class*="g-interviews__list__button--"]::after{
	content: "";
	display: inline-block;
	--MASK: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0idXRmLTgiPz4KPCEtLSBHZW5lcmF0b3I6IEFkb2JlIElsbHVzdHJhdG9yIDI3LjkuNiwgU1ZHIEV4cG9ydCBQbHVnLUluIC4gU1ZHIFZlcnNpb246IDkuMDMgQnVpbGQgNTQ5ODYpICAtLT4KPHN2ZyB2ZXJzaW9uPSIxLjEiIGlkPSLjg6zjgqTjg6Tjg7xfMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIiB4bWxuczp4bGluaz0iaHR0cDovL3d3dy53My5vcmcvMTk5OS94bGluayIgeD0iMHB4IgoJIHk9IjBweCIgdmlld0JveD0iMCAwIDE1MCAzMDAiIHN0eWxlPSJlbmFibGUtYmFja2dyb3VuZDpuZXcgMCAwIDE1MCAzMDA7IiB4bWw6c3BhY2U9InByZXNlcnZlIj4KPHN0eWxlIHR5cGU9InRleHQvY3NzIj4KCS5zdDB7ZmlsbDojRkZGRkZGO30KPC9zdHlsZT4KPGc+Cgk8Zz4KCQk8Zz4KCQkJPHBhdGggY2xhc3M9InN0MCIgZD0iTTcyLDE5NC43Yy0yLjMsMC00LjctMS02LjItM0wzNi4zLDE1NWMtMi40LTIuOS0yLjQtNy4xLDAtMTBsMjkuNS0zNi43YzIuOC0zLjQsNy44LTQsMTEuMi0xLjIKCQkJCWMzLjQsMi44LDQsNy44LDEuMiwxMS4yTDUyLjgsMTUwbDI1LjUsMzEuN2MyLjgsMy40LDIuMiw4LjUtMS4yLDExLjNDNzUuNSwxOTQuMSw3My44LDE5NC43LDcyLDE5NC43eiIvPgoJCTwvZz4KCTwvZz4KPC9nPgo8L3N2Zz4K) no-repeat center center / 100%;
	mask: var(--MASK);
	-webkit-mask: var(--MASK);
	background-color: var(--WHITE);
	width: 100%;
	aspect-ratio: 1/2;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
}
[class*="g-interviews__list__button--"]::before{
	content: "";
	display: inline-block;
	background: var(--BLACK);
	width: 70px;
	aspect-ratio: 1;
	border-radius: 50%;
	position: absolute;
	top: 0;
	z-index: -1;
}
.g-interviews__list__button--next::before{
	right: 0;
}
.g-interviews__list__button--prev::before{
	right: 0;
}
@media (hover: hover){
  [class*="g-interviews__list__button--"]:hover{
    cursor: pointer;
  }
	[class*="g-interviews__list__button--"]::before{
		transition: .3s;
	}
	[class*="g-interviews__list__button--"]:hover::before{
		transform: scale(1.2);
	}
  .g-interviews__list__scrollbar .swiper-scrollbar-drag:hover{
    cursor: pointer;
  }
    .g-interviews__list__scrollbar .swiper-scrollbar-drag::after{
    transition: .3s;
  }
  .g-interviews__list__scrollbar .swiper-scrollbar-drag:hover::after{
    background-color: var(--ORANGE02);
  }
}
@media screen and (min-width: 768px){
	.g-interviews__list{
		position: relative;
	}
	.g-interviews__list__thumb{
		margin-bottom: 20px;
	}
  .g-interviews__list__siteName{
    margin-bottom: 10px;
  }
	.g-interviews__list__siteName{
  font-size: var(--FZ_20);
    margin-bottom: 10px;
		white-space: wrap;
  }
  .g-interviews__list__siteName small{
    font-size: 14px;
  }
	.g-interviews__list__ttl{
		font-size: 14px;
	}
	[class*="g-interviews__list__button--"]{
    width: 35px;
    top: 35%;
  }
  .g-interviews__list__scrollbar{
    position: relative;
    width: 95%;
    max-width: 700px;
    height: 30px;
    margin: var(--GAP_20) auto 0;
  }
  .g-interviews__list__scrollbar::before{
    content: "";
    display: inline-block;
    background: var(--GRAY07);
    width: 100%;
    height: 2px;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .g-interviews__list__scrollbar .swiper-scrollbar-drag{
    width: 50px;
    top: 0;
    height: 30px;
    position: absolute;
    background: unset;
  }
  .g-interviews__list__scrollbar .swiper-scrollbar-drag::after{
    content: "";
    display: inline-block;
    background: var(--BLACK);
    width: 100%;
    height: 5px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
  }
}
@media screen and (max-width: 767px){
  .g-interviews__list{
    display: flex;
    overflow-x: auto;
    white-space: nowrap;
    padding-left: calc((100% - var(--INNER_WIDTH)) / 2);
    -ms-overflow-style: none;/* IE, Edge 対応 */
    scrollbar-width: none;/* Firefox 対応 */
  }
  .g-interviews__list::-webkit-scrollbar{
    display: none;
  }
  .g-interviews__list .swiper-wrapper{
    display: contents;
  }
  .g-interviews__list article{
    --WIDTH: 180px;
    min-width: var(--WIDTH);
    max-width: var(--WIDTH);
    flex: 0 0 auto;
    margin-right: 23px;
  }
	.g-interviews__list__thumb{
		margin-bottom: 15px;
	}
  .g-interviews__list__siteName{
    font-size: 14px;
    margin-bottom: 10px;
		white-space: wrap;
		font-family: var(--FF_BASE_D);
  }
  .g-interviews__list__siteName small{
    font-size: 12px;
  }
  .g-interviews__list__ttl{
  	display: none;
  }
}




/* -------------------s-nextLabel-------------------- */
.s-nextLabel{
  position: relative;
  width: 100%;
  z-index: 4;
  background-color: var(--ORANGE01);
  position: fixed;
  bottom: 0;
  transform: translateY(150%);
  left: 0;
  transition: .5s ease-in-out;
}
.s-nextLabel.is-fixed{
  transform: translateY(0%);
}
.s-nextLabel__container a{
  display: block;
  position: relative;
}
.s-nextLabel__container a::after{
  content: "";
  display: inline-block;
  background: url(/asset2025/images/top/ill_about.svg) no-repeat center center / 100%;
  aspect-ratio: 300/216;
  position: absolute;
  bottom: 0;
  z-index: 3;
}
.s-nextLabel__body{
  display: flex;
  align-items: center;
}
.s-nextLabel__label{
  font-family: var(--FF_EN);
  font-weight: 700;
  letter-spacing: 0.05em;
}
.s-nextLabel__arrow{
  display: grid;
  grid-template-columns: repeat(3,1fr);
}
.s-nextLabel__arrow span {
  display: inline-block;
  aspect-ratio: 1/2;
  background-color: var(--BLACK);
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  animation: blink 3s ease-in-out infinite;
  opacity: 0.1;
}
.s-nextLabel__arrow span:nth-child(1) {
  animation-delay: 0.5s;
}
.s-nextLabel__arrow span:nth-child(2) {
  animation-delay: 1s;
}
.s-nextLabel__arrow span:nth-child(3) {
  animation-delay: 1.5s;
}
@keyframes blink {
  0%, 100% {
    opacity: 0.1;
  }
  50% {
    opacity: 1;
  }
}
.s-nextLabel__heading{
  display: flex;
  font-weight: bold;
  align-items: baseline;
}
.s-nextLabel__heading span{
  font-family: var(--FF_EN);
  line-height: 1;
}
.s-nextLabel__heading small{
  display: inline-block;
  font-family: var(--FF_BASE_H);
}
@media (hover: hover){
  .s-nextLabel__container a:hover{
    opacity: 1;
  }
  .s-nextLabel__container a::after{
    transition: .3s;
  }
  .s-nextLabel__container a:hover::after{
    right: -20px;
  }
}
@media screen and (min-width: 768px){
  .s-nextLabel__container a{
    padding-block: var(--GAP_10);
  }
  .s-nextLabel__container a::after{
    width: 200px;
    right: 0;
  }
  .s-nextLabel__body{
    padding-left: var(--GAP_50);
  }
  .s-nextLabel__label{
    font-size: var(--FZ_20);
    margin-right: var(--GAP_40);
  }
  .s-nextLabel__arrow{
    width: 60px;
    gap: 15px;
    margin-right: var(--GAP_30);
  }
  .s-nextLabel__heading{
    gap: var(--GAP_15);
  }
  .s-nextLabel__heading span{
    font-size: var(--FZ_40);
  }
  .s-nextLabel__heading small{
    font-size: var(--FZ_14);
    position: relative;
    top: -5px;
  }
}
@media screen and (max-width: 767px){
  .s-nextLabel__container a{
    padding-block: 15px;
  }
  .s-nextLabel__container a::after{
    width: 100px;
    right: 10px;
  }
  .s-nextLabel__body{
    padding-left: 15px;
  }
  .s-nextLabel__label{
    font-size: 12px;
    margin-right: 8px;
  }
  .s-nextLabel__arrow{
    width: 25px;
    gap: 5px;
    margin-right: 10px;
  }
  .s-nextLabel__heading{
    gap: 5px;
    letter-spacing: 0.05em;
  }
  .s-nextLabel__heading span{
    font-size: 24px;
  }
  .s-nextLabel__heading small{
    font-size: 10px;
    position: relative;
    top: -2px;
  }
}
