/*全体設定*/
* {
	font-size:100%;
	font-family:Meiryo,'メイリオ',ArialMT,Hiragino Kaku Gothic Pro,'ヒラギノ角ゴ Pro W3',Osaka,Verdana,'ＭＳ Ｐゴシック';
}
body {
	margin:0;
	padding:0;
	background:#f5f5f5;
}
body.dir-index {
	background:#fff;
}
img {
	border:none;
}
a,button,select,input[type="checkbox"],input[type="radio"] {
	cursor:pointer;
}
a:link,a:visited,a:hover,a:active {
	text-decoration:none;
}
.rapper {
	width:970px;
	margin:auto;
	padding:0 20px;
	background:#fff;
	box-shadow:0 0 7px 0 #cecece;
}
.dir-index .mainCont {
	width:660px;
	float:none;
	margin:auto;
	word-break:break-all;
}
.mainCol {
	width:100%;
	background:#fff;
}
.mainColInner {
	width:970px;
	margin:auto;
}

/*基本パーツ*/
.mainCont {
	width:660px;
	float:left;
}
h1 {
	margin:15px 0 0 0;
	padding:0;
}
h2 {
	margin:0;
	padding:7px;
	border-bottom:solid 1px #999;
}
.dir-index h2 {
	margin:40px 0 10px 0;
	clear:both;
}
.dir-enq h2, .dir-confirm h2, .dir-complete h2 {
	width:640px;
}
#column_left h3 {
	margin-top:10px;
	font-size:120%;
}
.leadtext {
	font-size:.9em;
	text-align:justify;
}

