@charset "UTF-8";

/*-----------------------------------
	ページごとの設定
-----------------------------------*/

/*----- page_home -----*/
#page_home{
	box-sizing:border-box;
	width:770px;
	background:url(../img/home_illust_01.jpg) center top no-repeat;
	text-align:left;
	box-shadow: 0 0 5px rgb(0 0 0 / 30%);
}
#page_home .meeting_info{
	position: relative;
	margin:0;
	/*min-height:807px;*/
}
#page_home .meeting_info img{
	width:100%;
	vertical-align:bottom;
	line-height:.5rem;
}
#page_home .meeting_info img.theme{
	display: block;
	margin: 0 auto;
	vertical-align:bottom;
	line-height:.5rem;
}
#page_home .meeting_info img.details {
	display: block;
	vertical-align:bottom;
}
#page_home .term_notice{
	display:flex;
	justify-content:space-between;
	padding:30px 35px;
}
#page_home .term_box{
	margin:0 auto;
	padding:8px 10px;
	width:49%;
	background:rgb(255,255,255);
	border:solid 2px rgb(2,47,128);
	border-radius:6px;
	color:rgb(2,47,128);
	font-weight:600;
	text-align:center;
}
#page_home .term_box b{
	font-weight:900;
}
#page_home .term_box.w95{
	margin:0 auto;
	padding:8px 10px;
	width:95%;
	text-align:left;
}
#page_home .term_box .title{
	margin:0 0 3px;
	padding-bottom:3px;
	border-bottom:dotted 1px rgb(10,67,37);
	font-size:1.25rem;
	line-height:1.3;
}
#page_home .term_box .term{
	margin:0;
	font-size:1.25rem;
	line-height:1.3;
}
#page_home .term_box .note{
	margin:0;
	font-size:.625rem;
	line-height:1.6;
}

#page_home .important_notice01{
	background:rgb(255,255,255);
	border:solid 3px rgb(250,80,80);
	border-radius: 5px;
	padding:0 2rem;
	font-size:1.1rem;
	line-height:1.6;
}
#page_home .important_notice01 h2{
	margin:0 0 .4em;
	padding-bottom:.4em;
	border-bottom:dotted 1px rgb(180,180,180);
	font-size:2.0rem;
	font-weight:500;
	color:rgb(230,60,50);
	line-height:1.4;
	letter-spacing:0.05em;
}
#page_home .important_notice01 .date{
	margin:1.6rem 0;
	padding-right:1.6rem;
	text-align:right;
}
#page_home .important_notice01 .title{
	margin:1.6rem 0 0;
	padding-right:1.6rem;
	font-size:1.4rem;
	text-align:right;
}
#page_home .important_notice01 .name{
	margin:0;
	padding-right:1.6rem;
	font-size:1.6rem;
	text-align:right;
}
#page_home .important_notice01 .small{
	font-size:1.2rem;
	text-align:right;
	color:rgb(0,0,0);
}


#change_log{
	box-sizing:border-box;
	margin:0 auto;
	padding:20px 35px 0;
	width:100%;
	background:rgb(255,255,255);
}
#change_log h2 {
	margin: 0;
	border-bottom: solid 1px rgb(213, 213, 213);
	padding: 0.5rem 0.5em;
	font-size: 1.5rem;
	font-weight: 800;
	color: rgb(2,47,128);
	line-height: 1.4;
	letter-spacing: 0.05em;
}
#change_log .log_outer{
	height:215px;
	overflow-y:scroll;
}
#change_log dl{
	display:flex;
	flex-wrap:wrap;
	margin:0;
	font-size:.937rem;
}
#change_log dl dt,
#change_log dl dd{
	box-sizing:border-box;
	padding-top:.8em;
	padding-bottom:.8em;
	border-bottom:dotted 1px rgb(180,180,180);
	line-height:1.5;
}
#change_log dl dt{
	padding-left:6px;
	width:130px;
}
#change_log dl dt::before{
	box-sizing:border-box;
	content:"";
	display:inline-block;
	width:5px;
	height:5px;
	margin-right:8px;
	background:rgb(2,47,128);
	border-radius:2.5px;
	vertical-align:10%;
}
#change_log dl dd{
	margin:0;
	width:calc(100% - 130px);
}

#change_log dl dd a{
	color:rgb(234,85,50);
	transition:opacity .2s ease-out;
}

#change_log dl dd a:hover{
	opacity:.5;
}

/*--文字色--*/
#page_home .red{
	color:rgb(240,80,80);
}

/*--文字サイズ等--*/
#page_home .big{
	font-size:1.25em;
	line-height:1.5;
}

