@charset "UTF-8";
/* CSS Document */

/*
	Reset CSS
-----------------------------------------------------------------------------------------------*/
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section, main{
	display: block;
}

html{
	margin:0;
	padding:0;
	font-size: 62.5%;
}
body{
	margin:0 auto;
	padding:0;
	text-size-adjust: 100%;
}
p{
	line-height: 170%;
}
ul li,ol li{
	list-style: none;
}
/* 打ち消し用 */
li > ul{
	margin-top:0;
}
blockquote, q{
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after{
	content: '';
	content: none;
}
a{
	color:#333;
	text-decoration:none;
	transition: all 0.3s;
}
a:link{
	color:#333;
}
a:visited{
	color:#333;
}
a:hover{
	text-decoration:none;
}
img{
	border: none;
	vertical-align: top;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}
table{
	border-collapse: collapse;
	border-spacing: 0;
}
*,*::before,*::after{
	box-sizing: border-box;
}

/* iPad背景切れ対策 */
@media screen and (min-width: 767px){
	body{
		min-width: 1200px;
	}
}


/* 表示切替 */
.switch{
	visibility: hidden;
}
.sp{
	display: none;
}

@media screen and (max-width: 767px){
	body{
		-webkit-text-size-adjust:100%;
	}
	img{
		width:100%;
	}
	.pc{
		display:none;
	}
	.sp{
		display:block;
	}
	br.sp{
		display:inline-block;
	}
}
/*
	main
-----------------------------------------------------------------------------------------------*/
#main {
	color:#333;
	font-size: 1.4em;
	position: relative;
	width: 100%;
	padding:0;
	font-weight: 400;
}

#main *{
	font-family: 'Noto Sans JP', 'Yu Gothic', YuGothic, 'Hiragino Kaku Gothic ProN', Meiryo, sans-serif;
}
@media screen and (max-width: 767px){
	#main{
		font-size: 1.4rem;
	}
}

/*
	header
.headerOut{
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	height: 70px;
	background-color: #fff;
	font-feature-settings: "palt";
	padding: 15px 20px;
}
.headerOut a:hover{
	opacity: 0.7;
}
.headerLogo{
	display: flex;
	flex-direction: row-reverse;
	align-items: center;
}
.headerLogo a p {
	color: #fff;
	font-weight: bold;
}
.headerBtn {
	display: flex;
	align-items: center;
	justify-content: center;
	background-color:#90C320;
	width: 180px;
	height: 40px;
	position: relative;
	margin-right: 22px;
}
.headerBtn a {
	color: #fff;
	font-weight: bold;
	display: block;
}
.headerBtn::after {
	position: absolute;
	content: "";
	width: 8px;
	height: 8px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	opacity: 0.5;
	top:50%;
	right: 16px;
	transform:  rotate(45deg)translateY(-75%);
	transition: right 0.3s;
}
.headerBtn:hover::after {
	right: 12px;
}
.headerLogo img{
	width: 206px;
}
@media screen and (max-width: 767px){
	.headerOut {
		height: 48px;
		overflow: hidden;
		padding: 10px 8px; 
	}
	.headerOut > .logo {
		width: 160px;
	}
	.headerLogo {
		flex-direction: column;
		justify-content: center;
		align-items: center;
		padding-top: 8px;
	}
	.headerLogo p a {
		margin-bottom: 4px;
	}
	.headerBtn {
		width: 95px;
		height: 15px;
		margin-right: 0;
		white-space: nowrap;
	}
	.headerLogo img {
		width: 85px;
	}
	.headerLogo > p{
		line-height: 0;
		display: inline-block;
		margin: 0 0 5px 0;
	}
	.headerBtn::after {
		width: 3px;
		height: 3px;
		border-top: 1px solid #fff;
		border-right: 1px solid #fff;
		right: 5px;
	}
}
-----------------------------------------------------------------------------------------------*/

