/*============================================================
BA Insight用
============================================================*/
:root{
  /*--boost-container: 1200px; /* 右寄せの基準幅（中央コンテナ想定） */
  /*--gutter-boost: clamp(24px, (100vw - var(--boost-container))/2, 72px);*/
  /*--right-max: 960px;        /* ロゴ／メッセージの最大幅 */
}

section div.secWrap h2{
	color:var(--color-text);
}


/****************
メイン調整
****************/
main{
	margin-bottom: 0;
}

/****************
ヒーロー
****************/
section#hero {
  background: #FFFFFF url(/assets/images/insight/insight_hero_bg.jpg) no-repeat 50% center;
	background-size: cover;
}

section#hero div.heroRight div.serviceLogo{
	margin:0 auto 20px auto;
	text-align:center;
}
section#hero div.heroRight div.serviceLogo img {
	width:100%;
	max-width:449px;
	height:auto;
	filter:
		drop-shadow(0 0 8px rgba(255, 255, 255, .95))
		drop-shadow(0 0 24px rgba(255, 255, 255, .75));
}

/****************
概要
****************/
section div.secBox.issueBox{
	display:flex;
	flex-direction:column;
	gap:24px;
	width:100%;
}

section div.issueBubble{
	display:flex;
	flex-direction:column;
	gap:12px;
	width:100%;
}

section div.bubbleBox{
	padding:14px 16px;
	background:var(--color-bg-purple);
	border-left:4px solid var(--color-blue);
	border-radius:8px;
}

section div.bubbleBox p{
	margin:0;
	text-align:left;
	font-weight:700;
	line-height:1.7;
}

section div.issueLead{
	display:flex;
	flex-direction:column;
	gap:24px;
	align-items:center;
	width:100%;
}

section div.issueLeft{
	width:100%;
}

section div.issueLeft p{
	margin:0 0 1.2em;
	line-height:1.9;
	text-align:left;
}

section div.issueLeft p span.big{
	font-size: 120%;
	font-weight: 700;
}

section div.issueRight{
	width:100%;
	text-align:center;
}

section div.issueRight img{
	width:100%;
	max-width:220px;
	height:auto;
	margin:0 auto;
}

section div.issueArw{
	display:flex;
	justify-content:center;
	align-items:center;
	margin:20px auto;
}

section div.issueArw img{
	width:48px;
	height:auto;
}

section div.issuePropose{
	position:relative;
	width:100%;
	margin:0 auto;
	padding:32px 24px;
	background:#fff;
	border-radius:0;
	box-shadow:none;
	text-align:center;
	font-size:clamp(1.1rem, 2vw, 1.5rem);
	font-weight:700;
	line-height:1.8;
}
/* 左上の括弧 */
section div.issuePropose::before{
	content:"";
	position:absolute;
	left:0;
	top:0;
	width:48px;
	height:48px;
	border-top:2px solid var(--color-logo-insight);
	border-left:2px solid var(--color-logo-insight);
}

/* 右下の括弧 */
section div.issuePropose::after{
	content:"";
	position:absolute;
	right:0;
	bottom:0;
	width:48px;
	height:48px;
	border-right:2px solid var(--color-logo-insight);
	border-bottom:2px solid var(--color-logo-insight);
}
section div.issueTitle{
	display:flex;
	justify-content:center;
	align-items:flex-end;
	gap:4px;
	margin-bottom:8px;
	line-height:1;
}

section div.issuePropose .insightLogo{
	display:block;
	width:clamp(140px, 32vw, 190px);
	height:clamp(40px, 8vw, 54px);
	background:
		url(/assets/images/insight/insight_hero_logo.png)
		no-repeat
		center center / contain;
	text-indent:-9999px;
	overflow:hidden;
}

section div.issuePropose .wa{
	display:block;
	font-size:clamp(1rem, 2vw, 1.25rem);
	font-weight:700;
	line-height:1;
	/*padding-bottom:5px;*/
}

/****************
仕組み
****************/
section#scheme{
	background:var(--color-bg-green);
	padding-bottom: 40px !important;
}
section#scheme div.schemeImage img{
	margin:20px auto 40px auto;
}
section#scheme div.schemeBox{
	display:flex;
	flex-direction:column;
	gap:12px;
	width:100%;
	margin:32px auto 0;
	padding:0;
}

