﻿@charset "utf-8";
/* reset */
* {
margin: 0;
padding: 0;
box-sizing: border-box;
word-break: break-all;
word-wrap: break-word;
}
html {
font-family: sans-serif;
line-height: 1.15;
-ms-text-size-adjust: 100%;
-webkit-text-size-adjust: 100%;
font-size: 14px;
line-height: 1.3;
}
body {
padding: 0;
margin: 0;
background: #fff;
color: var(--txt_c);
font-size: 100%;
font-family: 'メイリオ','ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック';
font-family: 'Noto Sans JP', sans-serif;
font-weight: normal;
width: 100%;
height: 100%;
}
li{
list-style: none;
}
ul::before,
ul::after,
ol::before,
ol::after,
dl::before,
dl::after {
display: none;
}
img {
max-width: 100%;
vertical-align: top;
}
a {
color: var(--main_c);
}
/* reset end */

/* wrap */
#wrap {
min-width: 320px;
padding-top: 80px;
overflow: hidden;
background: #fff url(../images/visual_bg.jpg) no-repeat center bottom / cover;
background-attachment: fixed;
}
#header {
min-width: 320px;
}
#wrap * {
box-sizing: border-box;
}
#wrap img {
vertical-align: top;
max-width: 100%;
height: auto;
}
#wrap .area {
position: relative;
clear: both;
display: block;
z-index: 10;
padding: clamp(30px, 3.47vw, 50px) 0;
}
#wrap .area_in {
position: relative;
clear: both;
margin: 0 auto;
padding: 0 20px;
width: 100%;
max-width: 1040px;
display: flex;
flex-flow: column;
gap: clamp(30px, 3.47vw, 50px);
}
/*
	@media screen and (min-width: 768px) and (max-width: 1200px) {
	#wrap {
    background-size: auto 100%;
	}
    }
*/
	@media screen and (max-width: 768px) {
	#wrap {
    background-image: url("../images/visual_bg_sp.jpg");
	padding-top: 60px!important;
    max-width: 100%;
	}
	}
.pc {
display: block;
}
.sp {
display: none;
}
	@media screen and (max-width: 768px) {
	.pc {
	display: none;
	}
	.sp {
	display: block;
	}
	}
.contents1 {
position: relative;
}
.contents1::before {
display: block;
content: "";
width: 100%;
height: 300px;
background: linear-gradient(to top, rgba(255,255,255,1), rgba(255,255,255,0));
position: absolute;
left: 0;
bottom: 0;
}
.contents2 {
position: relative;
background: #fff url(../images/bg01.jpg) no-repeat center top / cover;
background-attachment: fixed;
}
.contents2::before {
display: block;
content: "";
width: 100%;
height: 300px;
background: linear-gradient(to bottom, rgba(255,255,255,1), rgba(255,255,255,0));
position: absolute;
left: 0;
top: 0;
}

	@media screen and (max-width: 768px) {
    .contents2 {
    background-image: url("../images/bg01_sp.jpg");
    }
    }
/* wrap end */

/* header */
#header {
position: fixed;
top: 0;
left: 0;
min-width: 320px;
width: 100%;
height: 80px;
z-index: 1;
z-index: 999;
background: var(--base_c);
background: #fff;
box-shadow: 0 2px 10px rgba(0,0,0,0.2);
transition: 0.2s;
}
/*
body:not(.active) #header {
background: linear-gradient(to bottom, rgba(255, 255, 255, 1), rgba(255, 255, 255, 0));
background: none;
box-shadow: none;
}
*/
#header * {
transition: 0.2s;
}
#header .area_in {
height: 100%;
max-width: 100%;
display: flex;
flex-flow: row nowrap;
justify-content: flex-start;
align-items: stretch;
padding: 0;
gap: 0;
}
#header .branding {
position: relative;
flex: 1 0 0%;
align-self: center;
display: flex;
}
#header .logo {
align-self: center;
padding: 10px;
}
#header .logo a {
display: flex;
height: 100%;
}
#header .logo img {
height: auto;
max-width: 400px;
width: 100%;
aspect-ratio: 710 / 53;
}
    #header #menu {
    flex: 0 1 500px;
    }
	@media screen and (min-width: 768px) and (max-width: 1000px) {
    #header #menu {
    flex: 0 1 446px;
    }
    }
	@media screen and (max-width: 768px) {
	#header {
	height: 60px;
	}
	#header .logo img {
	max-height: 20px;
	}
	#header .area_in {
	padding-left: 0;
	padding-right: 50px;
	}
	}
/* header end */

/* menu */
#menubtn {
display: none;
position: absolute;
width: 50px;
height: 100%;
right: 0;
top: 0;
cursor: pointer;
transition: .3s;
background: var(--burger_icon);
z-index: 99999;
}
	@media screen and (max-width: 768px) {
	#menubtn {
	display: block;
	}
	}
#menubtn.active {
background: var(--cross_icon);
}
#menu ul {
max-width: 800px;
}
#menu ul li.sns {
display: flex;
justify-content: center;
}
#menu ul li.sns a span {
display: inline-block;
text-indent: -9999px;
width: 30px;
height: 30px;
}
#menu ul li.sns .fb span {
background: var(--fb_icon);
}
#menu ul li.sns .x span {
background: var(--x_icon);
}
	@media screen and (max-width: 768px) {
	#menu ul li.sns .fb span {
	background: var(--fb_icon_w);
	}
	#menu ul li.sns .x span {
	background: var(--x_icon_w);
	}
	}
