@charset "utf-8";

/* 出展企業フォーム---------- */

.spk_form .c_wrap {
	padding-top: 30px;
}

.form_wrap {
	padding: 30px 50px;
	background: #fff;
	width: 100%;
	margin: 0 auto;
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	border-radius: 6px;
	-webkit-box-shadow: 0 0 2px rgb(26 45 59 / 20%);
	box-shadow: 0 0 2px rgb(26 45 59 / 20%);
	margin-top: 30px;
}

.color_btn {
	padding: 10px;
	min-width: 240px;
	width: 20%;
	display: block;
	margin-left: 10px;
}

#input-param ul {
	margin-top: 30px;
	width: 100%;
	margin: auto;
}

#input-param ul li {}

#input-param ul li + li {
	margin-top: 40px;
}

textarea,
select {
	width: 100%;
	font-family: source-han-sans-japanese, "游ゴシック", "Yu Gothic", "メイリオ", "Meiryo UI", sans-serif;
	font-weight: 500;
	background-color: #f3f2f2;
	border-radius: 5px;
	padding: 10px;
	border: none;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}

form#form {
	width: 100%;
}

#input-param {
	max-width: 920px;
	margin: auto;
}

input {
	background-color: #f3f2f2;
	border: none;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	border-radius: 5px;
	box-sizing: border-box;
	line-height: 3;
	font-family: source-han-sans-japanese, "游ゴシック", "Yu Gothic", "メイリオ", "Meiryo UI", sans-serif;
	font-weight: 500;
	padding: 0 10px;
}

textarea:focus,
input:focus {
	outline: none;
	border: 3px solid #5edfff!important;
	border-radius: 5px;
	transition: 0.3s;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}

input[type="text"] {
	width: 100%;
}

input[type="file"] {
	background: none;
	padding: 0;
}

input[type="file"]:focus {
	border: none!important;
}

.read_txt {
	max-width: 920px;
	margin: auto;
	margin-bottom: 10px;
}

.read_txt_sup {
	font-size: 1.4rem;
}

.read_txt + .flex {
	max-width: 920px;
	margin: auto;
	align-items: center;
}


/* 必須 */

.required {
	color: #ff0000;
	font-weight: bold;
	margin-left: 5px;
}

.required_txt {
	text-align: end;
	margin: auto;
}


/* タイトル */

.tit,
.sub_tit {
	font-weight: 600;
	display: block;
	margin-bottom: 10px;
}

.tit {
	font-size: 1.6rem;
	border-left: 2px solid #1155d0;
	padding-left: 10px;
	color: #1155d0;
}

.sub_tit {
	margin-top: 20px;
	font-size: 1.3rem;
}


/* 英語タイトル */

span.en_title {
	font-size: 1.2rem;
	color: #464646;
	margin-left: 5px;
}

.tit span.en_title {
	margin-left: 8px;
}


/* 横並び記入 */

.col_cont {
	display: grid;
	grid-template-columns: 150px 1fr 1fr;
	gap: 20px;
}

li .col_cont:nth-of-type(2) {
	border-top: 1px solid #e9e9e9;
	margin-top: 20px;
}

.button_sub {
	margin: auto;
	text-align: center;
	position: relative;
	z-index: 55;
}

.ex {
	display: block;
	font-size: 1.2rem;
	color: #666;
	font-weight: normal;
	margin-top: 5px;
}

.ex + .ex {
	margin-top: 0;
}


/* 注意文 */

.att_txt {
	text-indent: -1em;
	padding-left: 1em;
}

.att_txt::before {
	content: "※";
}


/* 中黒テキスト */

.dod_txt {
	text-indent: -1em;
	padding-left: 1em;
}

.dod_txt::before {
	content: "・";
}


/* 説明テキスト */

.desc_txt {
	font-size: 1.3rem;
}

.desc_txt .en {
	color: #464646;
	font-size: 1.2rem;
	display: block;
	margin-top: 5px;
}

.indent {
	padding-left: 1em;
	text-indent: -1em;
	display: block;
}