section#scheme div.flow{
	position:relative;
	display:grid;
	grid-template-columns:56px 1fr;
	align-items:center;
	gap:14px;
	width:100%;
	max-width: 80%;
	margin: 0 auto;
	aspect-ratio:auto;
	padding:16px 18px;
	border:2px solid var(--color-logo-insight);
	border-radius:12px;
	background:#fff;
	text-align:left;
}

section#scheme div.flow::before{
	counter-increment:scheme;
	content:"0" counter(scheme);
	color:var(--color-logo-insight);
	font-size:1.4rem;
	font-weight:700;
	line-height:1;
}

section#scheme div.schemeBox{
	counter-reset:scheme;
}

section#scheme div.flowImage{
	grid-column:1;
	grid-row:1 / span 2;
	width:42px;
	margin:0 auto;
}

section#scheme p.flowTitle{
	grid-column:2;
	margin:0;
	font-size:1rem;
	font-weight:700;
	line-height:1.5;
	text-align:left;
}

/* SPでは矢印は縦方向に表示 */
section#scheme div.schemeArw{
	width:0;
	height:0;
	margin:0 auto;
	border-left:10px solid transparent;
	border-right:10px solid transparent;
	border-top:14px solid var(--color-logo-insight);
}

/****************
分かること
****************/
section#package{
	position:relative;
	/*background:var--color-bg-gray);*/
	padding-top:72px;
	padding-bottom:72px;
	padding-bottom: 40px !important;
}

/* 上部の白い下向き三角 */
section#package::before{
	content:"";
	position:absolute;
	top:0;
	left:50%;
	transform:translateX(-50%);
	width:0;
	height:0;
	border-left:110px solid transparent;
	border-right:110px solid transparent;
	border-top:46px solid var(--color-bg-green);
}

section#package h2{
	/*color:var(--color-white);*/
}

section#package div.secBox > p{
	/*color:var(--color-white);*/
}

section#package div.secBox > p:last-child{
	margin-bottom:0;
}


/* カード*/
section#package div.packBox{
	display:flex;
	flex-direction:column;
	gap:28px;
	margin-top:40px;
}

section#package div.packDetail{
	background:var(--color-white);
	color:var(--color-black);
	width:100%;
	border: 1px solid var(--color-lightgray);
	border-radius: 4px;
	background: var(--color-white);
}

section#package div.packIcon{
	padding:24px;
	text-align:center;
}

section#package div.packIcon img{
	height:auto;
	margin:0 auto;
}

section#package div.packSub{
	text-align:center;
	font-size: clamp(0.8rem, 1.0vw, 1.1rem);
	font-weight:700;
}

section#package div.packExp{
	padding:0 28px 24px;
}

section#package div.packExp h3{
	margin:0 0 16px;
	text-align:center;
	font-size: clamp(1.2rem, 1.3vw, 1.4rem);
	font-weight:700;
	border-bottom: 1px solid var(--color-lightgray);
	padding: 0 0 12px;
}

section#package div.packExp h4{
	/*margin:0 0 16px;*/
	font-size: clamp(0.8rem, 0.9vw, 0.95em);
	font-weight:700;
	color:var(--color-logo-insight);
}

section#package div.packExp ul.packList{
	padding:0;
	margin:0;
	list-style:none;
}
section#package div.packExp ul.packList li{
	position:relative;
	padding-left:1.2em;
	font-size: 83%;
}
section#package div.packExp ul.packList li::before{
	content:"●";
	position:absolute;
	left:0;
	top:0;
	color:var(--color-logo-insight);
	font-size:.9em;
}


/****************
プラン
****************/
section#plan{
	background:var(--color-bg-green);
}

section#plan .secBox > p{
	text-align:center;
	line-height:1.8;
	font-weight:600;
}

/* swipe guide */
section#plan div.planSwipe{
	display:block;
	margin:0 0 12px;
	text-align:center;
	font-size:.85rem;
	font-weight:700;
	color:var(--color-logo-insight);
	animation:swipeGuide 1.6s ease-in-out infinite;
}