#menu ul li a {
display: inline-block;
text-decoration: none;
font-weight: bold;
text-align: center;
}
	@media screen and (min-width: 768px) {
	#menu ul {
	display: flex;
	width: 100%;
	height: 100%;
	max-width: 800px;
	align-items: center;
	font-size: 90%;
	}
	#menu ul li a {
	width: 100%;
	height: 100%;
	padding: 10px;
	color: #fff;
	color: var(--txt_c);
	}
	#menu ul li a:hover {
	color: var(--main_c2);
	}
	#menu li a.comp span {
	display: inline-block;
	background: var(--bg_btn);
	padding: 10px 20px;
	border-radius: 0;
	font-weight: bold;
	border-radius: 30px;
	color: #fff;
	}
	#menu li a.comp:hover {
	opacity: 0.7;
	}
	#menu li a.comp.contact_end span {
	background: #999;
	}
    #menu ul li.button {
    display: flex;
    gap: 5px;
    padding: 0 10px;
    }
    #menu ul li.button > a {
    padding: 0;
    }
	}
	@media screen and (max-width: 1000px) {
	#menu ul li a {
	padding: 5px;
	}
	}
	@media screen and (max-width: 800px) {
	#menu ul {
	max-width: 600px;
	}
	}
	@media screen and (max-width: 768px) {
	#menu ul li a {
	padding: 5px;
	font-size: 90%;
	color: #fff;
	}
	#menu li a.comp span {
	padding: 10px 10px;
	border-radius: 30px;
	}
	#menu {
	position: fixed;
	left: 100%;
	top: 0;
	height: 100%;
	width: 100%;
	padding: 60px 0 0 0;
	background: var(--bg_menu);
	transition: all 0.3s linear;
	z-index: 100;
	border-right: none;
	height: 100%;
	}
	#menu.active {
	left: 0;
	}
	#menu ul {
	border: none;
	display: block;
	width: 100%;
	max-width: 100%;
	}
	#menu ul li {
	display: block;
	}
	#menu ul li a {
	border: none;
	width: 100%;
	font-size: 1rem;
	}
	#menu li > a > * {
	padding: 20px;
	color: #fff;
	}
	#menu ul li a.comp {
	padding: 20px;
	}
	#menu ul li a.comp span {
	display: block;
	background: #fff;
	color: var(--bg_menu);
	}
	}
#menu li a.comp span {
}
#menu li.button .offline span {
background: var(--sub_c2);
color: #fff!important;
} 
#menu li.button .online span {
background: var(--sub_c);
color: #fff!important;
}
    @media screen and (max-width: 768px) {
    #menu ul li.button {
    padding: 20px 20px 0;
    }    
    #menu ul li a.comp {
    padding: 0;
    display: block;
    margin-bottom: 10px;
    }
    }
/* menu end */

/* visual */
#wrap #visual.area {
padding: 0;
}
#visual .area_in {
max-width: 100%;
width: 1000px;
margin: 0 auto;
aspect-ratio: 1200 / 630;
object-fit: cover;
background: url("../images/visual.png") no-repeat center center / contain;
padding: 0;
}
#visual .area_in img {
max-width: 100%;
width: 1200px;
aspect-ratio: 1200 / 630;
object-fit: cover;
opacity: 0;
}
	@media screen and (min-width: 1000px) {
    #visual .area_in {
    width: 100%;
    max-width: 1600px;
    aspect-ratio: 1600 / 630;
    background-image: url("../images/visual_1600.png");
    }
    #visual .area_in img {
    width: 100%;
    max-width: 1600px;
    aspect-ratio: 1600 / 630;
    object-fit: cover;
    }
    }
#visual + .contact_area {
padding-top: 0;
padding-bottom: 0;
}
/* visual end */

/* scroll_btn * /
.scroll_btn {
position: fixed;
right: 0;
bottom: 20px;
transform: translate(0,0);
z-index: 100;
box-shadow: 0 0 10px rgba(2,33,57,0.5);
transition: .3s;
border-radius: clamp(5px, 1.38vw, 10px) 0 0 clamp(5px, 1.38vw, 10px);
border: none;
overflow: hidden;
}
.scroll_btn.active {
right: 0;
bottom: 20px;
}
.scroll_btn a {
display: block;
background: none;
}
.scroll_btn a img {
transition: .3s;
width: clamp(50px, 5.55vw, 80px);
}
.scroll_btn a:hover img {
opacity: 0.8;
}
/* scroll_btn end */

/* lead */
#wrap #lead_area .area{
padding-top: 0;
}
/*
.lead_box {
display: flex;
flex-flow: row wrap;
align-items: center;
gap: 10px clamp(30px, 3.47vw, 50px);
width: 900px;
max-width: 100%;
margin: 0 auto;
color: #fff;
background: linear-gradient(to bottom, rgba(1,4,20, 0.8), rgba(6,27,135, 0.7));
box-shadow: 0 0 10px rgba(75,166,242, 0.3);
padding: clamp(30px, 3.47vw, 50px);
border-radius: clamp(5px, 1.38vw, 10px);
}
*/
.lead_box .base_tit {
flex: 0 1 auto;
}
.lead_box .lead_txt {
flex: 1 0 0%;
line-height: 2;
font-size: clamp(14px, 1.38vw, 20px);
color: var(--base_c);
}
	@media screen and (max-width: 768px) {
    .lead_box .base_tit,
    .lead_box .lead_txt {
    flex: 1 0 100%;
    }
    }
.lead_list {
display: flex;
flex-flow: row wrap;
gap: 40px;
max-width: 1000px;
margin: 0 auto;
}
.lead_list li {
flex: 0 1 calc(50% - 20px);
background: #fff;
border-radius: clamp(14px, 1.38vw, 20px);
box-shadow: 0 0 10px rgba(0,0,0,0.2);
overflow: hidden;
}
.lead_list li .info {
padding: clamp(20px, 2.77vw, 40px);
display: flex;
flex-flow: column;
gap: 10px;
}
.lead_list li .info .tit {
font-size: clamp(20px, 2.08vw, 30px);
color: var(--base_c);
font-weight: 600;
}
.lead_list li .info .txt {
line-height: 1.6;
font-size: clamp(14px, 1.38vw, 16px);
}
    @media screen and (min-width: 520px) and (max-width: 768px) {
	}
	@media screen and (max-width: 768px) {
    .lead_list {
    max-width: 500px;
    }
    .lead_list li {
    flex: 0 1 100%;
    }
    }