/*--文字中央ぞろえ--*/
#page_home .ta_c{
	text-align:center;
}

/*------------------------------
	page_message
------------------------------*/
#page_message .text{
	text-indent:1em;
	text-align:justify;
}
#page_message .photo{
	margin:1rem .3rem 0 1.5rem;
	width:140px;
	box-shadow:0 0 5px rgba(0,0,0,.3);
	float:right;
}
#page_message .photo img{
	display:block;
	width:100%;
	line-height:0;
	vertical-align:bottom;
}
#page_message .title{
	margin:123px 0 0;
	padding-right:1rem;
	font-size:1rem;
	line-height:1.5;
	text-align:right;
}
#page_message .name{
	margin:0;
	padding-right:1rem;
	font-size:1.25rem;
	font-weight:700;
	line-height:1.5;
	text-align:right;
}
#page_message .name small{
	font-size:.875rem;
	font-weight:400;
}
#page_message .affi{
	margin:0 0 30px;
	padding-right:1rem;
	font-size:.875rem;
	text-align:right;
}
#page_message .date {
    padding-right: 1rem;
    text-align: right;
}
#page_message .main_text{
	text-indent:1em;
}
#page_message .main_text p{
	margin:0;
}

/*------------------------------
	page_overview
------------------------------*/
#page_overview h2{
	margin-bottom:0;
}
#page_overview dl{
	display:flex;
	flex-wrap:wrap;
	margin:0;
	font-size:.937rem;
}
#page_overview dl dt,
#page_overview dl dd{
	-webkit-box-sizing:border-box;
	box-sizing:border-box;
	padding:1.3em 0.5em;
	border-bottom:solid 1px rgb(200,200,200);
}
#page_overview dl dt{
	margin:0;
	padding-left:1em;
	width:150px;
	color:rgb(2,47,128);
	font-weight:600;
}
#page_overview dl dd{
	margin:0;
	width:calc(100% - 150px);
}

/*------------------------------
	page_program
------------------------------*/
#page_program h3{
	margin-top:3rem;
	position:relative;
}
#page_program h3 span{
	display:flex;
	justify-content:end;
	margin-left:auto;
	margin-top:-1.2em;
	margin-bottom:0;
	font-size:1rem;
}
#page_program .date_and_time{
	margin-top:-.5rem;
	padding:.3em .4em;
	border-bottom:solid 1px rgb(200,200,200);
	font-size:0.875rem;
	font-weight:700;
	line-height:1.5;
	display: inline-block;
	width: 230px;
	width: fit-content;
}
#page_program h4.title{
	color: rgb(90, 31, 4);
	/* margin-top: 1em; */
	border-bottom: none;
	padding-left: 1em;
}
#page_program .session_theme{
	margin:.8em 0 .8em 1rem;
	padding-bottom:.3em;
	font-size:1.125rem;
	font-weight:700;
	border-bottom:dotted 1px rgb(180,180,180);
	color:rgb(2,47,128);
	line-height:1.5;
}
#page_program .sponsor{
	position:absolute;
	display:block;
	padding: 0;
	top:11px;
	right:0;
	font-size:1rem;
	font-weight: 700;
	color: rgb(2,47,128);
	text-align: right;
}
#page_program .speakers_box{
	margin:0 0 0 1rem;
	line-height:1.6;
}
#page_program .speakers_box dt{
	margin:0;
	width:110px;
	border:solid 1px rgb(2,47,128);
	border-radius:3px;
	font-size:.875em;
	font-weight:700;
	color:rgb(2,47,128);
	text-align:center;
	display: inline-block;
	vertical-align: top;
}
#page_program .speakers_box dt.small{
	font-size:.8em;
}
#page_program .speakers_box dt.small_02{
	font-size:.7em;
}
#page_program .speakers_box dt.small_03{
	font-size:.6em;
}
#page_program .speakers_box dd,
#page_program .speakers{
	margin:0 0 0 125px;
	padding-bottom:.6em;
	font-size:.937em;
	font-weight:700;
	width: calc(100% - 125px);
	display: inline-block;
}
#page_program .speakers_box dt+dd{
	margin-left: 11px;
}
#page_program .speakers_box dd.title{
	margin-bottom:.2em;
	padding-bottom:0;
	border-bottom:dotted 1px rgb(180,180,180);
	font-size:1em;
	color:rgb(7, 112, 7);
	line-height:1.4;
	/* margin-top: 0.7em; */
}
/* #page_program .speakers_box dt + dd.title{
	margin-top:-.05em;
} */
#page_program .speakers_box dd .affi,
#page_program .affi{
	display:inline-block;
	padding-left:.5em;
	font-size:.9em;
	font-weight:400;
	text-indent:-.5em;
}
#page_program .speakers_box dd + dt,
#page_program .speakers_box dd + dt + dd{
	margin-top:.5em;
}
#page_program .flyer {
	text-align: center;
	font-size:.8em;
	line-height: 1.5;
	font-weight:600;
}
#page_program .flyer img{
    color: rgba(255,255,255,1.00);
		text-decoration: none;
		display: block;
		cursor: pointer;
		width: 120px;
}
#page_program .flyer a:hover{
	background:rgb(255,255,255,1.00);
	color:rgba(247,147,30,1.00);
	border:solid 1px rgba(247,147,30,1.00);
}
#page_program .session_wrap{
	display: flex;
}
#page_program .credit{
	margin:.9em 0 2.5em 1rem;
	padding:.1em .5em;
	border:solid 1px rgb(160,80,20);
	border-radius:3px;
	font-weight:700;
}
#page_program .credit::before{
	content:"";
	box-sizing:border-box;
	display:inline-block;
	margin-right:6px;
	width:8px;
	height:8px;
	border:solid 2px rgb(160,80,20);
	border-radius:4px;
	vertical-align:6%;
}
#page_program .red_box{
	display:inline-block;
	padding:0 5px;
	background:rgb(240,30,30);
	font-size:.937rem;
	color:rgb(255,255,255);
}
#page_program .blue_box{
	display:inline-block;
	margin-right: 1rem;
	padding:0 5px;
	background:rgb(4, 110, 238);
	font-size:.937rem;
	color:rgb(255,255,255);
}