button, a.button {
	background-image: -moz-linear-gradient( 156deg, rgb(12, 26, 95) 0%, rgb(0, 160, 224) 100%);
	background-image: -webkit-linear-gradient( 156deg, rgb(12, 26, 95) 0%, rgb(0, 160, 224) 100%);
	background-image: -ms-linear-gradient( 156deg, rgb(12, 26, 95) 0%, rgb(0, 160, 224) 100%);
	max-width: 900px;
	margin: 30px auto 0;
	color: #fff;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	padding: 15px 70px;
	outline: none;
	border: none;
	font-family: source-han-sans-japanese, "游ゴシック", "Yu Gothic", "メイリオ", "Meiryo UI", sans-serif;
	border-radius: 50px;
	cursor: pointer;
	transition: 0.3s;
	font-size: 1.5rem;
	font-weight: 500;
	color: #fff;
    max-width: max-content;
}
button.btn_green, a.button.btn_green {
	background-image: -moz-linear-gradient(156deg, rgb(12 95 38) 0%, rgb(186 224 0) 100%);
	background-image: -webkit-linear-gradient(156deg, rgb(12 95 38) 0%, rgb(186 224 0) 100%);
	background-image: -ms-linear-gradient(156deg, rgb(12 95 38) 0%, rgb(186 224 0) 100%);
}

button:hover {
	opacity: .7;
}

.loader .txt {
	font-family: source-han-sans-japanese, "游ゴシック", "Yu Gothic", "メイリオ", "Meiryo UI", sans-serif;
}

::placeholder {
	color: #bbbbbb;
}


/* エラー---- */

.errors_txt {
	background: #fff1f1;
	padding: 10px;
	margin-top: 5px;
	display: block;
}

@media screen and ( max-width: 900px) {}

@media screen and ( max-width: 850px) {
	.form_wrap {
		padding: 30px 20px;
	}
	.read_txt_sup {
		width: 100%;
		/* text-align: center; */
		margin-bottom: 20px;
	}
}

@media screen and (max-width: 480px) {
	.form_wrap {
		padding: 10px 20px;
	}
	.color_btn {
		width: 100%;
		margin-left: 0;
	}
}


/* 送信完了  -------------------------*/

.completion h3 {
	text-align: center;
	font-weight: 500;
}

.completion h3 span {
	font-weight: 500;
	display: block;
	margin-top: 5px;
}

.completion .form_wrap {
	padding: 30px 10px;
}


/* 内容確認 -------------------------ダイアログのデザイン --*/

#dialog-confirm ul li + li {
	margin-top: 10px;
}

#dialog-confirm .form_title {
	font-size: 1.5rem;
	color: #000;
	font-family: 'source-han-sans-japanese';
	font-size: 1.5rem;
	font-weight: bold;
	margin: 0;
	display: block;
	background: #ebebeb;
	width: 100%;
	padding: 10px;
	/* font-weight: bold; */
	border: 0;
}

.ui-dialog {
	top: 100px!important;
}

.ui-dialog .ui-dialog-content {
	padding: 0 20px;
}

#dialog-confirm .form_title span {
	min-height: 0;
	padding: 0;
	font-weight: bold;
	display: inline-block;
	margin-top: 0;
}

#dialog-confirm .form_title span.en {
	font-size: 1.2rem;
	margin-left: 5px;
	color: #727272;
}

#dialog-confirm .content_confi {
	display: block;
	padding: 5px 10px;
	margin-top: 5px;
}

p.confi_txt {
	font-family: 'source-han-sans-japanese';
	display: block;
	/* background: #f5f5f5; */
	min-height: 30px;
	padding: 10px;
}

p.confi_txt {
	color: #f80000;
	font-weight: 500;
}

p.confi_txt::before {
	color: inherit;
	font-family: "Font Awesome 5 Free";
	font-weight: 700;
	content: '\f071';
	margin-right: 10px;
	color: #f80000;
}


/* ダイアログのタイトル */

.ui-dialog-titlebar {
	color: #ffffff;
	background: #1155d0;
	font-family: 'source-han-sans-japanese';
	font-weight: bold;
}


/* ダイアログの内容 */

.ui-dialog.ui-corner-all.ui-widget.ui-widget-content.ui-front.ui-dialog-buttons.ui-draggable.ui-resizable {
	width: 70%!important;
	/*position: fixed!important;
    top: 0!important;*/
}

.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset {
	text-align: center;
	display: flex;
}