/* lead end */

/* contact */
.contact_area {
padding: 0;
}
.contact_btn_wrap {
display: grid;
gap: 20px;
}
.contact_btn {
position: relative;
display: flex;
width: 100%;
height: clamp(60px, 6.94vw, 100px);
border-radius: clamp(30px, 3.47vw, 50px);
max-width: 600px;
margin: 0 auto;
align-items: center;
justify-content: center;
font-weight: 500;
text-decoration: none;
text-align: center;
color: #fff;
font-size: clamp(16px, 2.77vw, 28px);
transition: .3s;
background: var(--bg_btn);
box-shadow: 0 0 10px rgba(0,0,0,0.1);
}
.contact_btn span {
display: inline-block;
}
.contact_btn::before {
content: "";
position: absolute;
display: block;
right: 10px;
top: 50%;
width: clamp(30px, 3.47vw, 50px);
aspect-ratio: 50 / 50;
object-fit: cover;
background: var(--next_arrow_w);
transform: translate(0,-50%);
}
.contact_btn::after {
content: "";
position: absolute;
display: block;
left: 0;
top: 0;
width: 100%;
height: 100%;
display: block;
background: rgba(255,255,255,0.0);
border-radius: 50px;
transition: .3s;
visibility: inherit;
}
.contact_btn:hover::after {
background: rgba(255,255,255,0.2);
}
.contact_btn.contact_end {
background: #999;
}
.contact_btn_box {
display: flex;
gap: clamp(14px, 1.38vw, 20px);
}
.contact_btn_txt {
text-align: center;
}
.contact_btn.online {
background: var(--sub_c2);
}
.contact_btn.offline {
background: var(--sub_c);
}
	@media screen and (max-width: 700px) {
    .contact_btn_box {
    flex-flow: column;
    }
    }
/* contact end */

/* footer */
#footer {
background: #fff;
color: var(--txt_c);
}
#footer a {
transition: 0.3s;
}
#footer a:hover {
opacity: 0.7;
}
.company_logo {
padding: 30px;
text-align: center;
max-width: 260px;
margin: 0 auto;
}
#footer .text {
text-align: center;
}
#footer .copy {
text-align: center;
font-size: 90%;
padding: 0;
}
#nav {
clear: both;
padding: 20px;
}
#nav ul {
display: flex;
flex-flow: row nowrap;
justify-content: center;
align-items: stretch;
line-height: 1;
}
#nav ul li {
border-right: 1px solid #333;
}
#nav ul li.sns {
display: none;
}
#nav ul li:last-child {
border-right: none;
}
#nav ul li a {
font-weight: bold;
display: inline-block;
text-decoration: none;
padding: 0 20px;
color: var(--txt_c);
}
.footer_link {
text-align: center;
font-size: 90%;
}
.footer_link a {
text-decoration: none;
}
	@media screen and (max-width: 768px) {
    #nav {
    padding: 0 0 20px 0;
    }
    #nav ul {
    flex-flow: column wrap;
    justify-content: flex-start;
    }
    #nav ul li {
    border-right: none;
    border-bottom: 1px solid #ddd;
    }
    #nav ul li:last-child {
    }
    #nav ul li a {
    display: block;
    padding: 20px 0;
    text-decoration: none;
    }
	}
#footer .companylogo {
text-align: center;
}
#footer .companylogo img {
width: 300px;
max-width: 100%;
}
#footer .txt {
margin-bottom: 20px;
}
/* footer end */

/* pagetop */
#pagetop {
position: fixed;
right: 10px;
bottom: -100px;
transition: .3s;
opacity: 0;
z-index: 100;
}
#pagetop.active {
bottom: 10px;
opacity: 0.9;
}
#pagetop:hover {
opacity: 0.6;
}
#pagetop a {
display: block;
width: clamp(40px, 4.16vw, 60px);
height: clamp(40px, 4.16vw, 60px);
border-radius: clamp(20px, 2.08vw, 30px);
background: #000;
text-indent: -9999px;
}
#pagetop a:before {
content: "";
position: absolute;
left: 50%;
top: 50%;
width: clamp(20px, 2.77vw, 40px);
aspect-ratio: 50 / 50;
object-fit: cover;
transform: translate(-50%,-50%);
background: var(--top_arrow_w);
.contact_btn::before {
}
}
#pagetop {
display: none!important;
}
/* pagetop end */

/* title */
.base_tit {
display: flex;
flex-flow: column-reverse nowrap;
align-items: center;
color: var(--base_c);
}
.base_tit b {
font-size: clamp(14px, 1.38vw, 20px);
font-size: clamp(30px, 3.47vw, 50px);
font-weight: 600;
}
/*
.base_tit em {
font-style: normal;
font-size: clamp(14px, 1.38vw, 20px);
}
.base_tit span {
font-family: var(--font_en);
font-size: clamp(40px, 4.16vw, 60px);
font-weight: 600;
}
	@media screen and (max-width: 768px) {
	.base_tit {
	font-size: 120%;
	}
	}
.contents2 .base_tit {
color: #fff;
}
*/
/* title end */



