@charset "UTF-8";

/* =======================================================================================
	PC
======================================================================================= */

/* 初期設定 */

html { overflow-x: visible;}

body {
	font-size: 1.8rem;
	line-height: 1.8;
}

img {
	width: auto;
	transition: 0.2s;
}

svg { vertical-align: bottom; }

ul, ol { list-style: none; }

a {
	color: #3687bc;
	transition: 0.3s;
	text-decoration: none;
}
a:focus-visible {
	outline: -webkit-focus-ring-color auto 1px;
}
html, p { color: #4a4a4a; }
h2, h3 { color: #4a4a4a; }

/* レイアウト */

.site-main { margin: 0; }
.str-outer-full:nth-child(1)>.str-inner { max-width: 1200px; }
.str-outer-full .nav-location { padding: 0; }

.mainArea {
	max-width: 1920px;
	min-width: 360px;
	background: url(../images/bg.png);
	margin: 0 auto;
	padding-bottom: 80px;
}
.section-inner {
	width: 1200px;
	margin: 0 auto;
}
@media screen and (max-width: 1199px) {
	.str-outer-full .nav-location { padding: 0 10px; }
	.section-inner {
		width: calc(100% - 70px);
		margin: 0 auto;
	}
}

/* ファーストビュー */

.fv { margin-bottom: 80px; }
.fv-inner {
	width: 100%;
	margin: 0 auto;
}
h1.fv-img { margin: 0; }
.fv-img img { width: 100%; }

/* 共通　*/

/* タイトル　*/

.ttl {
	max-width: 615px;
	width: 100%;
	margin: 0 auto 80px;
	background: #26499d;
	color: #fff;
	font-size: 32px;
	text-align: center;
	position: relative;
}
.ttl:after,.ttl::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 0 58px 20px;
}
.ttl:after {
	right: 0;
	border-color: transparent transparent #fff transparent;
}
.ttl::before {
	left: -20px;
	border-color: transparent transparent #26499d transparent;
}

/* 白いボックス　*/

.section-box {
	padding: 100px 80px;
	background: #fff;
	border-radius: 25px;
}
.section-box:not(:last-child) { margin-bottom: 80px; }

/*各セクションエリア*/

.section-area:not(:last-child) { padding-bottom: 100px; }

/* ボタン　*/

.apply-btn-text {
	color: #af1369;
	font-weight: bold;
	font-size: 24px;
	text-align: center;
	margin-bottom: 10px;
}
.apply-btn-click {
	display: block;
	max-width: 600px;
	width: 100%;
	padding: 20px;
	margin: auto;
	background: #0f1ed2;
	border-radius: 15px;
	color: #fff;
	font-weight: bold;
	font-size: 28px;
	text-align: center;
	position: relative;
}
.apply-btn-click::before {
	content: "";
	background: url(../images/icon_check.png) no-repeat center center / cover;
	width: 40px;
	height: 40px;
	position: absolute;
	left: 20px;
	top: 50%;
	transform: translateY(-50%);
}
.apply-btn-click::after {
	content: "";
	background: url(../images/icon_arrow.png) no-repeat center center / cover;
	width: 90%;
	height: 35px;
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	bottom:  15px;
}

/* リード文*/

.read-img { margin-bottom: 40px; }
.read_text {
	text-align: center;
	font-size: 24px;
	font-weight: bold;
}
.new-line-pc { display: block; }

/* インターシップの魅力 */

.point-list {
	display: flex;
	gap: 40px;
}
.point-item {
	width: calc(100% / 3 - 20px);
	padding: 50px 20px 20px;
	background: #eaf6fd;
	border-radius: 12px;
	position: relative;
}
figure.point-img {
	position: absolute;
	top: -50px;
	left: 50%;
	transform: translateX(-50%);
	margin: 0;
}
.point-ttl {
	width: 224px;
	margin: 0 auto 20px;
	color: #163c69;
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	background: linear-gradient(transparent 50%, #efec64 50%);
}
.point-sub-ttl {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 50px;
	margin-bottom: 20px;
	text-align: center;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.5;
	color: #163c69;
}

/* 多彩なテーマ設定 */

.theme-list {
	display: flex;
	flex-wrap: wrap;
	gap: 60px 40px;
	padding-bottom: 40px;
}
.theme-item { width: calc(100% / 2 - 20px); }
figure.theme-img { margin: 0 0 20px; }
.theme-img img {
	width: 100%;
	height: 240px;
	border-radius: 12px;
	object-fit: cover;
	object-position: center center;
}
.theme-ttl {
	margin-bottom: 20px;
	text-align: center;
	font-size: 18px;
	font-weight: bold;
}
.theme-note {
	padding-bottom: 60px;
	text-align: center;
	font-size: 16px;
}

/* 参加者からの声 */

.voice-list {
	display: flex;
	flex-wrap: wrap;
	gap: 40px 40px;
}
.voice-item {
	display: flex;
	align-items: center;
	gap: 20px;
	width: calc(100% / 2 - 20px );
}
figure.voice-icon { margin: 0;}
.voice-icon { width: 100px; }
.voice-text {
	width: calc(100% - 120px);
	padding: 20px;
	position: relative;
	background: #eaf6fd;
}
.voice-text:before {
	right: 100%;
	top: 50%;
	border: solid transparent;
	content: "";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
}
.voice-text:before {
	border-right-color: #eaf6fd;
	border-width: 10px 20px;
	margin-top: 10px;
}

/* FAQ　*/

.faq {
	display: flex;
	flex-wrap: wrap;
}
.faq-q,.faq-a {
	width: 100%;
	font-size: 18px;
}
.faq-q {
	margin-bottom: 10px;
	padding: 10px 10px 10px 40px;
	position: relative;
}
.faq-q:before {
	content: "";
	background: url(../images/icon_q.png) no-repeat center center / cover;
	width: 30px;
	height: 30px;
	position: absolute;
	left: 0;
}
.faq-a {
	margin-bottom: 30px;
	padding: 10px;
	background: #eff2f6;
	border-radius: 12px;
	color: #4a4a4a;
}

/* 参加までのステップ　*/

figure.step-flow {
	margin: 0 0 80px;
}
.step-area {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 40px;
	margin: 60px 0;
}
.step-ttl {
	width: 134px;
	background: #1d2b55;
	border-radius: 10px;
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	color: #fff;
}
.step-content { width: calc(100% - 134px - 40px); }

.step-days {
	color: #0f1ed2;
	font-size: 32px;
	font-weight: bold;
}
.step-note {
	font-size: 14px;
}
.step-text {
	font-size: 18px;
	font-weight: bold;
}

/* =======================================================================================
	hover
======================================================================================= */

@media (hover: hover) {
	a:hover img { opacity: 0.8; }
	a:hover {
		color: #000;
		transition: 0.3s;
	}
	.apply-btn-click:hover {
		color: #fff;
		background: #3f4bdb;
		transition: background-color;
	}
}

/* =======================================================================================
	SP/TB
======================================================================================= */

@media screen and (max-width: 1199px) {

/* 初期設定 */

body { font-size: 1.6rem; }

img {
	width: 100%;
	max-width: 100%;
	height: auto;
	vertical-align: top;
}

img.new-window {
	width: auto;
	max-width: none;
}

/* レイアウト */

.fv { margin-bottom: 60px; }
.mainArea { padding-bottom: 40px; }
.read_text { font-size: 18px; }
.section-box { padding: 50px 40px; }
.section-area:not(:last-child) { padding-bottom: 50px; }
.ttl {
	margin: 0 auto 50px;
	font-size: 24px;
}
.ttl.diff { margin: 0 auto 80px; }
.ttl:after, .ttl::before { border-width: 0px 0 43px 20px; }
.point-list { gap: 20px; }
.point-item { width: calc(100% / 3 - 10px); }
.point-ttl { font-size: 18px; }
.point-sub-ttl {
	height: 50px;
	margin-bottom: 10px;
	font-size: 16px;
}
.theme-ttl { font-size: 16px; }

}

@media screen and (max-width: 979px) {
.point-list {
	flex-direction: column;
	gap: 80px;
}
.point-item { width: 100%; }
.theme-item { width: 100%; }
.voice-list { flex-direction: column; }
.voice-item { width: 100%; }
.voice-text:before { margin-top: -10px; }
.theme-note { padding-bottom: 40px; }
.faq-q, .faq-a { font-size: 16px; }
.step-ttl { font-size: 18px; }
.step-days { font-size: 24px; }
.step-area { margin-bottom: 40px; }
.apply-btn-text { font-size: 18px; }
.apply-btn-click { font-size: 24px; }
.apply-btn-click::after {
	content: "";
	background: none;
	width: auto;
	height: auto;
	position: static;
	transform: none;
	bottom:  0;
}

}

/* =======================================================================================
	SP
======================================================================================= */

@media screen and (max-width: 639px) {

/* 初期設定 */

body { font-size: 1.4rem; }

/* レイアウト */

.fv { margin-bottom: 40px; }
.section-inner {
	width: calc(100% - 40px);
	margin: 0 auto;
}
.section-box { padding: 25px 20px; }
.section-box:not(:last-child) { margin-bottom: 40px; }
.read_text {
	font-size: 16px;
	text-align: left;
}
.new-line-pc {
	display: inline;
	text-align: left;
}
.ttl {
	width: 260px;
	margin: 0 auto 35px;
	font-size: 20px;
}
.ttl:after, .ttl::before { border-width: 0px 0 36px 20px; }
.point-item { padding: 40px 20px 20px; }
.point-ttl { margin: 0 auto 10px; }
.theme-list { gap: 30px 0; }
.theme-ttl { margin-bottom: 10px; }
.theme-note {
	padding-bottom: 30px;
	font-size: 12px;
}
.apply-btn-text {
	font-size: 16px;
	text-align: left;
}
.apply-btn-click { padding: 20px 5px; }
.apply-btn-click::before {
	width: 20px;
	height: 20px;
}
.apply-btn-click {  font-size: 18px; }
.apply-btn-click span { display: block; }
.apply-btn-click::after {
	height: 15px;
	bottom: 15px;
}
.voice-icon { width: 70px; }
.voice-text {
	width: calc(100% - 70px);
	padding: 10px;
}
.voice-list { gap: 15px 0; }
.step-area { gap: 15px; }
.step-ttl {
	width: 100%;
	font-size: 16px;
}
.step-content { width: 100%; }
.step-days { font-size: 20px; }
.step-text { font-size: 16px; }
.faq-q, .faq-a { font-size: 14px; }

}