button.ui-button.ui-corner-all.ui-widget {
	background-image: -moz-linear-gradient( 156deg, rgb(12, 26, 95) 0%, rgb(0, 160, 224) 100%);
	background-image: -webkit-linear-gradient( 156deg, rgb(12, 26, 95) 0%, rgb(0, 160, 224) 100%);
	background-image: -ms-linear-gradient( 156deg, rgb(12, 26, 95) 0%, rgb(0, 160, 224) 100%);
	color: #fff;
	padding: 10px 50px;
	font-family: source-han-sans-japanese, "游ゴシック", "Yu Gothic", "メイリオ", "Meiryo UI", sans-serif;
	border-radius: 50px;
	cursor: pointer;
	transition: 0.3s;
}

button.ui-button.ui-corner-all.ui-widget:first-of-type {
	background: #b7b7b7;
}

button.ui-button.ui-corner-all.ui-widget.ui-button-icon-only.ui-dialog-titlebar-close {
	padding: 0;
	background: #fff;
	border-radius: 5px;
}

.ui-dialog .ui-dialog-title {
	font-size: 2rem;
	font-weight: bold;
}

@media screen and (max-width: 480px) {
	.ui-dialog.ui-corner-all.ui-widget.ui-widget-content.ui-front.ui-dialog-buttons.ui-draggable.ui-resizable {
		width: 90%!important;
	}
	.button_sub {
		z-index: 1;
	}
	.read_txt_sup {
		font-size: 1.2rem;
	}
}

.gray_box {
	padding: 10px;
	background: #f8f8f8;
	border: 1px solid #e9e9e9;
	margin-top: 10px;
}

.gray_box_col_cont {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 15px;
}
@media screen and (max-width: 480px) {
	.gray_box_col_cont {
		grid-template-columns: 1fr;
		gap: 10px;
	}
}

.checkbox_input {
	margin-top: 20px;
	display: flex;
	align-items: center;
	cursor: pointer;
	width: 100%;
	justify-content: space-between;
}

.checkbox_input input[type="checkbox"] {
	margin: 0;
	width: 0;
	opacity: 0;
}

.checkbox_input:hover .checkbox_input_text {
	font-weight: bold;
}

.checkbox_input input[type="checkbox"]:focus + .checkbox_input_dummy {
	border: dashed 1px #1155d0;
}

.checkbox_input input[type="checkbox"]:checked + .checkbox_input_dummy {
	background: #1155d0;
}

.checkbox_input input[type="checkbox"]:checked + .checkbox_input_dummy + .checkbox_input_text {
	font-weight: bold;
}

.checkbox_input input[type="checkbox"]:checked + .checkbox_input_dummy::before {
	content: "";
	display: block;
	position: absolute;
	top: 34%;
	left: 56%;
	width: 40%;
	height: 3px;
	border-radius: 2px;
	transform: translate(-6px, 5px) rotateZ(-135deg);
	transform-origin: 2px 2px;
	background: #FFFFFF;
}

.checkbox_input input[type="checkbox"]:checked + .checkbox_input_dummy::after {
	content: "";
	display: block;
	position: absolute;
	top: 40%;
	left: 60%;
	width: 76%;
	height: 3px;
	border-radius: 2px;
	transform: translate(-6px, 5px) rotateZ(-45deg);
	transform-origin: 2px 2px;
	background: #FFFFFF;
}

.checkbox_input_dummy {
	position: relative;
	top: 0;
	left: 0;
	display: block;
	width: 20px;
	height: 20px;
	border: solid 1px transparent;
	background: rgba(0, 0, 0, .1);
	border-radius: 4px;
}

.checkbox_input_text {
	margin-left: 5px;
	display: block;
	width: calc(100% - 25px);
}

/* 名前横並び */
.name_col {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}

#dialog-confirm .name_col p {
	padding: 0 10px;
}

#dialog-confirm .name_col p + p {
	padding-left: 0;
}

#dialog-confirm .name_col span {
	padding: 5px 0px;
}


/* 同意ダイアログ */
/*speaker_contractエリアをはじめは非表示*/
.speaker_contract{
	display: none;
}