/* popup */
.mfp-bg {
opacity: 0.9;
background: #000;
}
.popup_contents {
display: none;
}
.mfp-content {
max-width: 700px!important;
max-width: inherit!important;
padding: 50px 50px;
height: 100%;
}
.mfp-close {
position: fixed!important;
top: 10px!important;
right: 10px!important;
width: 50px!important;
height: 50px!important;
opacity: 1!important;
text-indent: -9999px;
position: relative;
}
.mfp-close:before {
content: "";
display: block;
position: absolute;
left: 0;
top: 0;
width: 50px;
height: 50px;
background: var(--cross_icon);
}
.pop_prev,
.pop_next {
position: fixed;
top: 50%;
z-index: 100;
display: block;
width: 50px;
height: 50px;
cursor: pointer;
text-indent: -9999px;
transition: .3s;
}
.pop_prev {
left: 10px;
background: var(--prev_arrow);
}
.pop_next {
right: 10px;
background: var(--next_arrow);
}
	@media screen and (max-width: 768px) {
	.mfp-content {
	padding: 40px;
	}
	.mfp-close {
	top: 0!important;
	right: 0!important;
	}
	.pop_prev {
	left: 0;
	}
	.pop_next {
	right: 0;
	}
	}
.pop_prev:hover,
.pop_next:hover {
opacity: 0.7;
}
.popup_box {
display: flex;
align-items: center;
height: 100%;
}
.popup_box_in {
margin: 60px 10px 10px 10px;
background: #fff;
padding: 30px;
box-shadow: 0 0 10px rgba(0,0,0,0.2);
max-width: 900px;
margin: 0 auto;
max-height: 100%;
overflow-y: scroll;
font-weight: 400;
width: 100%;
border-radius: 10px;
display: grid;
gap: 20px;
}
	@media screen and (max-width: 768px) {
	.popup_box_in {
	padding: 20px;
    gap: 10px;
	}
	}
/* popup end */


.program .cate {
display: flex;
align-items: center;
gap: 5px;
flex-flow: row wrap;
}
.program .cate > * {
font-size: 90%;
padding: 7px 10px;
color: #fff;
background: #333;
line-height: 1;
border-radius: 5px;
}
.program .cate > *.type {
background: var(--base_c);
}
.program .cate > *.offline {
background: var(--sub_c);
}
.program .cate > *.online {
background: var(--sub_c2);
}
.program .title b {
font-weight: 600;
line-height: 1.4;
font-size: clamp(20px, 2.08vw, 30px);
padding: 0;
color: var(--base_c);
}
.program .ico {
color: #999;
font-size: 0.9rem;
}
.program .gaiyou_box {
padding: 20px;
background: #f2f2f2;
border-radius: 5px;
}
.program .txt.gaiyou {
font-size: 1.1rem;
line-height: 1.6;
border-radius: 5px;
}
.program .txt.agenda {
display: flex;
flex-flow: column;
gap: 10px;
margin-top: 20px;
}
.program .txt.agenda > * {
line-height: 1.6;
}
.program .txt.reco {
display: flex;
flex-flow: column;
gap: 5px;
}
.program .txt.reco > * {
border-bottom: 1px solid #ddd;
padding-bottom: 5px;
line-height: 1.6;
padding: 10px 0;
}
.program .txt.reco > b {
background: #333;
color: #fff;
border: 0;
padding: 10px 20px;
border-radius: 5px;
}
.program .layout_box {
display: flex;
flex-flow: row wrap;
gap: 10px;
}
.program .bar {
border: 0;
padding: 10px 0;
border-radius: 5px;
display: flex;
gap: 10px;
align-items: center;
}
.program .bar b {
flex: 0 1 auto;
}
.program .bar::after {
flex: 1 0 0%;
display: block;
height: 0;
border-bottom: 1px solid #ccc;
content: "";
width: 100%;
}
.program .layout_box .layout {
padding-top: 10px;
display: flex;
flex-flow: row wrap;
gap: 10px 10px;
}
.timelist .program .layout_box .layout {
flex: 0 1 calc(50% - 5px);
}
    @media screen and (max-width: 768px) {
    .timelist .program .layout_box .layout {
    flex: 1 0 100%;
    }
    }
.program .layout_box .layout .photo {
flex: 0 1 100px;
border-radius: 5px;
overflow: hidden;
}
.popup_box.program .layout_box .layout .photo {
flex: 0 1 200px;
}
.program .layout_box .layout .info {
flex: 1 0 0%;
display: flex;
flex-flow: column;
gap: 10px;
}
.program .layout_box .layout .info .txt.prof {
font-size: 0.9rem;
line-height: 1.6;
}
@media screen and (max-width: 768px) {
.popup_box.program .layout_box .layout {
flex-flow: column;
}
.popup_box.program .layout_box .layout .photo {
flex: 0 1 auto;
max-width: 200px;
margin: 0 auto;
}
}
.program .info .txt {
display: flex;
flex-flow: column;
}
.program .info .txt .name {
font-weight: 600;
font-size: 1.2rem;
}
.popup_box.program .layout_box .layout:first-child {
border: none;
padding: 0;
}
/*
    @media screen and (max-width: 768px) {
    .program .title b {
    font-size: 1.2rem;
    }
    }
*/
/* timetable_area end */

.program .date {
display: flex;
flex-flow: row wrap;
justify-content: space-between;
font-size: 1.2rem;
line-height: 1;
gap: 5px;
}
.program .date .d {
display: flex;
flex-flow: row wrap;
font-weight: 500;
}
.program .date .d b {
display: inline-block;
padding-right: 10px;
font-weight: 600;
border-right: 1px solid #ddd;
}
.program .date .d span {
padding: 0 10px;
display: inline-block;
font-weight: 500;
}
.program .date .t {
text-align: right;
font-weight: 500;
}

.timelist .program .txt.prof {
display: none;
}

	@media screen and (max-width: 520px) {

	}














/* program */







/* program end */


