html{
    font-size: 15px;
    color: #606060;
    letter-spacing: 0.05em;
    line-height: 1.7;
    /* %で指定すると子や孫にも本要素で「計算後の実値」が継承されてしまうため、単位無しで指定 */
    font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Segoe UI", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", Meiryo, sans-serif;
    touch-action: manipulation; /*ダブルタップによるズームを無効化*/
}
*{
    font-family: inherit;/* フォントを継承（button等で勝手に他のフォントになるのを防ぐ */
}
body.no_scroll{
    overflow: hidden;
}
/*--------------------------------------------------------
講師動画
--------------------------------------------------------*/
.teacher_video{
	width:100%;
	width:calc(100% + 10px);
	overflow: hidden;
    margin-bottom:30px;
    position:relative;
    margin-left:-5px;
    margin-right:-5px;
}
@media only screen and (min-width: 738px){
	.teacher_video{
		margin-left:0px;
		margin-right:0px;
		width:100%;
	}
}
.teacher_video_block video{
	width:100%;
	 vertical-align:top;
}
.teacher_video .play_btn{
	position:absolute;
	top:50%;
	left:50%;
	margin-left:-40px;
	margin-top:-40px;
	background:#fff;
	opacity:0.8;
	width:80px;
	height:80px;
	border-radius:50%;
	box-shadow:8px 8px 16px 0px rgba(0,0,0,.05);
	display:flex;
	align-items: center;
    justify-content: center;
    cursor:pointer;
}
.teacher_video .play_btn i{
	color:#5193f7;
	margin-right:0px;
	font-size:28px;
}
/*--------------------------------------------------------
講師メッセージ
--------------------------------------------------------*/
.teacher_message{
	margin:0 auto;
	width:fit-content;
	padding-left:0 !important;
	margin-top:30px !important;
	margin-bottom:40px !important;
}
.teacher_message:before{
	display:none;
}
.teacher_message span{
	background:#5193f7;
	font-weight:bold;
	color:#fff;
	padding:5px;
	font-size:18px;
	display:inline-block;
}
.teacher_message span:not(:last-child){/* 最後要素以外はmargin-bottom加える */
	margin-bottom:10px;
}
@media only screen and (min-width: 738px){
	.teacher_message span{
		font-size:22px;
	}
}
.name_block{
	 box-sizing: border-box;
	width:100%;
	font-weight:bold;
	display:flex;
	flex-direction: column;
	border-bottom:2px solid #5193f7;
}
@media only screen and (min-width: 738px){
	.name_block{
		margin-right:30px;
	}
}
.name_block .name_en{
	color:#2668cc;
	font-size:14px;
}
.name_block .name_jp{
	font-size:28px;
	display:inline-block;
}
.name_block .teacher{
	font-size:15px;
	margin-right:10px;
}
/*--------------------------------------------------------
講師プロフィール
--------------------------------------------------------*/
.profile_block{
	background:#e8f1ff;
	padding:40px 15px 15px 15px;
	margin:0 -5px 30px -5px;
	position:relative;
}
@media only screen and (min-width: 738px){
	.profile_block{
		margin:0;
		  margin:0 -0 40px 0;
		padding:40px 15px 15px 15px;
		border-radius: 30px;
	}
}
.profile_block .img_title{
	width:124px;
	position:absolute;
	top:-30px;
	left:15px;
}
.profile_block .profile_item{
	display:flex;
	gap:15px;
}
.profile_block .title_vertical{
	display:flex;
	flex-direction: column;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	font-weight:bold;
}
.profile_block .title_vertical_en{
	color:#2668cc;
	font-size:14px;
	margin-top:3px;
}
.profile_block .title_vertical_jp{
	font-size:20px;
}
.profile_block .profile_txt .teacher_name{
	font-weight:bold;
	font-size:18px;
}
.profile_block .profile_txt .teacher{
	font-weight:bold;
	font-size:14px;
}
/*--------------------------------------------------------
講師写真
--------------------------------------------------------*/
.profile_img_block{
	width:100%;
	overflow: hidden;
    border-radius: 30px;
    margin-left:-30px;
    position:relative;
}
@media only screen and (min-width: 738px){
	.profile_img_block{
		 margin-left:0px;
		 margin-top:30px;
	}
}
.profile_img_block img.lesson_room_image{
	width:100%;
	vertical-align:top;
	margin-bottom:0;
}
/*--------------------------------------------------------
タグ
--------------------------------------------------------*/
.tag_block{
	display:flex;
	gap:8px;
	flex-wrap: wrap;
	margin-bottom:30px;
}
.tag_block .tag{
	display:inline-block;
	background:#99c2ff;
	background:#e8f1ff;
	color:#fff;
	color:#606060;
	font-weight:bold;
	padding:3px 10px;
	border-radius:5px;
	font-size:14px;
}
@media only screen and (min-width: 738px){
	.tag_block .tag{
		font-size:16px;
	}
}
.tag_block .tag.yellow{
    background:#fff0db;
    color:#ea9c2e;
    font-weight:bold;
}
.tag_block .tag i{
	margin-left:2px;
}
/*--------------------------------------------------------
講師スケジュール
--------------------------------------------------------*/
.schedule_block{
	padding:0px 0px 40px 15px;
	margin:0 -5px;
	position:relative;
	overflow-x: hidden;
}
@media only screen and (min-width: 738px){
	.schedule_block{
		margin:0;
	}
}
.schedule_block .img_title{
	width:180px;
	margin-bottom:10px;
}
.schedule_block .schedule_title{
	display:flex;
	gap:15px;
}
.schedule_block .title_vertical{
	display:flex;
	flex-direction: column;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	font-weight:bold;
}
.schedule_block .title_vertical_en{
	color:#2668cc;
	font-size:14px;
}
.schedule_block .title_vertical_jp{
	font-size:20px;
}
.schedule_block .lesson_img{
	width:100%;
	overflow: hidden;
    border-radius: 30px;
    margin-right:-50px;
}
@media only screen and (min-width: 738px){
	.schedule_block .lesson_img{
		margin-right:0px;
	}
}
.schedule_block .lesson_img img{
	margin-bottom:0;
}
/*--------------------------------------------------------
教室スケジュール
--------------------------------------------------------*/
.schedule_table_block{
	position: relative;
	padding-top: 85px;
	width:100%;
	/* max-width:1100px; */
	margin:0 auto 50px auto;
}
.schedule_table_block .scrollable_icon{
	position:absolute;
	width:30px;
	left:85px;
	bottom:0px;
	z-index: 10;
}
div.schedule_table_block_main{
  max-width:1100px;
  height:auto;
  background: #fff;
  overflow:auto;
  overflow-x:scroll;
  margin:0 auto;
   -webkit-overflow-scrolling: touch;
}
div.schedule_table_block_header{
    position: absolute;
    z-index: 21;
    top: 0;
    box-sizing: border-box;
    border-bottom: 2px solid #ccc;
    background-color: #ffffff;
	width:100%;
	max-width:1100px;
	height:85px;
}
.schedule_table_block_header.fixed{
	position: fixed;
    top: 80px;
    top: 0px;
    height: 92px;
    padding-top: 5px;
    width:calc(100% - 10px);
}
@media only screen and (min-width: 738px){
	.schedule_table_block_header.fixed{
		width:calc(100% - 20px);
	}
}
@media only screen and (min-width: 1117px){
	.schedule_table_block_header.fixed{
		max-width:700px;/*  Large画面の場合はmain_boxが700pxとなるため*/
	}
}
.schedule_table_block_header .header_inner{
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	margin-bottom: 10px;
	width:100%;
}
.schedule_table_block_header .header_inner .week_btn{
	z-index: 2;
	display: flex;
	width: 194px;
	width: 85px;
	height: 70px;
	border-radius: 5px;
	background-color: #f3f3f3;
	/* background-color: #fff; */
	flex: 0 0 85px;
	justify-content: center;
	margin-right: 10px;
	margin-left: 5px;
	font-size: 14px;
	letter-spacing: 0;
}
.schedule_table_block_header .header_inner .week_btn a{
	display:block;
	width:100%;
	/* cursor:pointer; */
}
.schedule_table_block_header .header_inner .week_btn .week_txt{
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    font-weight: bold;
    text-align: center;
    gap:5px;
}
.schedule_table_block_header .header_inner .week_btn .week_txt i{
	margin-right:0;
}
/* 時間帯タブ */
.schedule_table_block_header .header_inner .time_zone_tab{
	display: flex;
	/* flex: 1; */
	justify-content: space-between;
	width: 961px;
	width:calc(100% - 100px);
	width:calc(100% - 100px);
	margin-left:100px;
	height: 40px;
}
.schedule_table_block_header .header_inner .time_zone_tab .time_zone_item{
	display: flex;
    align-items: flex-end;
    padding-bottom: 2px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    width: calc(100%/3);
    height: 42px;
    cursor: pointer;
    font-size: 14px;
    font-weight: bold;
    border: 1px solid #99C2FF;
    gap:-1px;
    margin-bottom:0;
}
.schedule_table_block_header .header_inner .time_zone_tab .time_zone_item:nth-child(2),
.schedule_table_block_header .header_inner .time_zone_tab .time_zone_item:nth-child(3){
	border-left:0;
}
.schedule_table_block_header .header_inner .time_zone_tab .time_zone_item:first-child{
	border-radius: 3px 0 0 3px;
}
.schedule_table_block_header .header_inner .time_zone_tab .time_zone_item:last-child{
	border-radius: 0 3px 3px 0;
}
.schedule_table_block_header .header_inner .time_zone_tab .time_zone_item.active{
	border:0;
	color: #fff;
	background:#99C2FF;
}
.schedule_table_block_header .time_line_wrapper{
    margin-left: 99px;
    overflow-x: hidden;
    border-left: 1px solid #e0dcdf;
}
.schedule_table_block_header .time_line_wrapper .time_line{
	position: relative;
	display: flex;
	height: 35px;
	list-style: none;
	margin:0;
}
.schedule_table_block_header .time_line_wrapper .time_line li{
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    min-width: 51px;
    height: 33px;
    padding-top: 4px;
    /* font-family: 'Comfortaa', cursive; */
    font-size: 14px;
    border-right: 1px solid #ccc;
    border-top: 1px solid #ccc;
    color: #606060;
    background-color: #E8F1FF;
}
@media only screen and (min-width: 738px){
	.schedule_table_block_header .time_line_wrapper .time_line li{
		min-width: 81px;
	}
}
.schedule_table_block_header .time_line_wrapper .time_line li:first-child{
	margin:0px;
}
/* スクロールバー */
.schedule_table_block_header .upper_scrollbar{
	width: 100%;
    height: 17px;
    z-index: 2;
    position: absolute;
    overflow-x: scroll;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    display:none;
}
.schedule_table_block_header .upper_scrollbar .scrollbar_inner{
	height:17px;
	width:3364px;
}
@media only screen and (min-width: 1117px){
	.schedule_table_block_header .upper_scrollbar{
		display:block;
	}
	.schedule_table_block_header .upper_scrollbar .scrollbar_inner{
		width:5284px;
	}
}
.schedule_table_block .schedule_table_block_main table.schedule_table{
  width:auto;
  border-collapse: collapse;
  border-collapse: separate;
  border-spacing:0;
  padding:0;
}
.schedule_table_block .schedule_table_block_main table.schedule_table th,
.schedule_table_block .schedule_table_block_main table.schedule_table td {
	min-width:50px;
	width:50px;
	height: 100px;
	vertical-align: middle;
	padding: 0px;
	border-top: 2px solid #ccc;
	border-right: 1px solid #ccc;
}
.schedule_table_block .schedule_table_block_main table.schedule_table tr:first-child th,
.schedule_table_block .schedule_table_block_main table.schedule_table tr:first-child td{
    border-bottom: 2px solid #ccc;
    border-top: 0;
}
.schedule_table_block .schedule_table_block_main table.schedule_table tr:last-child th,
.schedule_table_block .schedule_table_block_main table.schedule_table tr:last-child td{
    border-bottom: 2px solid #ccc;
}
.schedule_table_block .schedule_table_block_main table.schedule_table tr:nth-child(2) th,
.schedule_table_block .schedule_table_block_main table.schedule_table tr:nth-child(2) td{
	border-top: 0;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .fixed_col,
.schedule_table_block .schedule_table_block_main table.schedule_table .fixed_row {
  position: sticky;
  top: 0;
  left: 0;
  background: #E8F1FF;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .fixed_row.time{
	height:60px;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .fixed_row.date .week.red{/* 日曜は赤く */
	color:#F45079;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .fixed_row.date .week.blue{/* 土曜は青く */
	color:#5193f7;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .fixed_col{
	background: #fff;
	border:none;
	border-right: 1px solid #ccc;
	height:70px;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .date{
	background: #fff;
    font-weight: bold;
    vertical-align: middle;
    min-width: 100px;
    font-size: 16px;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .date .week{
    font-weight: normal;
    font-size:14px;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .fixed_col {
  z-index: 2;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .fixed_row {
  z-index: 1;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .reserve_icon{
    position: relative;
    display: block;
    width: 50px;
    height: 100%;
}
@media only screen and (min-width: 738px){
	.schedule_table_block .schedule_table_block_main table.schedule_table .reserve_icon{
	   width: 80px;
	}
}
.schedule_table_block .schedule_table_block_main table.schedule_table .reserve_icon i{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: block;
    box-sizing: border-box;
    width: 45px;
    height: 45px;
    margin: auto;
    padding: 7px;
    border-radius: 3px;
    box-shadow: rgba(0,0,0,0.2) 0 1px 1px;
    fill: #ffffff;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .reservable_btn i{
    background-color: #5193f7;
    background-image: url(icon_circle.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 30px;
    cursor:pointer;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .unavailable_icon i{
    box-shadow: none;
    background-image: url(icon_line.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: 30px;
    cursor:pointer;
}
.schedule_table_block .schedule_table_block_main table.schedule_table .reserved_icon .reserved_txt{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: block;
    box-sizing: border-box;
    width: 45px;
    height: 45px;
    margin: auto;
    padding: 7px;
    border-radius: 3px;
    fill: #ffffff;
    background-color: #c0c0c0;
    color:#fff;
    font-weight:bold;
    font-size:14px;
    text-align:center;
    line-height:120%;
}
/*--------------------------------------------------------
担当曜日
--------------------------------------------------------*/
.week_block{
	display:flex;
	align-items: center;
	width:100%;
	gap:10px;
	position:relative;
	background:#e8f1ff;
	border-radius:20px;
	padding:15px;
	margin-right:auto;
	margin-left:auto;
	margin-bottom:40px;
}
@media only screen and (min-width: 738px){
	.week_block{
		max-width:500px;
	}
}
.week_block .week_txt{
	box-sizing: border-box;
	font-weight:bold;
	font-size:15px;
	width:100px;
	text-align:center;
	margin-bottom:0px;
	border-right:dashed 2.4px #5193f7;
	padding-right:10px;
	display:flex;
	justify-content: center;
	align-items: center;
	line-height:22px;
}
@media only screen and (min-width: 738px){
	.week_block .week_txt{
		font-size:18px;
		width:120px;
		height:40px;
	}
}
.week_block .week{
	display:flex;
	justify-content: center;
	width:calc(100% - 100px);
	width:100%;
	gap:10px;
}
@media only screen and (min-width: 738px){
	.week_block .week{
		width:calc(100% - 120px);
	}
}
.week_block .week .week_icon{
	display:flex;
	font-weight:bold;
	align-items: center;
	justify-content: center;
	width:100%;
	background:#99c2ff;
	border-radius:50%;
	color:#fff;
    width: calc(100% / 7);
    height: calc(100%/ 7);
    aspect-ratio: 1 / 1;
	margin-bottom:0px;
}
@media only screen and (min-width: 738px){
	.week_block .week .week_icon{
		font-size:18px;
	}
}
/*--------------------------------------------------------
動画popup
--------------------------------------------------------*/
.teacher_video_popup{
	 box-sizing: border-box;
    display: none;
    width: 100%;
    height: 100%;
    position: fixed;
    top: 0;
    left: 0;
    background: rgba(0,0,0,.75);
    -webkit-backdrop-filter: blur(3px);
    backdrop-filter: blur(3px);/* ぼかす */
    z-index: 1001;
    text-align: left;
    z-index: 9999;
    overflow: auto;
    opacity: 1;
    -webkit-overflow-scrolling: touch;
    -webkit-transition: all .4s ease-in-out;
    transition: all .4s ease-in-out;
}
.teacher_video_popup.active{
    display:flex;
    justify-content: center;
    align-items: center;
}
.teacher_video_popup .content{
	position: relative;
	width:100%;
	 aspect-ratio: 16 / 9;
}
@media only screen and (min-width: 1117px){
	.teacher_video_popup .content{
	    max-width: 680px;
	}
}
.teacher_video_popup .content iframe{
	width:100%;
	height:100%;
}
/* 閉じるボタン */
.teacher_video_popup .content .close_btn{
    position: absolute;
    top: -60px;
    right: 10px;
    color: #fff;
    font-size: 40px;
    background: none;
    border: none;
    cursor: pointer;
}
.teacher_video_popup .content .close_btn i{
	margin-right:0px;
}
/*--------------------------------------------------------
メインボタン
--------------------------------------------------------*/
.button_area{
    margin-top:35px;
    margin-bottom:15px;
}
@media only screen and (min-width: 738px){
    .button_area{
        margin-top:45px;
        margin-bottom:25px;
    }
}
.button_area a{
    text-decoration: none;
    width:100%;
}
.btn_comment{
    font-size:13px;
    font-weight:bold;
    position: relative;
    display:inline-block;
    margin:0 auto;
    margin-bottom:10px;
    color:#5193f7;
}
.btn_comment::before, .btn_comment::after {
    position: absolute;
    top: -6px;
    top: 0px;
    width: 2px;
    height:100%;
    content: '';
    background:#5193f7;
}
.btn_comment::before {
    left: -18px;
    transform: rotate(-30deg);
}
.btn_comment::after {
    right: -18px;
    transform: rotate(30deg);
}
button.btn_submit {
    position: relative;
    display: inline-block;
    padding:20px 30px;
    color: #fff;
    z-index: 1;
    border:none;
    background:none;
    outline: none;
    cursor:pointer;
    font-weight:bold;
    font-size:15px;
}
 button.btn_submit:before {
    content: "";
    position: absolute;
    z-index: -1;
    right: 0;
    left: 0;
    top: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    border-radius: 40px;
    background:#5193f7;
    transition: all .3s;
 }
button.btn_submit:hover:before {
  right: 0;
  transform: scale(1.1);
  background: #5193f7;
}
button.btn_submit i{
    margin-left:10px;
    margin-right:0px;
}
/*--------------------------------------------------------
レッスンリクエスト
--------------------------------------------------------*/
/* .lesson_request_box{
	width:100%;
	max-width:500px;
	margin-right:auto;
	margin-left:auto;
}
.lesson_request_box a{
	border:2px solid #5193f7;
	border-radius:20px;
	width:100%;
	display:flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	opacity:1;
    -webkit-transition: .3s;
    transition: .3s;
    padding:15px 15px 20px 15px;
}
.lesson_request_box a:hover{
	opacity:.7;
}
.lesson_request_box .blue_txt{
	color:#5193f7;
	font-size:18px;
	font-weight:bold;
	margin-bottom:5px;
}
.lesson_request_box .txt{
	margin-bottom:15px;
}
.lesson_request_box p.button{
	margin-bottom:0px;
} */
.lesson_request_block{
	background: repeating-linear-gradient(-135deg, #E4EBF7, #E4EBF7 4px, #E8F1FF 4px, #E8F1FF 10px);
    padding:15px 15px 20px 15px;
    width:calc(100% + 10px);
    margin: 0 -5px;
}
@media only screen and (min-width: 738px){
	.lesson_request_block{
		margin-left:0px;
		margin-right:0px;
		width:100%;
	}
}
.lesson_request_block .request_title{
	text-align:center;
	font-weight:bold;
	font-size:18px;
	color:#5193f7;
	margin-bottom:15px;
}
.lesson_request_block .lesson_request_area{/* 重ね順を調整するのに必要 */
	position:relative;
	z-index:1;
	max-width:500px;
	margin:0 auto;
}
.lesson_request_block .lesson_request_box{
	background:#fff;
	border-radius:20px;
	width:100%;
	display:flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	padding:15px 20px 20px 20px;
	gap:20px;
}
.lesson_request_block .lesson_request_img{
	position:absolute;
	width:70px;
	z-index:-10;
	right:20px;
	top:-68px;
	margin-bottom:0px;
}
@media only screen and (min-width: 738px){
	.lesson_request_block .lesson_request_img{
		width:90px;
		right:50px;
		top:-85px;
	}
}
.lesson_request_block .lesson_request_box .txt{
	font-size:14px;
	font-weight:bold;
}
.lesson_request_block .lesson_request_box p.button{
	margin-bottom:0px;
}
/* JASRACの許諾マーク */
footer div.copyright .jasrac_img{
    margin-right:auto;
    margin-left:auto;
}
footer div.copyright .jasrac_img img{
    width:48px;
    height:48px;
}
/* JASRACの許諾番号 */
footer div.copyright .jasrac_txt{
    font-size:10px;
    margin:0 auto 10px auto;
}