#page_program .session_box a {
    display: inline-block;
    float: right;
    margin-top: -30px;
    margin-right: 1rem;
    padding: 3px;
    box-shadow: 0 1px 1px 0 rgb(0 0 0 / 50%);
    text-decoration: none;
    font-size: .75rem;
    color: rgb(255,255,255);
    text-align: center;
    line-height: 1.3;
    background: rgb(252,82,3);
    border: solid 1px rgb(255,161,67);
    border-radius: 3px;
    cursor:pointer;
}
#page_program .session_box a:hover {
    background-color: rgb(245,130,30);
    color: rgb(255,255,255);
}



/*------------------------------
	page_cfa
------------------------------*/
#page_cfa .cfa_dl{
	dt{
		display: inline-block;
		width: 6em;
		text-align: right;
	}
	dd{
		display: inline-block;
		width: calc(100% - 7em);
		text-align: left;
		margin-left: 0;
	}
}
#page_cfa th.head{
	background-color: rgb(131, 202, 235);
	text-align: center;
	color: white;
	font-size: 1.1rem;
}
#page_cfa .period {
	padding: .5em 1em;
	border-radius: 5px;
	color: rgb(255, 130, 130);
	font-size: 1.062rem;
	font-weight: 700;
}

#page_cfa .period p {
	padding: .5em 1em;
	border: solid 2px rgb(255, 130, 130);
	border-radius: 5px;
	color: rgb(255, 130, 130);
	text-align: center;
	font-size: 1.062rem;
	font-weight: 700;
}

#page_cfa table.type01 {
	margin: .5em 0;
	width: 100%;
	border-collapse: collapse;
	font-size: .937rem;
	line-height: 1.5;
	text-align: left;
	table-layout: fixed;
}
#page_cfa table.type01 tbody {
	width: 100%;
}
#page_cfa table.type01 th,
#page_cfa table.type01 td {
	padding: .5em .8em;
	border: solid 1px rgb(180, 180, 180);
}
#page_cfa table.type01 tbody th.head {
	background-color: rgb(131, 202, 235);
	text-align: center;
	color: white;
	font-size: 1.1rem;
	width: 100%;
	border-bottom: none;
}
#page_cfa table.type01 tbody th {
	background: rgb(252, 247, 232);
	font-weight: 700;
	width: 50px;
}

#page_cfa .flowchart {
	display: flex;
	justify-content: space-between;
	margin: 1rem 0;
	padding: 0;
	font-size: .937rem;
	line-height: 1.5;
	text-align: center;
	list-style: none;
}

#page_cfa .flowchart li {
	position: relative;
	display: flex;
	flex-wrap: wrap;
	margin-right: 30px;
}

#page_cfa .flowchart li::after {
	position: absolute;
	top: calc(50% - .3em);
	right: -33px;
	content: "";
	display: block;
	box-sizing: border-box;
	width: 1.6rem;
	height: 1rem;
	border-style: solid;
	border-color: rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(255, 200, 100, 1);
	border-width: .8rem 0 .8rem 1rem;
	vertical-align: 10%;
	transition: .2s ease-out;
	transition-opacity: right, border;
}