/*
.popup_box {
border-radius: 5px;
}
.popup_box.program .txt.gaiyou {
padding: 20px 0;
margin-bottom: 0;
background: none;
}
.popup_box.program .jigyou {
margin-bottom: 10px;
}
.popup_box.program .layout .photo {
flex: 0 1 230px;
}
.popup_box.program .layout .photo img {
width: 210px;
border-radius: 0;
}
.popup_box .bar {
text-align: center;
background: #eee;
padding: 10px;
margin-bottom: 20px;
}
* /
#category_area .tab .timelist_nav li > *.active {
box-shadow: none!important;
}
#category_area .tab .timelist_nav {
box-shadow: 0 0 10px rgb(3 57 125 / 60%);
border: none;
background: #fff;
}
#category_area .tab .timelist_nav ul,
#category_area .tab .timelist_nav li {
border: none;
}
#category_area .tab .timelist_nav li > *,
#category_area .tab .timelist_nav li > *::after {
color: #fff;
border-color: #fff;
}
#category_area .tab .timelist_nav li > *.active::after,
#category_area .tab .timelist_nav li > *:hover::after{
border-color: #fff;
}
#category_area .tab .timelist_nav li > * {
background: rgba(59, 4, 11, 0.7);
}
#category_area .tab .timelist_nav li > *.active,
#category_area .tab .timelist_nav li > *:hover{
color: #fff!important;
background: rgba(59, 4, 11, 0.9);
background: #6A1C23;
}

#category_area .area_in {
max-width: 1200px;
padding-bottom: 0;
}
.categorylist {
display: flex;
flex-flow: column;
gap: 20px;
}
.categorylist .date {
display: none;
}
.categorylist {
flex: 1 0 0%;
}
@media screen and (max-width: 768px) {
#category_area .timelist {
padding: 0!important;
}
.categorylist {
padding: 20px 0;
}
}
@media screen and (max-width: 400px) {
}
#category_area .timelist.tabcont.C1 {
background: var(--C1_c);
}
#category_area .timelist.tabcont.C2 {
background: var(--C2_c);
}
#category_area .timelist.tabcont.C3 {
background: var(--C3_c);
}
#category_area .timelist.tabcont.C4 {
background: var(--C4_c);
}
#category_area .timelist.tabcont.C5 {
background: var(--C5_c);
}
#category_area .timelist.tabcont.C6 {
background: var(--C6_c);
}
#category_area .timelist.tabcont.C7 {
background: var(--C7_c);
}
#category_area .timelist.tabcont.C8 {
background: var(--C8_c);
}
#category_area .timelist.tabcont.C9 {
background: var(--C9_c);
}
#category_area .timelist.tabcont.C10 {
background: var(--C10_c);
}
#category_area .timelist.tabcont.C11 {
background: var(--C11_c);
}
#category_area .timelist.tabcont.C12 {
background: var(--C12_c);
}
/* timetable_area */
#timetable_area .base_tit {
/*color: var(--base_c2);*/
}
.timetable_box {
}
.program_box {
}
.timelist {
background: var(--base_c2);
box-shadow:  0 0 10px rgba(0,0,0,0.2);
padding: clamp(14px, 1.38vw, 20px) 0;
border-radius: 0 0 clamp(18px, 1.80vw, 26px) clamp(18px, 1.80vw, 26px);
}
.timelist_body {
display: flex;
flex-flow: column;
gap: 20px;
padding: 0 20px;
}
.timelist dl {
display: flex;
flex-flow: column;
gap: clamp(14px, 1.38vw, 20px);
}
.timelist dl.noprogram {
display: flex;
flex-flow: column;
gap: 0;
text-align: center;
background: rgba(26,83,209,0.1);
padding: 20px;
height: 100%;
border-radius: clamp(14px, 1.38vw, 20px);
}
.timelist dl.noprogram .txt.gaiyou {
font-size: 0.9rem;
padding-top: 10px;
}
.timelist dl dt {
display: flex;
flex-flow: row wrap;
align-items: center;
justify-content: center;
font-weight: bold;
font-size: 1.1rem;
color: var(--base_c);
}
    @media screen and (max-width: 768px) {
    .timelist dl {
    flex-flow: column;
    gap: 20px;
    }
    .timelist {
    padding: 20px 0;
    }
    .timelist dl dt {
    flex: 1 0 0%;
    padding: 0;
    }
    }
.timelist dl dd {
padding: 0;
flex: 1 0 0%;
}
.timelist .popup {
display: flex;
flex-flow: column;
gap: clamp(14px, 1.38vw, 20px);
background: #fff;
padding: 20px;
height: 100%;
border-radius: clamp(14px, 1.38vw, 20px);
width: 100%;
transition: all 0.2s linear;
cursor: pointer;
}
.timelist .popup:hover {
box-shadow: 0 2px 10px rgba(0,0,0,0.2)!important;
transform: translateY(-10px);
background: var(--base_c3);
}
.timelist_nav {
display: flex;
flex-flow: row wrap;
justify-content: center;
box-sizing: border-box;
background: #fff;
border-radius: clamp(18px, 1.80vw, 26px) clamp(18px, 1.80vw, 26px) 0 0;
}
.timelist_nav li {
flex: 1 0 0%;
}
	@media screen and (max-width: 1000px) {
    .timelist_nav li {
    flex: 1 0 16%;
    }
    .timelist_nav li:nth-child(6) > * {
    border-radius: 0 clamp(5px, 1.38vw, 10px) 0 0;
    }
    .timelist_nav li:last-child > * {
    border-radius: 0;
    }
    }