/* dayArea 配信開始の日付
-----------------------------------------------------------------------------------------------*/
.dayArea{
	width: 100%;
	margin: 0 auto;
	padding: 30px 0;
	text-align: center;
	font-size: 2.4rem;
	font-weight: bold;
	background: #0196b4;
}
.dayTxt{
	color: #fff;
	letter-spacing: 0.02em;
	line-height: 180%;
}
.dayTxt .colorGr{
	font-size: 3.4rem;
}
@media screen and (max-width: 767px){
	.dayArea{
		padding: 20px 0;
		font-size: 1.6rem;
	}
	.dayTxt{
		line-height: 160%;
	}
	.dayTxt .colorGr{
		font-size: 2.4rem;
	}
}

/*
	tagArea
-----------------------------------------------------------------------------------------------*/
.tagArea{
	width: 980px;
	margin: 45px auto 90px auto;
}
.tagAreaTit{
	text-align: center;
	font-weight: bold;
	font-size: 2.2rem;
	margin: 0 0 8px 0;
}
.tagArea .tagtext{
	text-align: center;
	font-size: 1.6rem;
	margin: 0 0 20px 0;
}
.tagArea .tagBox{
	width: 980px;
	border: solid 1px #cccccc;
	padding: 30px 35px;
}
.tagArea .tagBox ul{
	display: flex;
	flex-wrap: wrap;
	margin: 0 0 -20px 0;
}
.tagArea .tagBox li{
	display: flex;
	width: calc((100% - 10px)/2);
	margin: 0 10px 20px 0;
}
@media screen and (min-width: 767px){
	.tagArea .tagBox li:nth-of-type(2n){
		margin-right: 0;
	}
}
.tagArea .tagBox li div{
	display: flex;
	justify-content: center;
	align-items: center;
	min-width: 100px;
	height: 34px;
	color: #fff;
	border-radius: 5px;
}
.tagArea .tagBox p{
	display: flex;
	align-items: center;
	margin: 0 0 0 10px;
}
.tagColor_01{
	background-color: #bf9c46;
}
.tagColor_02{
	background-color: #5976ba;
}
.tagColor_03{
	background-color: #ea545d;
}
.tagColor_04{
	background-color: #6bbc6e;
}
.tagColor_05{
	background-color: #0099d9;
}
.tagColor_06{
	background-color: #924898;
}
.tagColor_07{
	background-color: #009da8;
}
.tagColor_08{
	background-color: #e99611;
}

@media screen and (max-width: 767px){
	.tagArea{
		width: 100%;
		max-width: 500px;
		margin: 20px auto 30px auto;
		padding: 0 10px;
	}
	.tagArea h3{
		font-size: 1.6rem;
		margin: 0 0 5px 0;
	}
	.tagArea .tagtext{
		font-size: 1.4rem;
		margin: 0 0 15px 0;
	}
	.tagArea .tagBox{
		width: 100%;
		border: solid 2px #cccccc;
		padding: 10px;
		display: block;
	}
	.tagArea .tagBox ul{
		display: block;
		margin: 0 0 -8px 0;
	}
	.tagArea .tagBox li{
		display: flex;
		width: 100%;
		margin: 0 -20px 8px 0;
	}
	.tagArea .tagBox li:nth-child(n+5){
		margin: 0 -20px 8px 0;
	}
	.tagArea .tagBox li div{
		font-size: 1.2rem;
		min-width: 80px;
		height: 26px;
		border-radius: 6px;
	}
	.tagArea .tagBox p{
		font-size: 1.4rem;
		display: flex;
		align-items: center;
		margin: 0 0 0 10px;
	}
}