/*表組み*/
table {
	width:100%;
	margin:0 0 15px 0;
	border-spacing:0;
	font-size:small;
}
table th,table td {
	border-bottom:dotted 1px #ccc;
	padding:6px;
	vertical-align:top;
}
table th {
	text-align:right;
}
.noBorder th,.noBorder td {
	border-top:none;
	border-bottom:none;
}
.noText th {
	color:transparent;
	font-size:0px;
}
table td ul {
	list-style-type:none;
	margin:0;
	padding:0;
	font-size:12px;
	color:#999;
}
th.hedding {
	background:linear-gradient(#fff,#efefef);
	text-align:left;
}
th.hedding h3 {
	margin:0;
	color: #333;
}
td select {
	margin:0 5px 5px 0;
	border:solid 1px #999;
	border-radius:6px;
	padding:3px;
	background:#fff;
}
td input[type="text"] {
	display:inline-block;
	margin:0 5px 5px 0;
	border:solid 1px #999;
	border-radius:6px;
	padding:4px;
	font-size:13px;
	background:#fff;
}
td input[type="text"]:focus,td input[type="checkbox"]:focus,td input[type="radio"]:focus,td select:focus,td textarea:focus {
	border:solid 1px #56b4ef;
	background:#eff;
	box-shadow:inset 0 1px 3px rgba(0,0,0,0.05), 0 0 8px rgba(82,168,236,0.6);
}
.time_tb th {
	width:20%;
	font-weight:normal;
}
.time_tb td {
	padding-left:20px;
}
.time_tb h4,.time_tb h5 {
	margin:0 0 10px;
	font-size: 1.2em;
}
.time_tb p {
	margin:10px;
	text-align:justify;
}
.dir-enq .userTable th {
	padding:11px 6px 0 0;
}
.userTable th {
	width:120px;
	white-space:nowrap;
}
.userTable th.long {
	width:640px;
	text-align:left;
	white-space:normal;
}
.dir-confirm .table-cart th {
	text-align:left;
}
.dir-complete .mainColInner {
	width:640px;
}

/*講演者紹介*/
.flex {
	display:flex;
	flex-wrap:wrap;
	margin:0 auto -40px;
}
.flex .sp_data {
	display:flex;
	width:100%;
	margin:0 0 30px;
}
.flex .sp_img {
	width:120px;
	padding:0 0 0 10px;
}
.flex .sp_img img {
	border-radius:5px;
	box-shadow:0px 0px 5px 2px #ddd;
}
.flex .sp_text {
	margin:0;
	padding-left:15px;
	font-size:.8em;
}
.speaker_profile_attached {
	display:block;
}
.speaker_data_name {
	display:block;
}
.speaker_profile_data {
	display:block;
	margin-top:15px;
	text-align:justify;
	font-size:11px;
}

/*右カラム*/
.navBarOuter {
	width:300px;
	float:right;
}
.navBarInner {
	width:290px;
	position:fixed;
	z-index:998;
	margin-left:10px;
}
.navBar {
	margin-top:15px;
}
.navBar * {
	font-size:small;
}
.infoArea .hedding span {
	display:inline-block;
}
.navButton {
	display:block;
	position:relative;
	z-index:0;
	text-align:center;
	width:80%;
	height:50px;
	margin:0 auto;
}
.navButton:before {
	content:'';
	width:100%;
	height:100%;
	position:absolute;
	left:0;
	z-index:-1;
	border-radius:6px;
	background:linear-gradient(#6be, #36b);
	transition:.2s;
}
.navButton:after {
	content:'';
	width:100%;
	height:100%;
	position:absolute;
	left:0;
	z-index:-2;
	border-radius:6px;
	background:linear-gradient(#6cf, #48d);
}
.navButton:hover:before {
	opacity:0;
}
.navButton a {
	display:inline-block;
	text-decoration:none;
	width:100%;
	height:100%;
	font-weight:normal;
	font-size:24px;
	line-height:56px;
	color:#fff;
}
.navButton button {
	width:100%;
	height:100%;
	border:none;
	font-weight:normal;
	background:transparent;
	font-size:24px;
	line-height:56px;
	color:#fff;
}
.subButton {
	display:flex;
}
.subgo {
	width:50%;
	order:2;
}
.subback {
	width:25%;
	order:1;
}
.subButton .subback.navButton:before {
	background:linear-gradient(#ccc,#666);
}
.subButton .subback.navButton:after {
	background:linear-gradient(#ddd,#999);
}
.infoAreaSpecsBox {
	float:left;
	margin:0 5px 0 0;
	border:solid 1px #999;
	border-radius:6px;
}
.infoAreaSpecs small,.infoAreaSpecs strong {
	width:70px;
	display:block;
	float:left;
	text-align:center;
}
.infoAreaSpecs small {
	padding:2px 0;
	background:#dedede;
}
.infoAreaSpecs strong {
	padding:7px 0;
	font-size:large;
	clear:both;
}
.infoAreaSpecs span {
	display:none;
}
.snsBox * {
	float:right;
}
.snsBoxTw {
	margin-right:5px;
}
.snsBoxFb {
	margin-right:5px;
}
.snsBoxGc {
	margin-right:5px;
}
.snsBoxGc a {
	display:inline-block;
	border-radius:3px;
	padding:2px 5px 1px;
	font-size:11px;
	color:#fff;
	background:#369;
}
.snsBoxGc a:hover {
	filter:saturate(50%);
}

.dir-complete .snsBoxGc {
	display:inline-block;
	margin:0;
}
.dir-complete .snsBoxGc a {
	display:inline-block;
	margin:-5px 10px;
	border-radius:3px;
	padding:5px 10px;
	font-size:14px;
	color:#fff;
	background:#369;
}
.dir-complete .snsBoxGc a:hover {
	filter:saturate(50%);
}

/*主催・共催・協賛*/
.sponsorInfo {
	float:right;
	width:290px;
	position:relative;
	z-index:999;
	background:#fff;
	box-shadow:0 0 30px 50px rgba(255,255,255,1);
	clip-path:inset(-100px 0);
	-webkit-clip-path:inset(-100px 0);
	color:#666;
	font-size:16px;
	clear:both;
}
.sponsorInfo h2 {
	width:260px;
}
.dir-index .sponsorInfo {
	display:none;
	width:auto;
	float:left;
	color:#000;
	font-size:16px;
	box-shadow:none;
}
.dir-index .sponsorInfo h2 {
	clear:both;
}
.dir-enq .sponsorInfo p , .dir-session .sponsorInfo p {
	margin:0 auto 20px;
	text-align:center;
	color:#666;
	font-size:120%;
	font-weight:bold;
}
.dir-enq .sponsorInfo img , .dir-session .sponsorInfo img {
	width:200px;
	margin:auto;
}

/*かんたん入力*/
.suggestBox img {
	float:left;
}
.suggestBox {
	width:250px;
	position:absolute;
	margin:5px 0 0 386px;
	border:solid 1px #bb9;
	border-radius:6px;
	padding:10px;
	background:#ffc;
	background-clip:padding-box;
	box-shadow:0 5px 10px rgba(0,0,0,0.2);
	text-align:center;
	font-size:small;
}
.suggestBox:before {
	content:'';
	position:absolute;
	top:10px;
	left:-15px;
	border-right:solid 15px #bb9;
	border-top:solid 7px transparent;
	border-bottom:solid 7px transparent;
	color:#f0c14b;
}
.suggestBox:after {
	content:'';
	position:absolute;
	top:10px;
	left:-13px;
	border-right:solid 15px #ffc;
	border-top:solid 7px transparent;
	border-bottom:solid 7px transparent;
}
#signature {
	width:244px;
	margin:10px 0;
	font-size:12px;
	font-family:'MS Gothic',mono;
	line-height:1.4;
	color:#999;
}
#suggestBoxClose {
	position:absolute;
	top:-3px;
	right:0px;
	float:right;
	padding:10px 5px 7px 5px;
	line-height:1;
}
#suggestBoxClose a {
	text-decoration:none;
	font-size:large;
	font-weight:bold;
}
#suggestBoxSubmit {
	display:block;
	margin:0 0 10px 0;
}
#suggestBoxDisp {
	float:right;
	margin:5px 30px 0 5px;
}
#suggestBoxSubmit a,#suggestBoxDisp a {
	display:block;
	padding:3px 8px 2px 8px;
	border:solid 1px #bf942a;
	border-radius:6px;
	box-shadow:inset 0 1px 0 rgba(255,255,255,.1);
	color:#332;
	background:linear-gradient(#f7dfa5,#f0c14b);
	text-align:center;
	text-decoration:none;
	text-shadow:0 1px 1px rgba(255,255,255,1);
	font-size:14px;
	font-weight:bold;
}
#suggestBoxSubmit a:hover,#suggestBoxDisp a:hover {
	background:#f0c14b;
}
.kantanLogo {
	width:236px;
}