.timelist_nav li > * {
position: relative;
padding: clamp(18px, 1.80vw, 26px) 5px clamp(18px, 1.80vw, 26px) 5px;
display: flex;
flex-flow: column wrap;
justify-content: center;
height: 100%;
text-align: center;
letter-spacing: 0.05em;
background: #fff;
letter-spacing: -0.05em;
text-decoration: none;
transition: all 0.2s linear;
cursor: pointer;
box-shadow: inset 0 0 2px rgba(0,0,0,0.0);
}
.timelist_nav li:first-child > * {
border-radius: clamp(18px, 1.80vw, 26px) 0 0 0;
}
.timelist_nav li:last-child > * {
border-radius: 0 clamp(18px, 1.80vw, 26px) 0 0 ;
}
.timelist_nav li > * > * {
display: block;
line-height: 1.2;
font-weight: bold;
margin: 0;
font-size: 90%;
}
.timelist_nav li > * > em {
font-style: normal;
font-size: 0.8rem;
max-width: 200px;
margin: 0 auto;
padding-top: 10px;
}
.timelist_nav li > * > em span {
display: inline-block;
}
.timelist_nav li > * > * span {
display: inline-block;
}
.timelist_nav li > * > b {
font-size: 150%;
}
/*
.timelist_nav li > *:after {
content: "";
display: inline-block;
position: absolute;
left: 50%;
bottom: 15px;
width: 8px;
height: 8px;
margin: -6px -9px 0 0;
border-bottom: 2px solid #333;
border-left: 2px solid #333;
transform: rotate(-45deg);
}*/
.timelist_nav li > *:hover {
background: var(--base_c);
opacity: 0.7;
color: #fff;
}
.timelist_nav li > *:hover:after {
border-color: #fff;
}
.timelist_nav li > *.active {
background: var(--base_c);
box-shadow: 0 0 10px rgba(0,0,0,0.7);
box-shadow: none;
color: #fff;
}
.timelist_nav li > *.active:after {
border-bottom: 2px solid #fff;
border-left: 2px solid #fff;
}
.timelist_nav li.C1 > *:hover,
.timelist_nav li.C1 > *.active {
background: var(--C1_c);
}
.timelist_nav li.C2 > *:hover,
.timelist_nav li.C2 > *.active {
background: var(--C2_c);
}
.timelist_nav li.C3 > *:hover,
.timelist_nav li.C3 > *.active {
background: var(--C3_c);
}
.timelist_nav li.C4 > *:hover,
.timelist_nav li.C4 > *.active {
background: var(--C4_c);
}
.timelist_nav li.C5 > *:hover,
.timelist_nav li.C5 > *.active {
background: var(--C5_c);
}
.timelist_nav li.C6 > *:hover,
.timelist_nav li.C6 > *.active {
background: var(--C6_c);
}
.timelist_nav li.C7 > *:hover,
.timelist_nav li.C7 > *.active {
background: var(--C7_c);
}
.timelist_nav li.C8 > *:hover,
.timelist_nav li.C8 > *.active {
background: var(--C8_c);
}
.timelist_nav li.C9 > *:hover,
.timelist_nav li.C9 > *.active {
background: var(--C9_c);
}
.timelist_nav li.C10 > *:hover,
.timelist_nav li.C10 > *.active {
background: var(--C10_c);
}
.timelist_nav li.C11 > *:hover,
.timelist_nav li.C11 > *.active {
background: var(--C11_c);
}
.timelist_nav li.C12 > *:hover,
.timelist_nav li.C12 > *.active {
background: var(--C12_c);
}
/*
	@media screen and (max-width: 1000px) {
	.timelist_nav li {
	flex: 1 0 25%;
	}
    .timelist_nav.tab2nav li {
	flex: 1 0 33.33%;
	}
	.timelist_nav li > *:after {
	bottom: 10px;
	}
	}
*/
	@media screen and (max-width: 768px) {
	.timelist_nav li > * {
	padding-top: 5px;
	padding-bottom: 20px;
	}
	.timelist_nav li {
	flex: 1 0 50%;
	}
	.timelist_nav li > * {
	padding: 10px 5px;
	}
	.timelist_nav li > *:after {
	display: none;
	}
    .timelist_nav li:first-child > * {
    border-radius: clamp(5px, 1.38vw, 10px) 0 0 0;
    }
    .timelist_nav li:nth-child(2) > * {
    border-radius: 0 clamp(5px, 1.38vw, 10px) 0 0 ;
    }
    .timetable_box .timelist_nav li:last-child > * {
    border-radius: 0;
    }
    .timelist_nav li:nth-child(2) > * {
    border-radius: 0 clamp(5px, 1.38vw, 10px) 0 0;
    }
    .timelist_nav li:nth-child(6) > * {
    border-radius: 0;
    }
	}
/*
	@media screen and (max-width: 400px) {
	.timelist_nav li {
	flex: 1 0 100%;
	}
    .timelist_nav.tab2nav li {
	flex: 1 0 100%;
	}
    .timelist_nav li:first-child > * {
    border-radius: clamp(5px, 1.38vw, 10px) clamp(5px, 1.38vw, 10px) 0 0;
    }
     .timelist_nav li:nth-child(2) > * {
    border-radius: 0;
    }
    }

*/




/* speakers_area * /
#speakers_area {
}
.photolist_box {
}
.photolist {
display: flex;
flex-flow: row wrap;
justify-content: center;
gap: 20px;
}
.photolist li {
flex: 0 1 calc(25% - 15px);
}
.photolist li > *.popup {
overflow: hidden;
max-width: 300px;
margin: 0 auto;
transition: .3s;
position: relative;
cursor: pointer;
display: flex;
flex-flow: row wrap;
height: 100%;
gap: clamp(30px, 3.47vw, 50px);
color: #fff;
background: linear-gradient(to top, rgba(1, 4, 20, 0.8), rgba(6, 27, 135, 0.7));
box-shadow: 0 0 10px rgba(75,166,242, 0.3);
padding: 10px 10px 20px;
border-radius: clamp(5px, 1.38vw, 10px);
}
.photolist li > *.popup .ico {
display: flex;
justify-content: center;
align-items: center;
width: 100px;
height: clamp(20px, 2vw, 26px);
background: #0B599A;
color: #fff;
position: absolute;
left: 26px;
top: 26px;
transform: translate(-50%,-50%) rotate(-45deg);
font-size: clamp(12px, 1.0vw, 16px);
}
.photolist li.KK > *.popup {
background: linear-gradient(to top, rgba(6, 27, 135, 0.8), rgba(8,118,211, 0.7));
}
.photolist li.KK > *.popup .ico {
background: #0876D3;
}
.photolist li > *:hover {
opacity: 0.6;
transform: translate(0,-10px);
}
.photolist li > *:hover img {
opacity: 1;
}
.photolist .layout {
display: flex;
flex-flow: column;
gap: 10px;
}
.photolist img {
width: 100%;
aspect-ratio: 300 / 300;
object-fit: cover;
transition: .3s;
border-radius: 5px;
}
.photolist .txt {
align-items: center;
justify-content: flex-start;
line-height: 1.6;
}
.photolist .program .txt .com,
.photolist .program .txt .job,
.photolist .program .txt .name {
}
.photolist .program .txt .com {
font-size: .9rem;
}
.photolist .program .txt .job {
font-size: .9rem;
display: none;
}
.photolist .program .txt .name {
font-size: 1.1rem;
}
	@media screen and (max-width: 768px) {
	.photolist li {
	flex: 0 1 calc(33.33% - 14px);
	}
	}
	@media screen and (max-width: 620px) {
	.photolist li {
	flex: 0 1 calc(50% - 10px);
	}
    }
	@media screen and (max-width: 420px) {
	.photolist li {
	flex: 0 1 100%;
	}
	}
/* speakers_area end */