@keyframes swipeGuide{
	0%{ transform:translateX(0); }
	50%{ transform:translateX(6px); }
	100%{ transform:translateX(0); }
}

/* plan cards SP */
section#plan div.planBox{
	display:flex;
	gap:16px;
	overflow-x:auto;
	padding:4px 20px 18px;
	/*margin-inline:-20px;*/
	scroll-snap-type:x mandatory;
	-webkit-overflow-scrolling:touch;
}

section#plan div.planDetail{
	flex:0 0 85%;
	scroll-snap-align:center;

	background:var(--color-white);
	border:1px solid #cfcfcf;
	border-radius:8px;
	padding:24px 20px;
}

section#plan div.planDetail h3{
	color:var(--color-logo-insight);
	font-size:2.2rem;
	line-height:1;
	text-align:center;
	font-weight:700;
	white-space:nowrap;
}

section#plan p.planName{
	margin-top:4px;
	text-align:center;
	color:#bdbdbd;
	font-weight:700;
	font-size: 80%;
}

section#plan div.target,
section#plan div.planPoint{
	margin-top:22px;
}

section#plan div.target h4,
section#plan div.planPoint h4{
	background:var(--color-logo-insight);
	color:var(--color-white);
	border-radius:999px;
	padding:6px 12px;
	text-align:center;
	font-size:.9rem;
	font-weight:700;
}

section#plan div.target p{
	margin-top:12px;
	font-weight: 700;
	font-size: 80%;
	min-height: 5rem;
}

section#plan div.planPoint ul{
	margin:12px 0 0;
	padding:0;
	list-style:none;
}

section#plan div.planPoint li{
	position:relative;
	padding-left:18px;
	font-size: 80%;
}

section#plan div.planPoint li::before{
	content:"";
	position:absolute;
	left:0;
	top:.65em;
	width:8px;
	height:8px;
	border-radius:50%;
	background:var(--color-logo-insight);
}

/* initial cost */
section#plan div.planInitial{
	display:flex;
	flex-direction:column;
	gap:12px;

	background:var(--color-white);
	border:1px solid #cfcfcf;
	border-radius:8px;
	padding:24px 20px;
	text-align:center;
	margin: 2rem auto 0;
}

section#plan div.initialTitle{
	color:var(--color-logo-insight);
	font-weight:700;
}

section#plan div.initialPrice{
	font-size:3.2rem;
	font-weight:800;
	line-height:1;
}

section#plan div.initialPrice span.en{
	font-size:1.3rem;
	margin-left:4px;
	margin-bottom: -16px;
}

section#plan div.initialExp p{
	text-align:left;
	font-weight:700;
	margin: 0;
}

section#plan ul.notice{
	margin:8px 0 0;
	padding:0;
	list-style:none;
}

section#plan ul.notice li{
	position:relative;
	padding-left:1.2em;
	font-size:72%;
	text-align:left;
}

section#plan ul.notice li::before{
	content:"※";
	position:absolute;
	left:0;
	top:0;
}



/****************
ブレークポイント
****************/
@media (max-width: 399.98px) {}

@media (min-width: 400px) {}