/*フォーム*/
.upComment {
	margin:0;
	color:#000;
}
.application_link {
	width:640px;
}
.application_link .golink {
	display:none;
}
.dir-enq label:hover {
	background:#eff;
	box-shadow:0 0 5px 3px #eff;
}
.dir-session form, .dir-enq form, .dir-confirm form, .dir-complete form {
	width:640px;
}
.dir-confirm .mainColInner {
	width:640px;
}
.dir-confirm form {
	margin:auto;
}
.notnull_tag {
	border-bottom:solid 2px #c00;
	line-height:1;
}

/*プライバシーポリシー*/
.privacypolicy {
	background:#fcfcfc;
	border:solid 1px #ccc;
	line-height:1.4;
	padding:5px;
}
.privacypolicy h3{
	margin:0;
	font-weight:bold;
	color:#333;
}
.privacypolicy ul{
	margin:5px 0 5px 10px;
	list-style-type:disc;
}
.privacypolicy ul li {
	margin:5px;
	font-size:0.9em;
	color:#666;
	line-height:1.4em;
}
.privacypolicy a:link {
	color:#00c !important;
}
.privacypolicy a:visited {
	color:#934C7B !important;
}

/*お問い合わせ*/
.credit {
	margin-top:40px;
	padding-bottom:20px;
}
.credit p {
	margin-left:20px;
	font-size:12px;
}
#credit_option {
	white-space:pre;
}

/*来場者アンケート*/
.VisitorEnquete { display:none; }
.unVisitorEnquete {}

/*その他*/
.program_speaker {
	margin-top:30px !important;
	border-left:solid 2px #ddd;
	padding-left:10px;
}
.annotation {
	margin:10px 0 20px;
	font-size:.8em;
}
.pageTop {
	display:block;
	float:right;
	margin:10px 0 10px 5px;
	border-radius:6px;
	padding:10px 15px;
	text-align:center;
	text-decoration:none;
	background:#bbb;
	color:#fff;
}
.pageTop a {
	text-decoration:none;
	color:#ccc;
}
.commentBox {
	width:470px;
	font-size:small;
	background:#FFC;
	margin-top:10px;
	margin-left:10px;
	padding:10px;
	border:1px solid #BB9;
	border-radius:6px;
	position:relative;
}
.commentBox:before {
	content:'';
	position:absolute;
	border-right:15px solid #BB9;
	border-top:7px solid transparent;
	border-bottom:7px solid transparent;
	top:10px;
	left:-15px;
	color:#664;
}
.commentBox:after {
	content:'';
	position:absolute;
	border-right:15px solid #FFC;
	border-top:7px solid transparent;
	border-bottom:7px solid transparent;
	top:10px;
	left:-13px;
}