/* overview_area */
#overview_area {
}
#overview_area {
}
.overviewe_box {
width: 100%;
border-radius: 5px;
background: #fff;
box-shadow: 0 0 10px rgb(0,0,0,0.1);
padding: clamp(20px, 3.47vw, 50px);
border-radius: clamp(18px, 1.80vw, 26px);
margin: 0 auto;
}
.dlist {
max-width: 800px;
margin: 0 auto;
}
.dlist dl {
display: flex;
width: 100%;
border-bottom: 1px solid rgba(0,0,0,0.3);
}
.dlist dl dt {
flex: 0 1 200px;
font-weight: bold;
position: relative;
padding: 40px 0;
vertical-align: middle;
text-align: left;
}
.dlist dl dd {
flex: 1 0 0%;
position: relative;
padding: 40px 0;
word-break: break-all;
}
.dlist a {
text-decoration: underline;
}
.dlist_txt {
text-align: center;
margin-top: 20px;
}
	@media screen and (max-width: 768px) {
	.dlist {
	padding: 0;
	}
	.dlist .txt_head {
	margin: 0 0 30px;
	}
	.dlist dl {
	display: block;
	padding: 0;
	}
	.dlist dl dt {
	padding: 20px 0;
	}
	.dlist dl dd {
	padding: 0 0 20px;
	}
	}
	@media screen and (max-width: 420px) {
	.dlist {
	}
	.dlist .txt_head {
	margin: 0 0 20px;
	}
	}
/* overview_area end */

/* faq_area */
#faq_area {
background: linear-gradient(to bottom, rgba(255,255,255,0), rgba(255,255,255,1));
}
.faq_box_in {
display: grid;
row-gap: 40px;
}
.faq_list {
display: grid;
gap: 20px;
}
.faq_list li {
background: #fff;
border-radius: clamp(14px, 1.38vw, 20px);
padding: clamp(14px, 1.38vw, 20px);
box-shadow: 0 2px 10px rgba(3,45,96,0.2);
}
.faq_list li > * {
position: relative;
display: grid;
grid-template-columns: auto 1fr;
row-gap: 20px;
padding: 0;
}
.faq_list li > * .ico {
font-size: 2rem;
padding: 0 20px;
}
.faq_list li > * .txt {
font-size: clamp(14px, 1.38vw, 20px);
padding: 10px 10px 10px 0;
line-height: 1.6;
}
.faq_list li > *.q .txt {
font-size: clamp(14px, 1.38vw, 20px);
font-weight: 600;
}
.faq_list li > * .txt .anno {
font-size: 0.9rem;
line-height: 1.3;
margin-top: 0.5rem;
display: inline-block;
}
.faq_list li > *.q {
padding-right: 50px;
cursor: pointer;
font-size: 1.3rem;
font-weight: bold;
}
.faq_list li > *.q::before,
.faq_list li > *.q::after {
content: "";
display: block;
width: 20px;
height: 2px;
position: absolute;
right: 10px;
top: calc(50% - 1px);
transform: translate(0,0);
background: #ccc;
transition: .3s;
}
.faq_list li > *.q:hover {
opacity: 0.7;
}
.faq_list li > *.q.active:::before {
}
.faq_list li > *.q::after {
transform: rotate(-90deg);
}
.faq_list li > *.q.active::after {
transform: rotate(0deg);
}
.faq_list li > *.q.active:hover::after {
}
.faq_list li > *.q .ico {
align-self: center;
font-family: var(--font_en);
color: var(--main_c);
font-weight: 600;
}
.faq_list li > *.a {
display: none;
padding-top: 20px;
padding-left: 20px;
}
.faq_list li > *.a::before {
content: "";
display: block;
width: 100%;
height: 1px;
background-color: #fff;
position: absolute;
left: 0;
top: 20px;
}
.faq_list li > *.a .ico {
display: none;
}
	@media screen and (max-width: 768px) {
	#faq_area {
	padding: 30px 0;
	}
	.faq_box {
	gap: 30px;
	grid-template-columns: auto;
	}
	}
	@media screen and (max-width: 520px) {
	#faq_area {
	padding: 20px 0;
	}
	.faq_box {
	gap: 20px;
	}
	}
/* faq_area end */