/*
	キービジュアル
-----------------------------------------------------------------------------------------------*/
.keyVisual{
	height: 440px;
	width: 100%;
	background: url("../images/kv_top_B_pc.jpg") no-repeat center center / cover;
	display: flex;
	justify-content: center;
	align-items: center;
}
.keyVisual .keyCopy{
	filter: drop-shadow(0 0 25px #000000);
}
@media screen and (max-width: 767px){
	.keyVisual{
		height: 200px;
		padding: 0 20px;
	}
}

/* 各社個別セミナー　*/
.companyArea {
	padding: 25px 0 100px 0;
	background-color: #E6FAFF;
}
.companyList {
	width: 980px;
	margin: 0 auto;
}
.companyListIn{
	width: 100%;
	margin-top: 140px;
}
.oneClumnBoxIn{
	display: flex;
	width: 100%;
	box-shadow: 0 10px 25px 0 rgba(0, 0, 0,0.1);
	background: #ffffff;
	padding: 20px 20px 20px 30px;
	margin-bottom: 140px;
}
.companyListIn.last .oneClumnBoxIn{
	margin-bottom: 0;
}
.oneClumnBoxIn li{
	display: flex;
    justify-content: space-between;
}
.oneClumnBoxIn li {
	width: 100%;
	margin: 0;
}
.greetingtxtArea{
	display: flex;
	justify-content: center;
	align-items: center;
}
.oneClumnBoxIn .greetingCopy{
	max-width: 800px;
	font-weight: bold;
	font-size: 2.4rem;
	color: #228EAC;
}
.oneClumnBoxIn .greetingCopy span{
	font-weight: normal;
}
.oneClumnBox,.companyListBox{
	position: relative;
}
.oneClumnBox::after,.companyListBox::after {
	position: absolute;
	content: "";
	display: block;
	width: 100%;
	border-top: 2px dotted #888888;
	top: -55px;
	left: 0;
}
.companyListBoxIn > li{
	width:calc((100% - 40px)/3);
	box-shadow: 0 10px 25px 0 rgba(0, 0, 0,0.1);
	background: #ffffff;
	padding: 30px 25px 25px;
}
.companyList .timeArea{
	position: absolute;
	content: "";
	display: flex;
	justify-content: center;
	align-items: center;
	width: 480px;
	height: 40px;
	font-size: 2.2rem;
	text-align: center;
	background-color: #000000;
	border-radius: 20px;
	color: #ffffff;
	padding: 0 0 4px 0;
	top: -74px;
	left: 50%;
    transform: translateX(-50%);
	z-index: 500;
}
.btn:hover{
	box-shadow: none;
}
.btn::after{
	content: "";
	width: 11px;
	height: 11px;
	border-top: 3px solid #fff;
	border-right: 3px solid #fff;
	opacity: 0.3;
	position: absolute;
	top:50%;
	right: 30px;
	transform: rotate(45deg)translateY(-50%);
	transition: right 0.3s;
}
.btn:hover::after{
	right: 26px;
}
.btn p {
	text-align: center;
	color: #fff;
	font-size: 2.0rem;
}
.oneClumnBox .btn{
	width: 284px;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: all 0.3s;
}
.oneClumnBox .btn:hover{
	opacity: 0.7;
}
.oneClumnBox .btn{
	width: 326px;
	height: 76px;
	background-color: #28A4E7;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: all 0.3s;
	position: relative;
}
.greetingListBox .btnArea{
	margin: 0;
}

@media screen and (max-width: 767px){
	.companyArea {
		padding: 25px 20px;
	}
	.companyList {
		width: 100%;
		max-width: 500px;
	}
	.companyListIn{
		width: 100%;
		margin-top: 80px;
	}
	.oneClumnBoxIn{
		display: block;
		width: 100%;
		padding:20px;
		margin-bottom: 120px;
	}
	.oneClumnBoxIn li{
		display: block;
	}
	.oneClumnBoxIn li {
		width: 100%;
		margin: 0;
	}
	.greetingtxtArea{
		display: block;
	}
	.oneClumnBoxIn .greetingCopy{
		max-width: 100%;
		text-align: center;
		font-size: 1.8rem;
		line-height: 150%;
		margin-bottom:20px;
	}
	.oneClumnBox::after,.companyListBox::after {
		position: absolute;
		content: "";
		display: block;
		width: 100%;
		border-top: 2px dotted #888888;
		top: -55px;
		left: 0;
	}
	.companyListBoxIn > li{
		width:calc((100% - 40px)/3);
		box-shadow: 0 10px 25px 0 rgba(0, 0, 0,0.1);
		background: #ffffff;
		padding: 30px 25px 25px;
	}
	.companyList .timeArea{
		width: 74%;
		height: 32px;
		font-size: 1.8rem;
		border-radius: 16px;
		padding: 5px 0 8px 0;
		top: -70px;
	}
	.companyListIn.last{
		margin: 110px auto 0 auto;
	}
	.btn:hover::after{
		right: 30px;
	}
	.btn p {
		font-size: 1.8rem;
	}
	.oneClumnBox .btn {
		width: 100%;
		height: 46px;
	}
}

/*
	companyList 各社個別セミナー
-----------------------------------------------------------------------------------------------*/
.companyListArea{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 40px 52px;
}
.companyList .companySec{
	display: flex;
  flex-direction: column;
	width: 464px;
	background: #fff;
	box-shadow: 0 10px 25px 0 rgba(0, 0, 0,0.1);
	padding: 25px;
}
/* 企業の特徴タグリスト */
.tagList{
	display: flex;
	color: #fff;
	font-size: 1.2rem;
	gap: 8px;
	margin-bottom:20px;
}
.tagList li{
	width: calc((100% - 16px) / 3);
	text-align: center;
	padding: 5px 0;
	border-radius: 5px;
}
.companyLogo{
	margin:15px auto;
}
.companyTit{
	font-weight: 700;
	line-height: 140%;
	margin-bottom:10px;
}
.companyTxt{
	font-size: 1.2rem;
	margin-bottom:25px;
}
/* テキスト下の各アキ調整用 */
.ma45{
	margin-bottom: 45px;
}
.ma65{
	margin-bottom: 65px;
}

/* 企業の特徴 視聴はこちら */
.watchArea{
	height: 100%;
	background: #28A4E7;
	padding: 30px 20px 20px 20px;
	margin:0 -25px -25px -25px;
}
.watchTit{
	position: relative;
	color: #fff;
	text-align: center;
	font-weight: 700;
	border-top: 2px dotted #fff;
	margin-bottom:30px;
}
.watchTit span{
	position: absolute;
	padding:0 15px;
	display: inline-block;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background: #28A4E7;
	font-size: 1.6rem;
}
.watchList{
	display: flex;
	flex-wrap: wrap;
	gap: 20px;
	justify-content: space-between;
}
.watchList li{
	width: 196px;
	text-align: center;
}
.watchList li a.btnWt{
	position: relative;
	width: 100%;
	padding: 10px;
	margin-bottom:5px;
	display: block;
	color: #28A4E7;
	background: #fff;
	font-size: 1.8rem;
	font-weight: 700;
	box-shadow: 2px 2px 8px 0 rgba(0, 0, 0, .2);
	transition: all 0.3s;
}
.watchList li a:hover.btnWt{
	opacity: 0.8;
}
.watchList li a.btnWt::after{
	position: absolute;
	content: "";
	width: 11px;
	height: 11px;
	border-top: 3px solid #28A4E7;
	border-right: 3px solid #28A4E7;
	opacity: 0.3;
	top: 50%;
	right: 30px;
	transform: rotate(45deg) translateY(-50%);
	transition: right 0.3s;
}
.watchList li a:hover.btnWt::after{
	right: 24px;
}
/* リンクグレーアウト */
a.btn.btnNone,
.watchList.btnNone li a.btnWt{
	background: #e5e5e5;
	color: #bfbfbf;
	pointer-events: none;
}
.btn.btnNone p{
	color: #bfbfbf;
}
.btn.btnNone::after{
	border-top: 3px solid #bfbfbf;
	border-right: 3px solid #bfbfbf;
}

.watchList li .watchTime{
	color: #fff;
	font-size: 1.2rem;
	line-height: 130%;
}
/* コラボ公演がある時 */
.watchList li a.btnWt .collabo{
	position: absolute;
	display: block;
	color: #000;
	left: -4px;
	top: -5px;
	background: #ffff00;
	width: 40px;
	height: 18px;
	font-size: 1.0rem;
}
.watchList li a.btnWt .collabo::before{
	position: absolute;
	content: "";
	width: 4px;
	height: 6px;
	left: 0;
	top:18px;
	aspect-ratio: 1;
	clip-path: polygon(0 0,100% 0,100% 100%);
	background: #9b8c1e;
}

@media screen and (max-width: 767px){
	.companyListArea{
		display: block;
	}
	.companyList .companySec{
		width: 100%;
		padding: 20px;
		margin-bottom:30px;
	}
	/* テキスト下の各アキ調整用 */
	.ma45{
		margin-bottom: 25px;
	}
	.ma65{
		margin-bottom: 25px;
	}
	/* 企業の特徴 視聴はこちら */
	.watchArea{
		height: 100%;
		padding: 30px 20px 20px 20px;
		margin:0 -20px -20px -20px;
	}
	.watchList{
		gap: 17px;
	}
	.watchList li{
		width: 100%;
	}
	.watchList li a.btnWt{
		width: 100%;
		font-size: 1.6rem;
	}
	.watchList li a:hover.btnWt::after{
		right: 30px;
	}
}

/* 予約する --視聴公開後に消す */
 .reservation{
	color: #000;
	width: 100%;
	text-align: center;
 }
 .reservation .btnArea{
	margin: 40px 0 60px 0;
 }
 .reservation .btnArea .btn{
	position: relative;
	margin: 0 auto;
	display: block;
	width: 600px;
	background: #28A4E7;
	color: #fff;
	padding: 30px 0;
	font-size: 2.2rem;
	font-weight: bold;
}
.reservation .btnArea .btn:hover{
	opacity: 0.7;
}

@media screen and (max-width: 767px){
	 .reservation .btnArea{
		padding: 0 10px;
		margin: 0 0 30px 0;
	 }
	 .reservation .btnArea .btn{
		width: 100%;
		padding: 20px 0;
		font-size: 1.8rem;
	}	
}


/*
	footer
-----------------------------------------------------------------------------------------------*/
footer{
	position: relative;
}
/* 既存タグ打ち消し用 */
.copyright{
	background: #0196b4;
}

.bgCopyright{
	background-color: #0196b4;
	width: 100%;
	padding: 30px 0 ;
	position: relative;
}
.bgCopyright p{
	color: #ffffff;
	width: 1200px;
	font-size: 1.1rem;
	text-align: center;
	padding: 0 30px;
	margin: 0 auto;
}
@media screen and (max-width: 767px){
	.bgCopyright{
		padding: 20px 0 ;
	}
	.bgCopyright p{
		width: 100%;
		transform: scale(0.85);
	}
}

/*
	pageTop
-----------------------------------------------------------------------------------------------*/
#pageTop{
	position: absolute;
	top:0;
	height: 100%;
	right: 40px;
	background-color: #0184A2;
}
#pageTop a{
	display: block;
	width: 60px;
	height: 100%;
	position: relative;
	transition: all 0.5s;
}
#pageTop a:hover{
	background-color: #007B9A;
	opacity: 0.7;
}
.footerArrow{
	content: "";
	width: 20px;
	height: 20px;
	border-top: 3px solid #fff;
	border-right: 3px solid #fff;
	opacity: 0.3;
	position: absolute;
	top:50%;
	left: 50%;
	transform: rotate(-45deg)translateY(-75%);
}
@media screen and (max-width: 767px){
	#pageTop {
		position: absolute;
		right: 0px;
	}
	#pageTop a{
		width: 40px;
		height: 35px;
	}
	.footerArrow{
		width: 10px;
		height: 10px;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
		top:100%;
	}
}