@media (min-width: 640px) {
	/* お悩み */
	section div.secBox.issueBox{
		gap:40px;
		max-width: 860px;
		margin: 0 auto;
	}

	section div.issueLead{
		flex-direction:row;
		justify-content:center;
		align-items:center;
		gap:40px;
	}

	section div.issueLeft{
		flex:1 1 auto;
		max-width:720px;
	}

	section div.issueLeft p{
		text-align:center;
	}

	section div.issueRight{
		flex:0 0 220px;
		width:220px;
	}

	section div.issueRight img{
		max-width:210px;
	}

	section div.issueArw{
		margin:24px auto;
	}

	section div.issueArw img{
		width:56px;
	}

	section div.issuePropose{
		width:min(760px, 100%);
		padding:36px 48px;
		font-size:clamp(1.2rem, 2vw, 1.6rem);
	}

	section div.issuePropose::before,
	section div.issuePropose::after{
		width:56px;
		height:56px;
	}

	section div.issuePropose .boostLogo{
		width:clamp(170px, 20vw, 230px);
		height:clamp(48px, 5vw, 64px);
	}

	section div.issuePropose .wa{
		font-size:1.25rem;
		padding-bottom:7px;
	}
	
	/* 仕組み */
	section#scheme div.schemeBox{
		display:flex;
		flex-direction:row;
		justify-content:center;
		align-items:center;
		gap:14px;
		max-width:1000px;
		counter-reset:none;
	}

	section#scheme div.flow{
		display:flex;
		flex-direction:column;
		justify-content:center;
		align-items:center;

		flex:0 0 clamp(120px, 15vw, 180px);
		width:clamp(120px, 15vw, 180px);
		aspect-ratio:1 / 1;
		padding:0;
		border:2px solid var(--color-logo-insight);
		border-radius:50%;
		background:var(--color-white);

		text-align:center;
	}

	section#scheme div.flow::before{
		content:none;
	}

	section#scheme div.flowImage{
		width:clamp(44px, 5vw, 70px);
		margin:0 auto 8px;
	}
	section#scheme div.flowImage.ajust img{
		margin: 16px auto -16px auto;
	}
	
	section#scheme p.flowTitle{
		margin:0;
		font-size: clamp(.8rem, .9vw, 1.0rem);
		text-align:center;
	}
	
	section#scheme div.schemeArw{
		flex:0 0 auto;
		border-top:12px solid transparent;
		border-bottom:12px solid transparent;
		border-left:18px solid var(--color-logo-insight);
		border-right:none;
	}
	
	/* パッケージ */
	section#package{
		padding-top:92px;
		padding-bottom:92px;
	}

	section#package::before{
		border-left:140px solid transparent;
		border-right:140px solid transparent;
		border-top:60px solid var(--color-bg-green);
	}

	section#package div.packBox{
		flex-direction:row;
		/*gap:40px;*/
		align-items:stretch;
	}

	section#package div.packDetail{
		flex:1 1 0;
		min-width:0;
		display:flex;
		flex-direction:column;
	}

	section#package div.packExp{
		flex:1;
	}

	section#package div.packIcon img{
	}
	/* プラン */
	section#plan div.planSwipe{
		display:none;
	}

	section#plan div.planBox{
		display:grid;
		grid-template-columns:repeat(2, minmax(0, 1fr));
		gap:20px;
		overflow:visible;
		padding:0;
		margin-inline:0;
	}

	section#plan div.planDetail{
		min-width:0;
		flex:auto;
		padding:24px 18px;
	}

	section#plan div.planDetail h3{
		font-size:1.8rem;
		overflow-wrap:anywhere;
	}
	
	section#plan div.planInitial{
		flex-direction:row;
		align-items:center;
		text-align:left;
		padding:24px 32px;
	}

	section#plan div.planInitial{
		display:flex;
		flex-direction:row;
		align-items:stretch;
		text-align:left;
		padding:24px 32px;
	}

	section#plan div.initialTitle{
		position:relative;
		flex:0 0 20%;
		display:flex;
		align-items:center;
		justify-content:center;
		color:var(--color-logo-insight);
		font-weight:700;
		text-align:center;
	}

	section#plan div.initialTitle::after{
		content:"";
		position:absolute;
		top:0;
		right:0;
		bottom:0;
		width:1px;
		background:var(--color-logo-insight);
	}

	section#plan div.initialPrice{
		flex:0 0 18%;
		display:flex;
		align-items:center;
		justify-content:center;
		text-align:center;
	}

	section#plan div.initialExp{
		flex:1;
		display:flex;
		flex-direction:column;
		justify-content:center;
		padding-left:24px;
	}
	section#plan div.initialExp p{
		text-align:left;
	}
}
@media (min-width: 860px) {
	/* プラン */
	section#plan div.planBox{
		grid-template-columns:repeat(4, minmax(0, 1fr));
	}
	section#plan div.planDetail h3{
		font-size:2rem;
	}
}

@media (min-width: 960px) {
	/* パッケージ */
	section#package div.packBox{
		/*gap:56px;*/
	}
	/* プラン */
	section#plan div.planBox{
		gap:22px;
	}
	section#plan div.planDetail{
		padding:28px 22px;
	}
	section#plan div.planDetail h3{
		font-size:2.35rem;
	}
}

@media (min-width: 1200px) {}