/* 1440px最大
vw = px ÷ 14.4
100px ÷ 14.4 = 6.94vw
50px ÷ 14.4 = 3.47vw
40px ÷ 14.4 = 2.77vw
30px ÷ 14.4 = 2.08vw
20px ÷ 14.4 = 1.38vw
10px ÷ 14.4 = 0.69vw

padding: clamp(80px, 6.94vw, 100px) 0;
padding: clamp(60px, 5.55vw, 80px) 0;
padding: clamp(40px, 4.16vw, 60px) 0;
padding: clamp(30px, 3.47vw, 50px) 0;
padding: clamp(20px, 2.77vw, 40px) 0;
font-size: clamp(16px, 2.08vw, 30px);
font-size: clamp(14px, 1.38vw, 20px);
font-size: clamp(14px, 1.38vw, 20px);
font-size: clamp(14px, 1.38vw, 10px);
*/
@media screen and (min-width: 768px) and (max-width: 1200px) {
}
@media screen and (max-width: 768px) {
}
:root {
/*--font_en:'Noto Sans JP', sans-serif;*/
--font_en:'Inter', 'Noto Sans JP', sans-serif;

--txt_c: #222;
--base_c: #032D60;
--base_c2: #D7EBFD;
--base_c3: #EAF5FE;
--main_c: #1a53d1;
--main_c2: #1a53d1;
--contact_bg_c: none;

--bg_btn: linear-gradient(to right, var(--main_c), var(--main_c2));
--bg_menu: var(--txt_c);
--bg_menu: var(--base_c);

--sub_c: #FFA201;
--sub_c2: #1a53d1;

--fb_icon_w: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100"%3E%3Cpath d="M73.09,55.83l2.75-17.96h-17.23v-11.66c0-4.91,2.41-9.7,10.13-9.7h7.84V1.21s-7.11-1.21-13.91-1.21c-14.19,0-23.47,8.6-23.47,24.17v13.69h-15.78v17.96h15.78v44.17h19.42v-44.17h14.48Z" fill="%23ffffff" /%3E%3C/svg%3E') no-repeat center / contain;
--x_icon_w: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100"%3E%3Cpath d="M59.31,42.34L95.74,0h-8.63l-31.63,36.77L30.21,0H1.08l38.2,55.6L1.08,100h8.63l33.4-38.83,26.68,38.83h29.14l-39.62-57.66h0ZM47.49,56.09l-3.87-5.54L12.82,6.5h13.26l24.85,35.55,3.87,5.54,32.31,46.21h-13.26l-26.36-37.71h0Z" fill="%23ffffff"  /%3E%3C/svg%3E') no-repeat center / contain;
--fb_icon: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100"%3E%3Cpath d="M73.09,55.83l2.75-17.96h-17.23v-11.66c0-4.91,2.41-9.7,10.13-9.7h7.84V1.21s-7.11-1.21-13.91-1.21c-14.19,0-23.47,8.6-23.47,24.17v13.69h-15.78v17.96h15.78v44.17h19.42v-44.17h14.48Z" fill="%23000" /%3E%3C/svg%3E') no-repeat center / contain;
--x_icon: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100"%3E%3Cpath d="M59.31,42.34L95.74,0h-8.63l-31.63,36.77L30.21,0H1.08l38.2,55.6L1.08,100h8.63l33.4-38.83,26.68,38.83h29.14l-39.62-57.66h0ZM47.49,56.09l-3.87-5.54L12.82,6.5h13.26l24.85,35.55,3.87,5.54,32.31,46.21h-13.26l-26.36-37.71h0Z" fill="%23000"  /%3E%3C/svg%3E') no-repeat center / contain;

--prev_arrow: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100"%3E%3Cpath d="M65.6 24.57 62.77 21.75 37.32 47.2 34.49 50.03 37.32 52.86 37.32 52.86 62.77 78.31 65.6 75.49 40.14 50.03 65.6 24.57Z" fill="%23cccccc"  /%3E%3C/svg%3E') no-repeat center / contain;
--next_arrow: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100"%3E%3Cpath d="M34.44 24.54 37.27 21.72 62.73 47.17 65.56 50 62.73 52.83 62.73 52.83 37.27 78.28 34.44 75.46 59.9 50 34.44 24.54Z" fill="%23cccccc"  /%3E%3C/svg%3E') no-repeat center / contain;
--prev_arrow_w: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100"%3E%3Cpath d="M65.6 24.57 62.77 21.75 37.32 47.2 34.49 50.03 37.32 52.86 37.32 52.86 62.77 78.31 65.6 75.49 40.14 50.03 65.6 24.57Z" fill="%23fff"  /%3E%3C/svg%3E') no-repeat center / contain;
--next_arrow_w: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100"%3E%3Cpath d="M34.44 24.54 37.27 21.72 62.73 47.17 65.56 50 62.73 52.83 62.73 52.83 37.27 78.28 34.44 75.46 59.9 50 34.44 24.54Z" fill="%23fff"  /%3E%3C/svg%3E') no-repeat center / contain;
--top_arrow_w: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100"%3E%3Cpath d="M24.54 65.56 21.72 62.73 47.17 37.27 50 34.44 52.83 37.27 52.83 37.27 78.28 62.73 75.46 65.56 50 40.1 24.54 65.56Z" fill="%23fff"  /%3E%3C/svg%3E') no-repeat center / contain;
--bottom_arrow_w: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100"%3E%3Cpath d="M75.46,34.44l2.82,2.83-25.45,25.46-2.83,2.83-2.83-2.83h0l-25.45-25.46,2.82-2.83,25.46,25.46,25.46-25.46Z" fill="%23fff"  /%3E%3C/svg%3E') no-repeat center / contain;

--cross_icon: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100"%3E%3Cpath d="M70.55 32.35 67.72 29.52 50.04 47.2 32.37 29.52 29.54 32.35 47.22 50.03 29.54 67.71 32.37 70.54 50.04 52.86 67.72 70.54 70.55 67.71 52.87 50.03 70.55 32.35z" fill="%23fff"  /%3E%3C/svg%3E') no-repeat center / contain;
--burger_icon: url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" width="100" height="100"%3E%3Cpath d="M72,32H28v-4h44v4ZM72,48H28v4h44v-4ZM72,68H28v4h44v-4Z" fill="%23ddd"  /%3E%3C/svg%3E') no-repeat center / contain;
}