#page_cfa .flowchart li:last-child {
	margin-right: 0;
}

#page_cfa .flowchart li:last-child::after {
	content: none;
}

#page_cfa .flowchart li .name {
	box-sizing: border-box;
	margin: 0;
	padding: .5rem .5rem;
	width: 100%;
	background: rgb(150, 180, 160);
	color: rgb(255, 255, 255);
	font-weight: 500;
}

#page_cfa .flowchart li .description {
	margin: 0;
	padding: 1rem 1rem 2rem .8rem;
	width: 100%;
	min-height: 35px;
	background: rgb(210, 230, 220);
}

#page_cfa .flowchart li .description.end {
	padding-top: 30px;
	min-width: 170px;
	background: rgb(50, 140, 80);
	color: rgb(255, 255, 255);
}

#page_cfa .step_box {
	margin: 50px 0 0 15px;
	padding-left: 18px;
	border-top: solid 3px rgb(50, 140, 80);
	border-left: solid 1px rgb(50, 140, 80);
}

#page_cfa .bg_pink {
	display: inline-block;
	margin: 0 .3em;
	padding: 0 .3em;
	background: rgb(240, 130, 150);
	border-radius: 3px;
	color: rgb(255, 255, 255);
	font-weight: 500;
}
#page_cfa .border{
	display: inline-block;
	position: relative;
}

#page_cfa .border:before {
	position: absolute;
	content: '';
	width: 100%;
	height: 1px;
	border-top: solid 1px rgb(244, 67, 54);
	left: 0 ;
	top: calc(50% - 4px) ;
}

#page_cfa .border:after {
	position: absolute;
	content: '';
	width: 100%;
	height: 1px;
	border-bottom: solid 1px rgb(244, 67, 54);
	left: 0 ;
	bottom: calc(50% - 4px);
}



/*------------------------------
	page_presenter
------------------------------*/




/*------------------------------
	page_performer
------------------------------*/




/*------------------------------
	page_access
------------------------------*/
#page_access .venuename{
	font-size:1.25rem;
	font-weight:700;
}

#page_access .googlemap{
	margin:1.5em 0;
	width:100%;
	height:400px;
	box-shadow:0 0 5px rgba(0,0,0,.2);
}

#page_access .float_right{
	width:380px;
	float:right;
}

#page_access .float_right img{
	width:100%;
}

#page_access .map_box{
	margin:20px auto;
	width:650px;
}

#page_access .map_box img{
	width:100%;
}

/*------------------------------
	page_link
------------------------------*/
#page_links dl dt::before{
	content: "";
	position: absolute;
	top: 50%;
	left: 2px;
	display: block;
	width: 4px;
	height: 4px;
	background: rgb(239,57,74);
}
#page_links dl dt{
	box-sizing:border-box;
	font-weight:700;
	padding-left:1em;
	position:relative;
}
#page_links dl dd{
	box-sizing:border-box;
	margin:0 0 25px 18px;
	font-weight:700;
}
#page_links dl dd a{
	display:block;
	box-sizing:border-box;
	width:100%;
	position: relative;
	border-bottom:1px rgba(60,60,60,0) dotted;
	color:rgb(0,100,160);
	text-decoration:none;
	transition:.2s ease-out;
	transition-property:background,color,border-radius,padding-left;
}
#page_links dl a:hover{
	display:inline-block;
	padding-left:10px;
	border-bottom:1px rgb(0,100,160) dotted;
	transition:.2s ease-out;
	transition-property:background,color,border-radius,padding-left;
}
#page_links dl a::after{
	content: "";
	position: absolute;
	right: 0;
	width:10px;
	height: 0px;
	margin: auto;
	border-left: 10px solid rgb(234,85,50);
	border-top: 10px solid transparent;
	border-bottom: 10px solid transparent;
	transition:.2s ease-out;
}
#page_links dl a:hover::after{
	content: "";
	position: absolute;
	right:10px;
	width:10px;
	height: 0px;
	margin: auto;
	border-left: 10px solid rgb(234,85,50);
	border-top: 10px solid transparent;
	border-bottom: 10px solid transparent;
}
/*------------------------------
	page_registration
------------------------------*/
#page_registration .period {
	padding: .5em 1em;
	border-radius: 5px;
	color: rgb(255, 130, 130);
	font-size: 1.2rem;
	font-weight: 700;
}
/*------------------------------
	page_access
------------------------------*/
#page_access section dl{
	display: flex;
}
#page_access section dl dt{
	font-weight: 700;
}
#page_access section>dl dd{
	text-align: left;
	margin-left: 0;
}
#page_access dl dd{
	text-align: left;
	margin-left: 2rem;
}