/*モーダルの横幅を変更したい場合*/
.speaker_contract .modaal-container{
    max-width: 900px;
}
/*モーダルのボタンの色を変更したい場合*/
.speaker_contract .modaal-close:after, 
.speaker_contract .modaal-close:before{
	background:#ccc;	
}
.speaker_contract .modaal-close:focus:after,
.speaker_contract .modaal-close:focus:before,
.speaker_contract .modaal-close:hover:after,
.speaker_contract .modaal-close:hover:before{
	background:#666;
}

.speaker_contract_list{
}
.speaker_contract_list li {
}
.speaker_contract_list > li + li{
	margin-top: 10px;
}
.speaker_contract_list li h3{
	font-weight: bold;
	margin-bottom: 5px;
}
.center{
    text-align: center;
}
.center .color_btn{
	margin: auto;
}


/* セッションフォーム */
.ssn_form{}

.ssn_form .col_cont.name{
    grid-template-columns: 1fr 1fr;
}
.ssn_form #input-param .col_cont.name li + li {
    margin-top: 0;
}


/* ラジオボタン */
.radio_btn{
	display: flex;
	flex-wrap: wrap;
}

.radio_btn label{
	font-weight: bold;
}

.radio_btn label {
	position: relative;
	cursor: pointer;
	padding-left: 35px;
	margin-right: 15px;
}

.radio_btn label::before,
.radio_btn label::after {
	content: "";
	display: block; 
	border-radius: 50%;
	position: absolute;
	transform: translateY(-50%);
	top: 50%;
}

.radio_btn label::before {
	background-color: #fff;
	border: 1px solid #ddd;
	border-radius: 50%;
	width: 20px;
	height: 20px;
	left: 5px;
}

.radio_btn label::after {
	background-color: #1155d0;
	border-radius: 50%;
	opacity: 0;
	width: 12px;
	height: 12px;
	left: 10px;
}

.radio_btn input:checked + label {
	color: #1155d0;
}

.radio_btn input:checked + label::after {
	opacity: 1;
}

.radio_btn input {
	position: absolute;
	white-space: nowrap;
	border: 0;
	clip: rect(0 0 0 0);
	clip-path: inset(50%);
	overflow: hidden;
	height: 1px;
	width: 1px;
	margin: -1px;
	padding: 0;
}

/* ============================================== */
/* スピーカーエントリーフォーム固有スタイル */
/* ============================================== */

/* ローダー */
.loader {
    opacity: 0.8;
    position: fixed;
    width: 100%;
    height: 100vh;
    background-color: #fff;
    z-index: 555;
    top: 0;
    left: 0;
    display: flex;
    justify-content: center;
    align-items: center;
}
.loader .txt {
    font-size: 45px;
    font-weight: bold;
    color: rgb(30, 50, 93);
}
.ui-dialog {
    top: 100px !important;
}

.info_text {
    max-width: 920px;
    margin: auto;
    text-align: right;
}

.notice_text {
    max-width: 920px;
    margin: 20px auto;
    padding: 16px 20px;
    background-color: #fff8e1;
    border-left: 5px solid #f5a623;
    color: #8a6d00;
    font-size: 16px;
    font-weight: bold;
    border-radius: 4px;
}
.notice_text span {
    font-size: 14px;
}

/* セクションカード */
.section_card {
    padding: 28px 32px;
    margin: 0 0 30px 0;
    border-radius: 8px;
    box-sizing: border-box;
}
.section_card + .section_card {
    margin-top: 40px;
}
.section_card_info {
    background-color: #f6f8ff;
}
.section_card_entry {
    background-color: #f4fff3;
}
.section_card ul {
    margin: 0 !important;
}
/* カード内のセクション見出し */
.form_wrap .section_card ul li.section_heading_li {
    list-style: none;
    background: transparent;
    color: #0d47a1;
    padding: 0 0 16px;
    margin: 0 0 8px;
    border: none;
    border-bottom: 2px solid rgba(13, 71, 161, 0.3);
    font-size: 22px;
    font-weight: bold;
    line-height: 1.5;
}
.form_wrap .section_card ul li.section_heading_li .en_title {
    color: #1565c0;
    font-size: 14px;
    margin-left: 12px;
    font-weight: normal;
}
/* 見出し直後のliは余白詰め */
.form_wrap .section_card ul li.section_heading_li + li {
    margin-top: 24px !important;
}