@charset "utf-8";

* {
	list-style: none;
	margin: 0px;
	padding: 0px;
	font-family: 'Public Sans', 'Noto Sans JP', sans-serif;
	font-weight: 400;
}

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	background: transparent;
}

main,
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

img {
	display: block;
	width: 100%;
}

a {
	text-decoration: none;
}

/* =============================================
	アクティングアラート
============================================= */
#acting_alert {
  position: absolute;
  left: 0px;
  top: 0px;
  width: 240px;
  margin: 5px;
  z-index: 99999;
  opacity: .60;
  -moz-opacity: .60;
  filter: progid:DXImageTransform.Microsoft.Alpha(opacity=60);
}
#acting_alert span.top, #acting_alert span.bottom {
  display: block;
  background: #fff;
}
#acting_alert span.top span, #acting_alert span.bottom span {
  display: block;
  height: 1px;
  overflow: hidden;
  background: #1393c0;
}
#acting_alert span.r1 {
  margin: 0 5px;
}
#acting_alert span.r2 {
  margin: 0 3px;
}
#acting_alert span.r3 {
  margin: 0 2px;
}
#acting_alert span.top span.r4, span.bottom span.r4 {
  margin: 0 1px;
  height: 2px;
}
#acting_alert p.close_alert {
  margin: 0;
  padding: 3px;
  background: #1393c0;
  text-align: right;
  height: 25px;
}
#acting_alert .close_alert a {
  background-image: url(/static/upload/relation.oki.com/system/seminar_base/shared/img/bannerClose.gif);
  display: block;
  width: 23px;
  height: 23px;
}
#acting_alert .close_alert a img {
  display: none;
}
#acting_alert p.content {
  padding: 1em;
  margin: 0;
  background: #fff;
  border: 1px solid #1393c0;
  height: 100%;
}
#acting_alert span.item {
  font-size: 12px;
}
#acting_alert a {
  color: #0088cc;
  text-decoration: none;
}
#acting_alert p.close_alert{
  height: 30px;
}

/* =============================================
	No Script
============================================= */
noscript .alert-error,
.alert-error.alert-cookie {
  color: #b94a48;
  background-color: #f2dede;
  border-color: #eed3d7;
  width: 500px;
  margin: 30px auto;
}
noscript .alert,
.alert.alert-cookie {
  margin-bottom: 20px;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.5);
  background-color: #f2dede;
  border: 1px solid #fbeed5;
  -webkit-border-radius: 4px;
  -moz-border-radius: 4px;
  border-radius: 4px;
  padding-top: 8px;
  padding-right: 14px;
  padding-bottom: 8px;
  padding-left: 14px;
  line-height: 150%;
}
@media (width < 768px){
  noscript .alert-error,
  .alert-error.alert-cookie {
    width: 90%;
    margin: 30px auto;
  }
}
noscript .alert-error h4,
.alert-error.alert-cookie h4 {
  color: #b94a48;
}

/* =============================================
  	ヘッダー
============================================= */
.header {
  position: relative;
  margin-bottom: 10px;
  padding: 8vw 0 0;
  background-image: url(../user/images/header.jpg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: right center;
}
.header::before {
  position: absolute;
  content: '';
  z-index: 1;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  opacity: 0.9;
}
.header h1 {
  position: relative;
  z-index: 2;
  text-align: center;
  font-size: 5vw;
  line-height: 1.3;
  font-weight: 900;
  padding: 0 15px 8vw;
}
.header .header-h1-sub {
  display: block;
  margin-top: 2vw;
  padding: 0 4vw;
  text-align: center;
  font-size: 3.7vw;
  line-height: 1.3;
  font-weight: 700;
}
@media (width > 767px){
  .header {
    margin-bottom: 30px;
    padding: 50px 0 0;
  }
  .header h1 {
    font-size: 40px;
    padding-bottom: 50px;
  }
  .header .header-h1-sub {
    margin-top: 5px;
    font-size: 28px;
  }
}

/* =============================================
  	フッター
============================================= */
.footer {
  padding: 20px 0;
  word-break: break-all;
	border-top: solid 1px;
}
.footer .footer-logo img {
  width: auto;
  height: 70px;
  margin: 0 auto 20px;
}
.footer .footer-text {
  width: 90%;
  margin: 0 auto;
  text-align: center;
}
.footer .footer-text1 {
  margin-bottom: 10px;
  font-size: 14px;
  line-height: 1.4;
}
.footer .footer-text2 {
  margin-bottom: 15px;
  font-size: 15px;
  line-height: 1.4;
  font-weight: 700;
}
.footer .footer-copyright {
  margin-top: 25px;
  text-align: center;
  font-size: 10px;
  line-height: 1;
}
@media (width > 767px){
  .footer {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    padding: 40px 0 20px;
    width: 100%;
    margin: 0 0 0 auto;
  }
  .footer .footer-logo {
    width: 45%;
    max-width: 400px;
    box-sizing: border-box;
    padding-right: 20px;
  }
  .footer .footer-logo img {
    height: 105px;
    margin: 0 auto;
  }
  .footer .footer-logo.only-logo {
    padding: 0;
  }
  .footer .footer-text {
    width: 45%;
    max-width: 400px;
    margin: 0;
    text-align: left;
  }
  .footer .footer-text1 {
    margin-bottom: 10px;
  }
  .footer .footer-text2 {
    /* margin-bottom: 15px; */
    font-size: 18px;
  }
  .footer .footer-copyright {
    width: 100%;
    margin-top: 35px;
    font-size: 12px;
  }
}

/* =============================================
  	フローナビ
============================================= */
.entry-flow {
  margin-bottom: 30px;
  overflow: hidden;
}
.entry-flow ul {
  display: flex;
  justify-content: center;
  width: 98%;
  margin: 0 auto;
}
.entry-flow ul li {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 25%;
  padding: 1.5vw 1vw;
  box-sizing: border-box;
  text-align: center;
  font-size: 2.6vw;
  line-height: 1;
  font-weight: 700;
  color: #fff;
  background: #cccccc;
}
.entry-flow ul li + li {
  border-left: 2px solid;
}
.entry-flow ul li.current::before{
  border-color: transparent transparent transparent #004ea2;
}
.entry-flow ul li::before {
  position: absolute;
  z-index: 1;
  content: '';
  width: 0;
  height: 0;
  right: -1.3vw;
  top: calc(50% - 2.8vw);
  border-style: solid;
  border-width: 2.8vw 0 2.8vw 1.4vw;
  border-color: transparent transparent transparent #cccccc;
}
.entry-flow ul li::after {
  position: absolute;
  z-index: 2;
  content: '';
  width: 3.6vw;
  height: 3.6vw;
  box-sizing: border-box;
  right: -1.8vw;
  top: calc(50% - 1.8vw);
  border-top: solid 4px #f9f9f9;
  border-right: solid 4px #f9f9f9;
  transform: rotateZ(45deg) skew(25deg, 25deg);
}
@media (width > 767px){
  .entry-flow {
    margin: 0 auto 40px;
  }
  .entry-flow ul {
    width: 100%;
    max-width: 1080px;
    width: calc(100% - 20px);
  }
  .entry-flow ul li {
    padding: 10px;
    font-size: 16px;
  }
  .entry-flow ul li::before {
    right: -8px;
    top: calc(50% - 18px);
    border-width: 18px 0 18px 9px;
  }
  .entry-flow ul li::after {
    width: 24px;
    height: 24px;
    right: -12px;
    top: calc(50% - 12px);
  }
}

/* =============================================
  	リード文
============================================= */
.entry-lead {
  margin-bottom: 30px;
}
.entry-lead p {
  width: 90%;
  margin: 0 auto 1em;
  font-size: 15px;
  line-height: 1.8;
}
.entry-lead p br {
	display: inline;
}
@media (width > 767px){
  .entry-lead p {
    text-align: center;
  }
}

/* =============================================
  	セミナービュー
============================================= */
.preview-table {
  border-collapse: collapse;
  margin-bottom: 20px;
  word-break: break-all;
}
.preview-table th {
  min-width: 7em;
  padding: 10px 15px 10px 0;
  text-align: left;
  vertical-align: baseline;
  font-size: 13px;
  line-height: 1.3;
  font-weight: 700;
}
.preview-table td {
  padding: 10px 0;
  text-align: left;
  vertical-align: baseline;
  font-size: 15px;
  line-height: 1.3;
}
.sb_sb_preview .input-button .button:nth-of-type(n+2) {
  margin-top: 20px;
}
@media (width > 767px){
  .preview-table {
    margin-bottom: 40px;
  }
  .preview-table th {
    min-width: 13em;
    padding: 15px 40px 15px 0;
    font-size: 16px;
  }
  .preview-table td {
    padding: 15px 0;
    font-size: 18px;
  }
}

/* =============================================
  	タイムテーブル
============================================= */
.sessionAlert {
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  z-index: 40;
  width: 100%;
  height: 100vh;
  left: 0;
  top: 0;
}
.sessionAlert.hide {
  display: none;
}
.sessionAlert>div {
  width: 80%;
  padding: 30px 0 40px;
}
.sessionAlert h3 {
  margin-bottom: 20px;
  text-align: center;
}
.sessionAlert h3 span {
  display: inline-block;
  vertical-align: middle;
}
.sessionAlert h3 span:nth-of-type(1) {
  width: 20px;
  height: 20px;
  padding: 5px;
  font-size: 20px;
  line-height: 1;
  font-weight: 700;
  border-radius: 15px;
}
.sessionAlert h3 span:nth-of-type(2) {
  margin-left: 10px;
  text-align: left;
  font-size: 18px;
  line-height: 1.3;
  font-weight: 700;
}
.sessionAlert p {
  width: 90%;
  margin: 0 auto;
  font-size: 14px;
  line-height: 1.6;
}
.sessionAlert p br {
  display: none;
}
.sessionAlert .alert-select {
  width: 160px;
  height: 16px;
  margin: 30px auto 0;
  padding: 10px 0;
  text-align: center;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
}
.sessionAlert .alert-cancel {
  width: 160px;
  height: 16px;
  margin: 20px auto 0;
  padding: 10px 0;
  text-align: center;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
}
.error_display span.label.label-warning {
  font-size: 16px;
  display: inline-block;
  height: 16px;
  margin-left: 10px;
  margin-right: 5px;
  padding: 1px;
  line-height: 1;
  font-weight: 900;
  border-radius: 8.5px;
}
.error_display span.ss_error_msg {
	font-size: 16px;
	display: inline-block;
	padding-top: 15px;
  line-height: 1;
  font-weight: 700;
}
.error_display {
	padding-top: 15px;
	margin: 0 auto;
	width: 90%;
}
.error_display.session_error .smperror {
  display: flex;
}
.error_display.session_error span.ss_error_msg {
  padding-top: 2px;
}
.error_display.session_error span.ss_error_msg .ss_time2 + .ss_time {
  margin-top: 5px;
}
.entry-section h2 {
  margin-bottom: 20px;
  padding-top: 40px;
}
.entry-section h2 .day {
  display: block;
  margin-bottom: 15px;
  text-align: center;
  font-size: 40px;
  line-height: 1;
  font-weight: 900;
}
.entry-section h2 .date {
  display: block;
  text-align: center;
  font-size: 26px;
  line-height: 1;
  font-weight: 900;
}
.timetable {
  margin-bottom: 40px;
  padding: 20px 0 5px;
}
.timetable .session-time {
  padding: 10px 0 5px;
  text-align: center;
  font-size: 26px;
  line-height: 1;
  font-weight: 900;
}
.timetable .session-container {
  padding: 15px 5px;
  overflow-x: visible;
}
.timetable .session-list {
  display: flex;
  width: 100%;
  flex-wrap: wrap;
  justify-content: space-between;
}
.timetable .session {
  position: relative;
  width: calc(100% - 20px);
  margin: 0 8px 20px;
  box-sizing: border-box;
  padding: 12px 12px 30px 12px;
  border-radius: 5px;
  border: solid 3px;
}
.timetable .session.hide {
  display: none !important;
}
.timetable .session .flexWrap>div {
  margin-bottom: 15px;
}
.timetable .session.pickup .session-code::after {
  content: 'おすすめセッション';
  display: inline-block;
  vertical-align: text-bottom;
  height: 11px;
  padding: 3px;
  margin-left: 10px;
  font-size: 11px;
  line-height: 1;
  border-radius: 3px;
  border: solid 1px;
}
.timetable .session-hall {
  padding-bottom: 5px;
  text-align: left;
  line-height: 1;
  font-weight: 700;
}
.timetable .session-code {
  margin-bottom: 5px;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
}
.timetable .session-title {
  margin-bottom: 10px;
  font-size: 18px;
  line-height: 1.3;
  font-weight: 700;
}
.timetable .session-title a {
  font-weight: 700;
}
.timetable .session-title a span {
  font-weight: 700;
}
.timetable .session-summary {
  font-size: 12px;
  line-height: 1.6;
}
.timetable .session-speaker {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
}
.timetable .session-speaker .speaker-photo {
  width: 80px;
}
.timetable .session-speaker .speaker-photo[src=''] {
  height: 0;
}
.timetable .session-speaker .speaker-photo:not([src='']) {
  margin-bottom: 15px;
}
.timetable .session-speaker div {
	margin-bottom: 15px;
	font-size: 11px;
	line-height: 1.5;
}
.timetable .session-speaker>div {
  width: calc(100% - 90px);
}
.timetable .session-speaker>div p {
  margin-bottom: 15px;
  font-size: 11px;
  line-height: 1.5;
}
.timetable .session-speaker div:empty {
	display: none;
}
.timetable .session-button {
  position: absolute;
  bottom: 12px;
  left: calc(50% - 80px);
  width: 160px;
  height: 36px;
}
.timetable .session-button input {
  display: none;
}
.timetable .session-button span {
  position: absolute;
  left: 0;
  top: 0;
  width: 160px;
  height: 16px;
  padding: 10px 0;
  text-align: center;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
}
.timetable .session-button span::after {
  content: '選択する';
}
.timetable .session-button.limit span::after {
  content: '満席';
}
.timetable .session-button.few span::after {
  content: '残りわずか';
}
.timetable .session-button.before span::after {
  content: '近日申込開始';
}
.timetable .session-button.finished span::after {
  content: '受付終了';
}
.timetable .session-button.error span::after {
  content: '開催未定';
}
.timetable .session-button input:checked+span::before {
  position: absolute;
  content: '';
  width: 20px;
  height: 10px;
  right: 5px;
  top: 6px;
  border-left: solid 2px;
  border-bottom: solid 2px;
  transform: rotate(-45deg);
}
.timetable .session-button input:checked+span::after {
  content: '選択済み';
}
.buttonArea {
  position: relative;
  height: 80px;
  margin-bottom: 40px;
}
.fixedArea.js_btn_area {
	display: flex;
	flex-direction: row-reverse;
}
.buttonArea .fixedArea {
  position: absolute;
  z-index: 5;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  height: 80px;
  box-sizing: border-box;
  padding-left: 60px;
  left: 0;
  bottom: 0;
}
.buttonArea .fixedArea.fixed {
  position: fixed;
  border-top: solid 1px;
}
.buttonArea .topButton {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 60px;
  height: 50px;
}
.buttonArea .topButton img {
  width: 30px;
  height: 30px;
}
.buttonArea .topButton span {
  margin-top: 3px;
  text-align: center;
  font-size: 10px;
  line-height: 1;
}
.buttonArea .submitButton {
  width: 200px;
  height: 48px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 15px 0;
  text-align: center;
  font-size: 18px;
  line-height: 1;
  font-weight: 700;
  border: none;
  border-radius: 0;
}
.buttonArea .submitButton span {
  display: inline-block;
  vertical-align: middle;
  margin-left: 0.5em;
  font-size: 75%;
}
@media (width > 767px){
  .sessionAlert>div {
    width: 600px;
    padding: 40px 0 40px;
  }
  .sessionAlert h3 {
    margin-bottom: 30px;
  }
  .sessionAlert h3 span:nth-of-type(2) {
    font-size: 20px;
  }
  .sessionAlert h3 span:nth-of-type(2) br {
    display: none;
  }
  .sessionAlert p {
    text-align: center;
    font-size: 16px;
  }
  .sessionAlert p br {
    display: inline;
  }
  .sessionAlert .alert-select,
  .sessionAlert .alert-cancel {
    transition: opacity 0.5s;
  }
  .sessionAlert .alert-select:hover,
  .sessionAlert .alert-cancel:hover {
    cursor: pointer;
    opacity: 0.7;
  }
  .sb_timetable_index_matrix .entry-flow {
    width: 90%;
  }
  .entry-section h2 {
    width: 90%;
    margin: 0 auto 40px;
    padding-top: 60px;
  }
  .entry-section h2 .day {
    display: inline-block;
    margin-bottom: 0;
    text-align: left;
    font-size: 54px;
  }
  .entry-section h2 .date {
    display: inline-block;
    margin-left: 20px;
    text-align: left;
    font-size: 30px;
  }
  .timetable {
    width: 90%;
    margin: 0 auto 40px;
    box-sizing: border-box;
    padding: 20px 10px 1px;
  }
  .timetable .session-time {
    margin-left: 10px;
    padding: 5px 0 15px;
    text-align: left;
    font-size: 32px;
  }
  .timetable .session-container {
    padding: 0;
  }
  .timetable .session-list {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
    width: 100%;
  }
  .timetable .session {
    margin: 0 10px 20px;
    box-sizing: border-box;
    padding: 17px 17px 40px 17px;
  }
  .timetable .session .flexWrap>div {
    margin-bottom: 20px;
  }
  .timetable .session.pickup .session-code::after {
    height: 12px;
    font-size: 12px;
  }
  .timetable .session.large {
    width: 100%;
  }
  .timetable .session.large .flexWrap {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
  }
  .timetable .session.large .flexWrap>div {
    width: 50%;
    box-sizing: border-box;
  }
  .timetable .session.large .flexWrap>div:nth-of-type(1) {
    padding-right: 40px;
  }
  .timetable .session-code {
    margin-bottom: 10px;
  }
  .timetable .session-title {
    margin-bottom: 20px;
  }
  .timetable .session-title span {
    font-weight: 700;
  }
  .timetable .session-title a span {
    border-bottom: 1px solid;
  }
  .timetable .session-title a span:hover {
    border-bottom: 1.6px solid;
  }
  .timetable .session-summary {
    font-size: 13px;
  }
	.timetable .session-speaker div {
    margin-bottom: 7px;
    font-size: 12px;
	}
  .timetable .session-speaker>div p {
    font-size: 12px;
  }
  .timetable .session-button {
    bottom: 17px;
    transition: opacity 0.5s;
  }
  .timetable .session-button:hover {
    cursor: pointer;
    opacity: 0.7;
  }
  .timetable .session-button.limit:hover,
  .timetable .session-button.before:hover,
  .timetable .session-button.finished:hover,
  .timetable .session-button.error:hover {
    cursor: default;
    opacity: 1;
  }
  .buttonArea {
    height: 80px;
    margin: 60px 0;
  }  
  .buttonArea .fixedArea {
    height: 80px;
    padding-left: 100px;
  }  
  .buttonArea .topButton {
    width: 100px;
    height: 80px;
  }  
  .buttonArea .topButton img {
    width: 50px;
    height: 50px;
  }  
  .buttonArea .topButton span {
    margin-top: 5px;
    font-size: 14px;
  }  
  .buttonArea .submitButton {
    width: 300px;
    height: 50px;
    padding: 13px 0;
    font-size: 24px;
    transition: opacity 0.5s;
  }  
  .buttonArea .submitButton:hover {
    cursor: pointer;
    opacity: 0.7;
  }
}
/* 画面サイズに応じてセッションのサイズを調整 */
@media (width >= 425px){
  .timetable .session {
    width: calc(50% - 20px);
  }
}
@media (width >= 992px){
  .timetable .session {
    width: calc(33.33% - 20px);
  }
}
@media (width >= 1200px){
  .timetable .session {
    width: calc(25% - 20px);
  }
}

/* =============================================
  	セッションビュー
============================================= */
.sb_session_preview header::before {
	opacity: 1;
}
.sb_session_preview .header h1 {
  padding: 0 15px 8vw;
}
.sb_session_preview .footer {
	padding: 20px 0;
	border-top: none 0px;
}
.sb_session_preview .footer .footer-copyright {
	margin-top: 0;
}
.sb_session_preview .session-overlay {
	width: 100%;
	height: 100%;
}
.sb_session_preview .session-overlay .session-time {
  margin-bottom: 10px;
  font-size: 16px;
  line-height: 1.2;
  font-weight: 700;
}
.sb_session_preview .session-overlay .session-item {
  width: 85%;
  padding: 20px;
}
.sb_session_preview .session-overlay .session-code {
	margin-bottom: 5px;
	font-size: 16px;
	line-height: 1;
	font-weight: 700;
}
.sb_session_preview .session-item.pickup .session-code::after {
	content: 'おすすめセッション';
	display: inline-block;
	vertical-align: text-bottom;
	height: 11px;
	padding: 3px;
	margin-left: 10px;
	font-size: 11px;
	line-height: 1;
	border-radius: 3px;
	border: solid 1px;
}
.sb_session_preview .session-overlay .session-title {
  margin-bottom: 10px;
  font-size: 18px;
  line-height: 1.3;
  font-weight: 700;
}
.sb_session_preview .session-overlay .session-title a {
	font-weight: 700;
}
.sb_session_preview .session-overlay .session-category {
  margin-bottom: 5px;
}
.sb_session_preview .session-overlay .session-summary {
  margin-bottom: 20px;
  font-size: 14px;
  line-height: 1.6;
}
.sb_session_preview .session-overlay .session-speaker {
  position: relative;
  min-height: 80px;
  padding-left: 90px;
}
.sb_session_preview .session-overlay .session-speaker + .session-speaker {
  margin-top: 15px;
}
.sb_session_preview .session-overlay .session-speaker .speaker-photo {
  position: absolute;
  width: 80px;
  left: 0;
  top: 0;
}
.sb_session_preview img {
  display: block;
  width: 100%;
}
.sb_session_preview .session-overlay .session-speaker {
	min-height: 120px;
	font-size: 14px;
}
@media (width > 767px) {
  .sb_session_preview .header h1 {
		padding: 0 15px 50px;
	}
  .sb_session_preview .footer {
    padding: 20px 0 20px;
	}
	.sb_session_preview .session-overlay .session-item {
		width: 800px;
		height: auto !important;
		margin: 0 auto 30px auto;
		box-sizing: border-box;
		padding: 15px;
		border-radius: 5px;
		border: solid 2px;
	}
	.sb_session_preview .session-overlay .session-code {
			margin-bottom: 10px;
	}
	.sb_session_preview .session-overlay .session-title {
    font-size: 20px;
  }
	.sb_session_preview .session-overlay .flexWrap {
    display: flex;
    justify-content: space-between;
  }
	.sb_session_preview .session-overlay .session-summary {
    width: 414px;
    margin: 0;
    padding-right: 20px;
    border-right: solid 1px;
  }
	.sb_session_preview .session-overlay .speaker-container {
    width: 300px;
  }
}

/* =============================================
  	入力
============================================= */
.ss_form h2 {
  padding: 0 5%;
  font-size: 20px;
  line-height: 1.3;
  font-weight: 900;
  margin-bottom: 10px;
}
.ss_form div + h2 {
  margin-top: 30px;
}
.ss_form .input-bg {
  padding: 20px 5% 1px;
}
.ss_form .input-item {
  margin-bottom: 30px;
}
.ss_form .ss_input {
  display: flex;
  flex-wrap: wrap;
}
.ss_form h3 {
  order: 1;
  flex-shrink: 0;
  max-width: 100%;
  margin-bottom: 5px;
  font-size: 16px;
  line-height: 1.4;
  font-weight: 700;
}
.ss_form h3 .label-warning {
  display: inline-block;
  vertical-align: text-top;
  margin-left: 10px;
  padding: 4px 8px;
  font-size: 12px;
  line-height: 1;
  font-weight: 700;
}
.ss_form h3 .label-warning:empty {
	display: none;
}
.ss_form .ss_input .labelArea {
  width: 100%;
  order: 3;
}
.ss_form .ss_input .labelArea > br:nth-child(1) {
  display: none;
}
.ss_form .ss_input .ss_upComment {
  display: none;
}
.ph {
  display: none;
}
.ss_form .ss_input label {
  display: inline-block;
}
.ss_form .input-item label:nth-of-type(2):not(.check-label) {
  margin-top: 10px;
}
.ss_form .ss_input label input:focus,
.ss_form .ss_input label select:focus,
.ss_form .ss_input label textarea:focus {
  outline-offset: -2px;
  outline-style: solid;
  outline-width: 2px;
}
/* テキスト */
.ss_form .ss_input label input[type='text'] {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  width: 90vw;
  box-sizing: border-box;
  padding: 10px;
  font-size: 16px;
  line-height: 1.3;
  border: solid 1px;
  border-radius: 5px;
}
/* テキストエリア */
.ss_form .ss_input label textarea {
  appearance: none;
  width: 90vw;
  box-sizing: border-box;
  padding: 10px;
  font-size: 16px;
  line-height: 1.3;
  border: solid 1px;
  border-radius: 5px;
}
/* チェックボックス */
.ss_form .ss_input label input[type='checkbox'] {
  width: 0;
  height: 0;
  opacity: 0;
  pointer-events: none;
}
.ss_form .ss_input label .checkbox-text {
  display: inline-block;
  position: relative;
  margin-top: 10px;
  padding-left: 25px;
  font-size: 16px;
  line-height: 1.2;
}
.ss_form .ss_input label .checkbox-text.bold {
  font-weight: bold;
}
.ss_form .ss_input label .checkbox-text::before {
  position: absolute;
  content: '';
  top: 0;
  left: 0;
  width: 15px;
  height: 15px;
	border: 1px solid;
  border-radius: 5px;
}
.ss_form .ss_input label input[type='checkbox']:disabled + .checkbox-text {
  opacity: 0.4;
}
.ss_form .ss_input label input[type='checkbox']:checked + .checkbox-text::after {
  position: absolute;
  content: '';
  top: -3px;
  left: 6px;
  width: 5px;
  height: 13px;
  transform: rotate(40deg);
  border-bottom: 3px solid;
  border-right: 3px solid;
}
/* ラジオボタン */
.ss_form .ss_input label input[type='radio'] {
  width: 0;
  height: 0;
  opacity: 0;
  pointer-events: none;
}
.ss_form .ss_input label .radio-text {
  display: inline-block;
  position: relative;
  margin-top: 10px;
  margin-right: 15px;
  padding-left: 20px;
  font-size: 16px;
  line-height: 1.2;
}
.ss_form .ss_input label .radio-text.bold {
  font-weight: bold;
}
.ss_form .ss_input label .radio-text::before {
  position: absolute;
  content: '';
  top: 0;
  left: 0;
  width: 15px;
  height: 15px;
  border: 1px solid;
  border-radius: 8.5px;
}
.ss_form .ss_input label input[type='radio']:checked + .radio-text::after {
  position: absolute;
  content: '';
  top: 4px;
  left: 4px;
  width: 9px;
  height: 9px;
  border-radius: 4.5px;
}
/* プルダウン */
.ss_form .ss_input label select {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  width: 90vw;
  box-sizing: border-box;
  padding: 10px 20px 10px 10px;
  font-size: 16px;
  line-height: 1;
  border: solid 1px;
  border-radius: 5px;
  background-image: url(../user/images/select_btn.png);
  background-repeat: no-repeat;
  background-position: right 5px center;
  background-size: 10px 9px;
}
.ss_form .ss_input label select::-ms-expand {
  display: none;
}
/* パスワード */
.ss_form .ss_input label input[type='password'] {
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  width: 90vw;
  box-sizing: border-box;
  padding: 10px;
  font-size: 16px;
  line-height: 1.3;
  border: solid 1px;
  border-radius: 5px;
}
/* 郵便番号 */
.ss_form #zip .ss_input .labelArea > br:nth-of-type(2) {
  display: none;
}
.ss_form #zip .ss_input label input[type='text'] {
  width: 80px;
}
/* ファイル */
.ss_form .ss_input label input[type='file'] {
  display: none;
}
.ss_form .ss_input label .file-text {
  display: block;
  position: relative;
  min-height: 22px;
  padding-top: 8px;
  padding-left: 175px;
  font-size: 12px;
  line-height: 1.5;
  word-break: break-all;
}
.ss_form .ss_input label .file-text::before {
  position: absolute;
  content: '';
  width: 165px;
  height: 30px;
  left: 0;
  top: 0;
  border-radius: 5px;
  background-image: url(../user/images/input_file.png);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}
/* ファイルクリアボタン */
.clear_btn {
  margin-top: 6px;
  padding: 3px 6px;
}
/* バリデーション */
.ss_form .ss_input > span {
  order: 2;
}
.ss_form .ss_input .formError .label-warning {
  display: inline-block;
  vertical-align: middle;
  height: 11px;
  margin-left: 10px;
  margin-right: 5px;
  padding: 1px;
  font-size: 11px;
  line-height: 1;
  font-weight: 900;
  border-radius: 6.5px;
}
.ss_form .ss_input .formError .formErrorContent {
  display: inline;
  font-size: 11px;
  line-height: 1;
  font-weight: 700;
}
/* 個人情報文言 */
.privacy-notes {
  font-size: 75%;
  margin-bottom: 10px;
}
.ss_form .privacy-text {
  height: 6em;
  padding: 5%;
  font-size: 13px;
  line-height: 1.6;
  overflow-y: scroll;
}
/* submitボタン */
.input-button {
  padding: 40px 0;
}
.input-button.js_btn_area {
  display: flex;
  flex-direction: column;
}
.input-button .button {
  display: block;
  width: 200px;
  height: 36px;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 9px 0;
  text-align: center;
  font-size: 18px;
  line-height: 1;
  font-weight: 700;
  border: none;
  border-radius: 0;
}
.input-button .button span {
  display: inline-block;
  vertical-align: middle;
  margin-left: 0.5em;
  font-size: 75%;
}
.input-button .button.prev + .button {
  margin-top: 30px;
}
.input-button .button.prev span {
  margin-right: 0.5em;
}
.input-button .alert {
  text-align: center;
  color: red;
  font-weight: bold;
}
@media (width > 767px){
  .ss_form h2 {
    padding: 0;
    width: 750px;
    margin: 0 auto 15px;
    font-size: 32px;
  }
  .ss_form div + h2 {
    margin-top: 50px;
  }
  .ss_form {
    margin-top: 50px;
  }
  .ss_form .input-bg {
    width: 650px;
    margin: 0 auto;
    padding: 40px 50px 10px;
  }
  .ss_form .flexWrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .ss_form .input-item {
    width: 100%;
  }
  .ss_form .input-item:not(#zip) label:nth-of-type(2):not(.check-label) {
    margin: 0 0 0 10px;
  }
  .ss_form .input-item label + br {
    display: none;
  }
  .ss_form .ss_input label input[type='text'],
  .ss_form .ss_input label select,
  .ss_form .ss_input label textarea {
    width: 650px;
  }
	.ss_form .ss_input label textarea {
    height: 120px;
	}
  .ss_form .input-item.short .ss_input label input[type='password'],
  .ss_form .input-item.short .ss_input label input[type='text'],
  .ss_form .input-item.short .ss_input label select,
  .ss_form .input-item.short .ss_input label textarea {
    width: 312px;
  }
  .ss_form .input-item.middle .ss_input label select, 
  .ss_form .input-item.middle .ss_input label textarea {
    width: 435px;
  }
  .ss_form .ss_input .ss_bottomComment {
    width: 100%;
    order: 4;
    margin-top: 15px;
    font-size: 12px;
    line-height: 1.5;
  }
	.labelArea table {
		width: 100%;
	}
  /* パスワード */
  .ss_form .ss_input label input[type='password'] {
    width: inherit;
  }
  /* バリデーション */
  .ss_form .ss_input .formError .label-warning {
    height: 13px;
    font-size: 13px;
    border-radius: 7.5px;
  }
  .ss_form .ss_input .formError .formErrorContent {
    font-size: 13px;
  }
  /* 個人情報文言 */
  .ss_form .privacy-text {
    height: 120px;
    padding: 15px;
    font-size: 14px;
  }
  /* submitボタン */
  .input-button.js_btn_area {
    flex-direction: inherit;
    width: 750px;
    margin: 0 auto;
  }
  .input-button {
    padding: 60px 0;
  }
  .input-button .button {
    width: 300px;
    height: 50px;
    padding: 13px 0;
    font-size: 24px;
    transition: opacity 0.5s;
  }
  .input-button .button.prev + .button {
    margin-top: 0;
  }
  .input-button .button:hover {
    cursor: pointer;
    opacity: 0.7;
  }
}
@media (width < 768px){
	.labelArea table td {
		display: block;
	}
}

/* =============================================
  	確認
============================================= */
.confirm-session li {
  margin-bottom: 20px;
  padding: 20px;
  border-radius: 5px;
}
.confirm-session li .code {
  margin-bottom: 5px;
  font-size: 16px;
  line-height: 1;
  font-weight: 900;
}
.confirm-session li .date {
  margin-bottom: 8px;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
}
.confirm-session li h3 {
  font-size: 16px;
  line-height: 1.4;
  font-weight: 700;
}
.confirm-session li .price {
  text-align: right;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
}
.confirm-session li.ss_cart_calc_record {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.confirm-session li.ss_cart_calc_record h3 {
  order: 0;
  margin: 0;
}
.confirm-session li.ss_cart_calc_record p {
  font-size: 16px;
  font-weight: 700;
  margin-left: auto;
}
.confirm-table {
  border-collapse: collapse;
  margin-bottom: 20px;
  word-break: break-all;
}
.confirm-table th {
  min-width: 7em;
  padding: 10px 15px 10px 0;
  text-align: left;
  vertical-align: baseline;
  font-size: 13px;
  line-height: 1.3;
  font-weight: 700;
}
.ss_form h2.enquete_header {
  margin-top: 30px;
}
.confirm-table td {
  padding: 10px 0;
  text-align: left;
  vertical-align: baseline;
  font-size: 15px;
  line-height: 1.3;
}
.ss_num,/* cartの人数 */
.ss_price_type11,/* キャンペーン型かつ無料(確認画面) */
h2.ss_price_type12, /* キャンペーン型かつキャンペーン課金の際の見出し */
.ss_price_type12 .label,/* キャンペーン型かつキャンペーン課金(確認画面) */
.ss_price_type21 .ss_cart_calc_record.ss_price,/* サブキャンペーン型かつ無料(確認画面) */
.ss_price_type21 .price.ss_price,/* サブキャンペーン型かつ無料(確認画面) */
.ss_price_type_cart11 .ss_price, .ss_price_type_cart11 .label,/* キャンペーン型かつ無料(cart) */
.ss_price_type_cart12 .label,/* キャンペーン型かつキャンペーン課金(cart) */
.ss_price_type_cart21 .ss_price/* サブキャンペーン型かつ無料(cart) */{
	display: none;
}
@media (width > 767px){
  .confirm-session li .code {
    display: inline-block;
    margin-bottom: 8px;
    font-size: 18px;
  }
  .confirm-session li .date {
    display: inline-block;
    margin-left: 15px;
    font-size: 18px;
  }
  .confirm-session li h3 {
    font-size: 18px;
  }
  .confirm-table {
    margin-bottom: 40px;
  }
  .confirm-table th {
    min-width: 13em;
    padding: 15px 40px 15px 0;
    font-size: 16px;
  }
  .confirm-table td {
    padding: 15px 0;
    font-size: 18px;
  }
  .ss_form h2.enquete_header {
    margin-top: 50px;
  }
}

/* =============================================
  	完了
============================================= */
body.sb_interimcomplete_index footer {
  margin-top: 140px;
}
main.complete {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* =============================================
	カート
  支払方法入力
  請求先情報入力
============================================= */
.sb_cart_index .set_recalculate {
  margin-bottom: 50px;
}
.sb_cart_index table.ss_cardTable {
  margin-bottom: 15px;
}
.sb_cart_index .error_display {
  margin: 0;
  padding: 0;
}
.sb_cart_index button.recalculation {
  display: none;
  margin-left: 20px;
  padding: 3px 6px;
  -webkit-appearance: none;
  appearance: none;
  border: solid 1px #000;
  background-color: rgb(240,240,240);
  cursor: pointer;
}
.sb_payment_index .popup_open {
  text-decoration: underline;
  cursor: pointer;
}
.input-bg.bg-bule {
  padding: 5px 50px;
  font-size: 25px;
  font-weight: bold;
  text-align: center;
}
.sb_payment_index div.entry-lead {
  margin: 30px auto;
}
.sb_payment_index div.entry-lead.mar50 {
  margin: 50px auto;
}
.sb_payment_index .popup {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  display: none;
  justify-content: center;
  align-items: center;
  z-index: 3;
}
.sb_payment_index div.popup_cloce {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
}
.sb_payment_index .popup_inner {
  position: relative;
  border-radius: 2%;
  padding: 15px;
  max-width: 85%;
  width: 1000px;
  padding: 50px 15px 15px 15px;
  height: 60%;
}
.sb_payment_index button.popup_cloce {
  position: absolute;
  right: 15px;
  top: 12px;
  padding: 3px 6px;
}
.sb_payment_index .popup_scroll {
  overflow-y: scroll;
  height: 100%;
}
.sb_payment_index .popup_table {
  width: 100%;
}
.sb_payment_index .popup_table th, .popup_table td {
  display: block;
  padding: 10px 0 10px 10px;
  text-align: left;
}
table.ss_cardTable {
  max-width: 1000px;
  border: solid 1px;
  border-collapse: collapse;
  width: 90%;
  margin: 0 auto;
}
table.ss_cardTable tr {
  display: table-row;
  margin: 0;
  border: none;
  border-bottom: solid 1px;
  text-align: center;
}
table.ss_cardTable tr th {
  padding: 15px 0;
  font-size: 15px;
  text-align: center;
  line-height: 1;
  font-weight: 700;
  display: table-cell;
  width: 35%;
}
table.ss_cardTable tr td {
  display: table-cell;
  padding: 20px;
  border: none;
  text-align: left;
}
.sb_cart_index table.ss_cardTable tr td,
.sb_cart_index table.ss_cardTable tr td.ss_cart_day,
.sb_cart_index table.ss_cardTable tr td.ss_cart_day + td {
  text-align: left;
}
.sb_payment_index .ss_form .ss_input .labelArea {
  order: initial;
}
.sb_cart_index .ss_form .ss_input label input[type='text'],
.sb_payment_index .ss_form .ss_input label input[type='text'],
.sb_payment_index .ss_form .ss_input label select {
  width: inherit;
}
.select_alert {
  width: 90%;
  margin: 20px auto;
  max-width: 1000px;
}
.sb_cart_index .input-button.js_btn_area,
.sb_payment_index .input-button.js_btn_area {
  padding-top: 0px;
}
.same_data_area {
  margin: 0 5%;
}
@media (width > 767px) {
  .sb_cart_index main,
  .sb_payment_index main {
    width: 750px;
    margin: 0 auto;
  }
  .sb_cart_index table.ss_cardTable,
  .sb_cart_index .entry-lead p,
  .sb_payment_index table.ss_cardTable,
  .sb_payment_index .entry-lead p {
    width: 100%;
  }
  .same_data_area {
    width: 750px;
    margin: 0 auto;
  }
}
@media (max-width: 767px) { 
  table.ss_cardTable tr td,
  table.ss_cardTable tr th {
      display: block;
      width: auto;
  }
  table.ss_cardTable tr th.ss_cart_responsive_hide {
      display: none;
  }
  .sb_payment_index .entry-lead p {
    width: 90%;
  }
}

/* =============================================
	マイページ
============================================= */
body.booth header h1,
body.movie header h1,
body.mypage header h1 {
  left: 46px;
}
body.booth .searchList,
body.movie .searchList,
body.mypage .searchList {
  display: none;
}
.icon-def {
  display: none;
}
.overlay {
  position: fixed;
  z-index: 15;
  width: 100%;
  height: 100vh;
  left: 0;
  top: 0;
  transition: opacity 0.5s;
}
.overlay.hide {
  opacity: 0;
  pointer-events: none;
}
/* ヘッダー */
body.mypage header {
  height: 80px;
}
body.mypage header .header-inner {
  position: fixed;
  z-index: 30;
  width: 100%;
  height: 40px;
  left: 0;
  top: 0;
}
body.mypage header .event-menuButton {
  position: absolute;
  left: 0;
  top: 0;
  width: 36px;
  height: 100%;
}
body.mypage header .event-menuButton span {
  display: block;
  position: absolute;
  width: 20px;
  height: 2px;
  left: 8px;
}
body.mypage header .event-menuButton span:nth-of-type(1) {
  top: 12px;
}
body.mypage header .event-menuButton.open span:nth-of-type(1) {
  top: 19px;
  transform: rotate(45deg);
}
body.mypage header .event-menuButton span:nth-of-type(2) {
  top: 19px;
}
body.mypage header .event-menuButton.open span:nth-of-type(2) {
  opacity: 0;
}
body.mypage header .event-menuButton span:nth-of-type(3) {
  top: 26px;
}
body.mypage header .event-menuButton.open span:nth-of-type(3) {
  top: 19px;
  transform: rotate(-45deg);
}
body.mypage header h1 {
  position: absolute;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  left: 82px;
  top: 0;
  width: calc(100% - 118px);
  height: 100%;
}
body.mypage header h1 span {
  display: block;
  font-size: 10px;
  line-height: 1.3;
  font-weight: 700;
}
body.mypage header h1 span strong {
  font-size: 11px;
  font-weight: 900;
}
body.mypage header .event-name {
  display: none;
}
body.mypage header .event-logout {
  position: absolute;
  display: flex;
  justify-content: center;
  align-items: center;
  right: 0;
  top: 0;
  width: 36px;
  height: 100%;
}
body.mypage header .event-logout svg {
  width: 20px;
  height: 20px;
}
body.mypage header .event-logout span {
  display: none;
}
/* サイドメニュー */
body.mypage .pageList {
  position: fixed;
  z-index: 20;
  width: 100%;
  height: 100vh;
  box-sizing: border-box;
  padding: 80px 30px 100px;
  left: 0;
  top: 0;
  transition: left 0.5s cubic-bezier(0.8, 0, 0.2, 1);
  overflow-y: scroll;
}
body.mypage .pageList.hide {
  left: -100%;
}
body.mypage .pageList ul li + li {
  margin-top: 25px;
}
body.mypage .pageList ul li a {
  display: flex;
  align-items: center;
}
body.mypage .menu_icon {
  background-repeat: no-repeat;
  background-size: contain;
  width: 15%;
  height: calc((100vw - 60px) * 0.15);
}
body.mypage .pageList ul li span {
  margin-left: 15px;
  font-size: 18px;
  line-height: 1;
  font-weight: 700;
}
body.mypage .pageList ul li span br {
  display: none;
}
/* フッター */
/* body.mypage footer {
  padding: 20px 0;
  border-top: solid 1px;
} */
/* body.mypage footer .footer-logo img {
  width: auto;
  height: 70px;
  margin: 0 auto 20px;
} */
/* body.mypage footer .footer-text {
  width: 90%;
  margin: 0 auto;
  text-align: center;
} */
/* body.mypage footer .footer-text1 {
  margin-bottom: 10px;
  font-size: 14px;
  line-height: 1.4;
} */
/* body.mypage footer .footer-text2 {
  margin-bottom: 15px;
  font-size: 15px;
  line-height: 1.4;
  font-weight: 700;
} */
/* body.mypage footer .footer-copyright {
  margin-top: 25px;
  text-align: center;
  font-size: 10px;
  line-height: 1;
} */
/* main */
body.mypage main h2 {
  margin-top: 30px;
  margin-bottom: 30px;
  text-align: center;
  font-size: 20px;
  line-height: 1;
  font-weight: 900;
}
body.mypage .mypage-header {
  padding: 40px 0;
  text-align: center;
}
body.mypage .mypage-header .mypage-lead {
  width: 90%;
  margin: 0 auto 30px;
}
body.mypage .mypage-header .mypage-button {
  position: relative;
  display: inline-block;
  height: 30px;
  padding: 5px 5px 5px 35px;
  border: solid 1px;
  border-radius: 5px;
}
body.mypage .button_img {
  width: 20%;
}
body.mypage .mypage-header .mypage-button span {
  display: inline-block;
  height: 16px;
  padding: 7px 20px;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
}
body.mypage .entrance-news {
  margin-bottom: 50px;
}
body.mypage .entrance-news ul {
  padding: 5px 5%;
}
body.mypage .entrance-news ul li {
  padding: 20px 0;
}
body.mypage .entrance-news ul li + li {
  border-top: solid 1px;
}
body.mypage .entrance-news ul .news-date {
  margin-bottom: 5px;
  font-size: 14px;
  line-height: 1;
  font-weight: 700;
}
body.mypage .entrance-news ul .news-text {
  font-size: 15px;
  line-height: 1.6;
}
body.mypage .entrance-news ul .news-text a {
  text-decoration: underline;
}
body.mypage .mypages_text {
  width: 90% !important;
  margin: 0 auto 30px;
}
body.mypage main .mypages_text h3 {
  font-size: 1.5em;
}
body.mypage .mypage-info {
  margin-bottom: 40px;
}
body.mypage .mypage-info table {
  border-collapse: collapse;
  width: 90%;
  margin: 0 auto;
}
body.mypage .mypage-info table tr {
  display: block;
  margin-bottom: 15px;
  border: solid 1px;
}
body.mypage .mypage-info table tr:first-child {
  text-align: center;
}
body.mypage .mypage-info table tr th {
  padding: 10px 0;
  text-align: center;
  font-size: 14px;
  line-height: 1;
  font-weight: 700;
  display: block;
}
body.mypage .select_id {
  display: none !important;
}
body.mypage .ss_login table.ss_mypage_table th.start_day {
  display: none;
}
body.mypage .mypage-info .ss_login table td {
  width: auto;
}
body.mypage .mypage-info table td {
  display: block;
  padding: 10px;
  text-align: center;
}
body.mypage .mypage-info table td div + div {
  margin-top: 10px;
}
body.mypage .mypage-info table td .ss_mypage_application_startdate {
  margin-bottom: 5px;
  font-size: 15px;
  line-height: 1.4;
  font-weight: 700;
}
body.mypage .mypage-info table td .ss_mypage_application_title {
  margin-bottom: 10px;
  font-size: 16px;
  line-height: 1.4;
}
body.mypage .mypage-info table td .ss_mypage_application_title strong {
  font-weight: 700;
}
body.mypage .mypage-info table td .ss_mypage_application_document li {
  font-size: 14px;
  line-height: 1.5;
}
body.mypage .mypage-info table td a {
  display: inline-block;
  padding: 7px;
  font-size: 14px;
  line-height: 1;
  font-weight: 700;
}
body.mypage .mypage-note {
  width: 90%;
  margin: 10px auto 0;
}
body.mypage .mypage-note li {
  padding-left: 1em;
  text-indent: -1em;
  font-size: 13px;
  line-height: 1.5;
}
body.mypage .mypage-note li + li {
  margin-top: 10px;
}
body.mypage .js_mypage_table {
  margin-top: 20px;
}
body.mypage .js_mypage_table:blank {
  display: none;
}
body.mypage .mypage-info .js_mypage_table table tr:first-child {
  display: none;
}
body.mypage .mypage-info .js_mypage_table table tr td {
  text-align: center;
}
body.mypage .mypage-info .js_mypage_table table tr td:first-child {
  font-weight: 700;
  line-height: 1.4;
}
/* topButton */
body.mypage .topButton {
  display: block;
  position: fixed;
  z-index: 12;
  width: 30px;
  height: 30px;
  right: 10px;
  bottom: 15px;
  border-radius: 15px;
}
body.mypage .topButton svg {
  width: 100%;
  height: 100%;
}
/* ss_login */
body.mypage .ss_login .table th {
  padding-top: 15px;
  padding-bottom: 15px;
}
body.mypage .ss_login .table th .captcha {
  width: 80%;
  margin: 0 auto;
}
body.mypage .label-warning {
  display: inline-block;
  vertical-align: text-top;
  margin-left: 10px;
  padding: 4px 8px;
  font-size: 12px;
  line-height: 1;
  font-weight: 700;
}
body.mypage .mypages_timetable .ss_rightComment {
  display: block;
}
body.mypage .mypages_timetable input[type='text'],
body.mypage .mypages_timetable input[type='password'] {
  width: 80%;
  -webkit-tap-highlight-color: transparent;
  -moz-appearance: none;
  -webkit-appearance: none;
  appearance: none;
  box-sizing: border-box;
  padding: 10px;
  font-size: 16px;
  line-height: 1.3;
  border: solid 1px;
  border-radius: 5px;
}
body.mypage .mypages_timetable input[type='text']:focus,
body.mypage .mypages_timetable input[type='password']:focus {
  outline-offset: -2px;
  outline-style: solid;
  outline-width: 2px;
}
body.mypage .ss_login .formError .label-warning {
  display: inline-block;
  vertical-align: middle;
  height: 11px;
  margin-left: 0;
  margin-right: 5px;
  padding: 1px;
  font-size: 11px;
  line-height: 1;
  font-weight: 900;
  border-radius: 6.5px;
}
body.mypage .ss_login .formError .formErrorContent {
  display: inline;
  font-size: 11px;
  line-height: 1;
  font-weight: 700;
} 
body.mypage .ss_form_btn {
  width: 95%;
  margin-right: auto;
  margin-left: auto;
  text-align: center;
}
body.mypage .ss_form_btn button {
  padding: 15px 50px;
  margin-top: 50px;
  margin-bottom: 0px;
  border: 0;
  font-size: 14px;
  font-weight: 700;
  width: 95%;
}
body.mypage .ss_form_btn button:hover {
  cursor: pointer;
}
body.mypage .ss_login .ss_form_btn .btn-link {
  margin-bottom: 30px;
}
body.mypage .ss_login table th {
  display: block;
  width: auto;
}
body.mypage .mypages_btn a:hover {
  cursor: pointer;
}
body.mypage_login_plain .flexWrap:last-child tr:first-child {
  display: none;
}
@media (width > 767px) {
  /* ヘッダー */
  body.mypage header {
    height: 100px;
  }
  body.mypage header .header-inner {
    height: 60px;
  }
  body.mypage header .event-menuButton {
    width: 60px;
  }
  body.mypage header .event-menuButton:hover {
    cursor: pointer;
  }
  body.mypage header .event-menuButton span {
    width: 24px;
    left: 18px;
  }
  body.mypage header .event-menuButton span:nth-of-type(1) {
    top: 21px;
  }
  body.mypage header .event-menuButton.open span:nth-of-type(1) {
    top: 21px;
    transform: none;
  }
  body.mypage header .event-menuButton span:nth-of-type(2) {
    top: 29px;
  }
  body.mypage header .event-menuButton.open span:nth-of-type(2) {
    opacity: 1;
  }
  body.mypage header .event-menuButton span:nth-of-type(3) {
    top: 37px;
  }
  body.mypage header .event-menuButton.open span:nth-of-type(3) {
    top: 37px;
    transform: none;
  }
  body.mypage header h1 {
    left: 70px;
    width: calc(100% - 415px);
  }
  body.mypage header h1 span {
    font-size: 15px;
  }
  body.mypage header h1 span strong {
    font-size: 20px;
  }
  body.mypage header .event-name {
    position: absolute;
    right: 145px;
    top: 0;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    width: 210px;
    height: 100%;
  }
  body.mypage header .event-name p {
    text-align: right;
    font-size: 14px;
    line-height: 1.2;
  }
  body.mypage header .event-name p.small_font {
    font-size: 11px;
  }
  body.mypage header .event-name p span {
    margin: 0 5px;
    font-size: 18px;
    font-weight: 700;
  }
  body.mypage header .event-name p.small_font span {
    margin: 0 2px;
  }
  body.mypage header .event-name p .login-name.small_font {
    font-size: 12px;
  }
  body.mypage header .event-name p span.read_name_span {
    margin: 0 0.15rem;
  }
  body.mypage header .event-logout {
    right: 15px;
    top: 15px;
    width: 110px;
    height: 30px;
    transition: background 0.3s;
  }
  body.mypage header .event-logout:hover {
    cursor: pointer;
  }
  body.mypage header .event-logout span {
    display: block;
    margin-left: 7px;
    font-size: 14px;
    line-height: 1;
    font-weight: 700;
  }
  /* サイドメニュー */
  body.mypage .event-menuArea {
    position: fixed;
    z-index: 20;
    width: 60px;
    height: 100vh;
    left: 0;
    top: 0;
    border-right: solid 1px;
    overflow: hidden;
  }
  body.mypage .event-menuArea.wide {
    width: 250px;
    left: -250px;
  }
  body.mypage .event-menuArea.wide.open {
    transition: left 0.3s cubic-bezier(0.8, 0, 0.2, 1);
    left: 0;
  }
  body.mypage .event-menuArea.wide .event-menuArea-inner {
    width: 220px;
    height: 100%;
    padding: 0 40px 0 15px;
    overflow-y: scroll;
    overscroll-behavior: none;
  }
  body.mypage .pageList {
    position: relative;
    width: 60px;
    height: auto;
    padding: 80px 0 0;
    background-color: transparent;
    transition: left 0s;
    overflow-y: visible;
  }
  body.mypage .pageList.hide {
    left: 0;
  }
  body.mypage .event-menuArea.wide .pageList {
    width: 220px;
  }
  body.mypage .pageList ul li + li {
    margin-top: 15px;
  }
  body.mypage .pageList ul li a {
    display: flex;
    flex-direction: column;
    justify-content: center;
  }
  body.mypage .event-menuArea.wide .pageList ul li a {
    flex-direction: row;
    justify-content: flex-start;
  }
  body.mypage .menu_icon {
    width: 30px;
    height: 30px;
    transition: fill 0.5s;
  }
  body.mypage .pageList ul li span {
    margin-top: 3px;
    margin-left: 0;
    text-align: center;
    font-size: 10px;
    line-height: 1.2;
    font-weight: 400;
    transition: color 0.5s;
  }
  body.mypage .event-menuArea.wide .pageList ul li span {
    margin-top: 0;
    margin-left: 15px;
    text-align: left;
    font-size: 14px;
    line-height: 1;
  }
  body.mypage .pageList ul li span br {
    display: inline;
  }
  body.mypage .event-menuArea.wide .pageList ul li span br {
    display: none;
  }
  /* フッター */
  body.mypage:not(.mypages_side) footer {
    width: calc(100% - 61px);
  }
  /* body.mypage footer {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    width: calc(100% - 61px);
    margin: 0 0 0 auto;
    padding: 40px 0 20px;
  } */
  /* body.mypage footer .footer-logo {
    width: 45%;
    max-width: 400px;
    box-sizing: border-box;
    padding-right: 20px;
  } */
  /* body.mypage footer .footer-logo img {
    height: 105px;
    margin: 0 auto;
  } */
  /* body.mypage footer .footer-logo.only-logo {
    padding: 0;
  } */
  /* body.mypage footer .footer-text {
    width: 45%;
    max-width: 400px;
    margin: 0;
    text-align: left;
  } */
  /* body.mypage footer .footer-text2 {
    font-size: 18px;
  } */
  /* body.mypage footer .footer-copyright {
    width: 100%;
    margin-top: 35px;
    font-size: 12px;
  } */
  /* main */
  body.mypage main {
    width: calc(100% - 61px);
    margin: 0 0 0 auto;
  }
  body.mypage main h2 {
    margin-top: 60px;
    margin-bottom: 40px;
    font-size: 30px;
  }
  body.mypage .mypage-header {
    padding: 60px 0 30px;
    text-align: left;
  }
  body.mypage .mypage-header .flexWrap {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 90%;
    max-width: 1000px;
    margin: 0 auto;
  }
  body.mypage .mypage-header .flexWrap.center {
    justify-content: space-around;
  }
  body.mypage .mypage-header .mypage-lead {
    width: 55%;
    margin: 0;
  }
  body.mypage .mypage-header .mypage-button {
    height: 40px;
    padding: 5px 5px 5px 45px;
  }
  body.mypage .mypage-header .mypage-button span {
    height: 18px;
    padding: 11px 20px;
    font-size: 18px;
    transition: color 0.5s;
  }
  body.mypage .entrance-news {
    margin-bottom: 60px;
  }
  body.mypage .entrance-news ul {
    width: 94%;
    max-width: 1000px;
    margin: 0 auto;
    box-sizing: border-box;
    padding: 5px 20px;
  }
  body.mypage .entrance-news ul li {
    display: flex;
    max-width: 800px;
    margin: 0 auto;
  }
  body.mypage .entrance-news ul .news-date {
    flex-shrink: 0;
    width: 5em;
    margin-bottom: 0;
    font-size: 15px;
    line-height: 1.6;
  }
  body.mypage .mypages_text {
    margin: 0;
  }
  body.mypage .mypages_timetable th {
    font-size: 15px;
    font-weight: 700;
  }
  body.mypage .mypage-info {
    margin-bottom: 60px;
  }
  body.mypage .mypage-info table {
    max-width: 1000px;
    border: solid 1px;
  }
  body.mypage .mypage-info table tr {
    display: table-row;
    margin: 0;
    border: none;
    border-bottom: solid 1px;
  }
  body.mypage .mypage-info table tr th {
    display: table-cell;
  }
  body.mypage .mypage-info table tr:first-child th.ss_mypage_responsive_show {
    display: table-cell;
  }
  body.mypage .mypage-info table td {
    display: table-cell;
    padding: 20px;
    text-align: center;
    border: none;
  }
  body.mypage .mypage-info table td .ss_mypage_application_startdate {
    font-size: 16px;
  }
  body.mypage .mypage-info table td .ss_mypage_application_title {
    margin-bottom: 15px;
    font-size: 18px;
  }
  body.mypage .mypage-info table td .ss_mypage_application_document li {
    font-size: 15px;
  }
  body.mypage .mypage-info table td a {
    min-width: 8em;
    padding: 7px;
    font-size: 14px;
    line-height: 1.3;
    transition: background 0.5s;
  }
  body.mypage .mypage-note {
    max-width: 1000px;
    margin: 20px auto 0;
  }
  body.mypage .mypage-info .js_mypage_table table tr:first-child {
    display: table-row;
  }
  body.mypage .mypage-info .js_mypage_table table tr td:nth-child(n+2) {
    width: 30%;
  }
  /* topButton */
  body.mypage .topButton {
    width: 50px;
    height: 50px;
    right: 20px;
    bottom: 30px;
    border-radius: 25px;
  }
  /* ss_login */
  body.mypage .mypages_timetable td {
    text-align: left !important;
  }
  body.mypage .ss_form_btn button {
    width: initial;
    margin: 50px;
  }
  body.mypage .ss_login .formError .label-warning {
    height: 13px;
    font-size: 13px;
    border-radius: 7.5px;
  }
  body.mypage .ss_login .formError .formErrorContent {
    font-size: 13px;
  } 
  body.mypage .ss_login .table th {
    display: table-cell;
    width: 30%;
  }
  body.mypage .ss_login table.ss_mypage_table th.start_day {
    display: block;
  }
}
@media (width >= 1080px){
  /* サイドメニュー */
  .event-menuArea.wide.open {
    transition: left 0s;
  }
}
/* .mypages_side */
body.mypages_side header .event-menuButton,
body.mypages_side header .event-name,
body.mypages_side header .event-logout {
	display: none;
}
body.mypages_side header h1 {
  left: 46px;
}
body.mypages_side main {
	width:100%;
}
/* public */
body.top_index .mypages_timetable input[type='text'],
body.seminar_list .mypages_timetable input[type='text'] {
  width: inherit;
}
body.reminder_finish .mypage-header .flexWrap {
  flex-wrap: wrap;
}
.ss_public_responsive_show {
  display: none;
}
.ss_public_responsive_hide {
  display: table-cell;
}
body.top_index .mypage-info .seminar_list table td,
body.seminar_list .mypage-info .seminar_list table td {
  text-align: center !important;
}
@media (width < 768px) {
  body.top_index .mypages_timetable input[type='text'],
  body.seminar_list .mypages_timetable input[type='text'] {
    width: 80%;
  }
  body.top_index .mypages_timetable input[name='start_day_start'],
  body.top_index .mypages_timetable input[name='start_day_end'],
  body.seminar_list .mypages_timetable input[name='start_day_start'],
  body.seminar_list .mypages_timetable input[name='start_day_end'] {
    width: 35%;
  }
  body.top_index .mypage-info .seminar_list table tr,
  body.seminar_list .mypage-info .seminar_list table tr {
    margin-bottom: 0;
  }
  .ss_public_responsive_show {
    display: inline;
    font-weight: 700;
  }
  .ss_public_responsive_hide {
    display: none !important;
  }
}

/* modal */
.modal-backdrop {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 1040;
  display: none;
}
.modal-backdrop.fade {
	opacity: 0;
}
.modal-backdrop, .modal-backdrop.fade.in {
	opacity: 0.8;
	filter: alpha(opacity=80);
}
.modal {
	position: fixed;
	top: 10%;
	left: 50%;
	z-index: 1050;
	width: 560px;
	margin-left: -280px;
	border: 1px solid;
	-webkit-border-radius: 6px;
	-moz-border-radius: 6px;
	border-radius: 6px;
	outline: none;
	-webkit-box-shadow: 0 3px 7px;
	-moz-box-shadow: 0 3px 7px;
	box-shadow: 0 3px 7px;
	-webkit-background-clip: padding-box;
	-moz-background-clip: padding-box;
	background-clip: padding-box;
  display: none;
}
* html .modal {
	position: absolute;
}
.modal.fade {
	top: -25%;
	-webkit-transition: opacity 0.3s linear, top 0.3s ease-out;
	-moz-transition: opacity 0.3s linear, top 0.3s ease-out;
	-o-transition: opacity 0.3s linear, top 0.3s ease-out;
	transition: opacity 0.3s linear, top 0.3s ease-out;
}
.modal.fade.in {
	top: 10%;
}
.modal-header {
	padding: 9px 15px;
	border-bottom: 1px solid;
	text-align: right;
}
.modal-header .close {
  font-size: 20px;
  font-weight: bold;
  line-height: 20px;
  text-shadow: 0 1px 0;
  opacity: 0.2;
  padding: 0;
  cursor: pointer;
  background: transparent;
  border: 0;
  -webkit-appearance: none;
  margin-top: 2px;
}
.modal-header h3 {
	margin: 0;
	line-height: 30px;
}
.modal-body {
	position: relative;
	height: 400px;
	padding: 5px;
	-webkit-overflow-scrolling: touch;
}
.modal_win .navbar .navbar-inner {
	min-height: inherit;
}
.modal_win .navbar .brand {
	font-size: 14px;
	padding: 5px;
}
.modal_win .ss_subtitle {
	font-size: 95%;
}
.modal-form {
	margin-bottom: 0;
}
.modal-footer {
	padding: 14px 15px 15px;
	margin-bottom: 0;
	text-align: right;
	border-top: 1px solid;
	-webkit-border-radius: 0 0 6px 6px;
	-moz-border-radius: 0 0 6px 6px;
	border-radius: 0 0 6px 6px;
 *zoom: 1;
	-webkit-box-shadow: inset 0 1px 0;
	-moz-box-shadow: inset 0 1px 0;
	box-shadow: inset 0 1px 0;
}
.modal-footer:before, .modal-footer:after {
	display: table;
	line-height: 0;
	content: "";
}
.modal-footer:after {
	clear: both;
}
.modal-footer .btn + .btn {
	margin-bottom: 0;
	margin-left: 5px;
}
.modal-footer .btn-group .btn + .btn {
	margin-left: -1px;
}
.modal-footer .btn-block + .btn-block {
	margin-left: 0;
}
@media (width < 768px) {
  #Modal_window {
    height: 93%;
  }
  .modal {
    left: 3%;
      right: 3%;
      width: 94%;
    margin-left: auto;
  }
  .modal-header button {
    width:auto;
  }
  .modal-header .close {
    padding: 10px;
    margin: -10px;
  }
  .modal.fade.in {
    top:3%;
  }
  .modal-header {
    padding: 1% 2%;
  }
  .modal-body {
    height:85%;
  }
  .modal_win #ss_header {
    width: 100%;
  }
}

/* カレンダーUI */
.ui-datepicker {
  width: 17em;
  padding: 0.2em 0.2em 0;
  display: none;
}
.ui-widget {
  font-family: Arial,Helvetica,sans-serif;
  font-size: 1em;
}
.ui-widget-content {
  border: 1px solid;
}
.ui-corner-all {
  border-top-left-radius: 3px;
  border-top-right-radius: 3px;
  border-bottom-left-radius: 3px;
  border-bottom-right-radius: 3px;
}
.ui-widget.ui-widget-content {
  border: 1px solid;
}
.ui-helper-clearfix:before, .ui-helper-clearfix:after {
  content: "";
  display: table;
  border-collapse: collapse;
}
.ui-helper-clearfix:after {
  clear: both;
}
.ui-widget-header {
  border: 1px solid;
  font-weight: bold;
}
.ui-datepicker .ui-datepicker-header {
  position: relative;
  padding: 0.2em 0;
}
.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next {
  position: absolute;
  top: 2px;
  width: 1.8em;
  height: 1.8em;
}
.ui-datepicker .ui-datepicker-prev {
  left: 2px;
}
.ui-datepicker .ui-datepicker-next {
  right: 2px;
}
.ui-datepicker .ui-icon {
  vertical-align: middle;
  width: 16px;
  height: 16px;
  text-indent: -99999px;
  overflow: hidden;
  background-repeat: no-repeat;
}
.ui-icon-circle-triangle-w {
  background-position: -80px -192px;
}
.ui-widget-header .ui-icon {
  background-image: url(smoothness/images/ui-icons_222222_256x240.png);
}
.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span {
  display: block;
  position: absolute;
  left: 50%;
  margin-left: -8px;
  top: 50%;
  margin-top: -8px;
}
.ui-icon-circle-triangle-e {
  background-position: -48px -192px;
}
.ui-datepicker .ui-datepicker-title {
  margin: 0 2.3em;
  line-height: 1.8em;
  text-align: center;
}
.ui-datepicker .ui-datepicker-title select {
  font-family: Arial,Helvetica,sans-serif;
  font-size: 1em;
  margin: 1px 0;
}
.ui-datepicker select.ui-datepicker-month, .ui-datepicker select.ui-datepicker-year {
  width: 45%;
}
.ui-datepicker table {
  width: 100%;
  font-size: .9em;
  border-collapse: collapse;
  margin: 0 0 0.4em;
}
.ui-datepicker th {
  padding: 0.7em 0.3em;
  text-align: center;
  font-weight: bold;
  border: 0;
}
.ui-state-disabled {
  cursor: default !important;
  pointer-events: none;
}
.ui-datepicker td {
  border: 0;
  padding: 1px;
}
.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled {
  opacity: .35;
  filter: Alpha(Opacity=35);
  background-image: none;
}
.ui-datepicker td span, .ui-datepicker td a {
  display: block;
  padding: 0.2em;
  text-align: right;
  text-decoration: none;
}
.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default, .ui-button, html .ui-button.ui-state-disabled:hover, html .ui-button.ui-state-disabled:active {
  border: 1px solid;
  font-weight: normal;
}
.ui-state-hover,
.ui-widget-content .ui-state-hover,
.ui-widget-header .ui-state-hover,
.ui-state-focus,
.ui-widget-content .ui-state-focus,
.ui-widget-header .ui-state-focus,
.ui-button:hover,
.ui-button:focus {
	border: 1px solid;
	font-weight: normal;
}
.ui-datepicker .ui-datepicker-prev-hover {
	left: 1px;
}
.ui-datepicker .ui-datepicker-next-hover {
	right: 1px;
}
.ui-state-hover .ui-icon,
.ui-state-focus .ui-icon,
.ui-button:hover .ui-icon,
.ui-button:focus .ui-icon {
	background-image: url("smoothness/images/ui-icons_888888_256x240.png");
}
.ui-state-hover,
.ui-widget-content .ui-state-hover,
.ui-widget-header .ui-state-hover,
.ui-state-focus,
.ui-widget-content .ui-state-focus,
.ui-widget-header .ui-state-focus,
.ui-button:hover,
.ui-button:focus {
	border: 1px solid;
	font-weight: normal;
}
.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {
  border: 1px solid;
}
.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active, a.ui-button:active, .ui-button:active, .ui-button.ui-state-active:hover {
  border: 1px solid;
  font-weight: normal;
}

/* =============================================
	イベントページ
============================================= */
/* セッション一覧 */
body.event-session .session-navigation-wrapper {
  position: relative;
  height: 42px;
  margin-bottom: 40px;
}
body.event-session .session-navigation {
  position: absolute;
  z-index: 5;
  width: 100%;
  height: 42px;
  top: 0;
  right: 0;
}
body.event-session .session-navigation ul {
  display: flex;
  border-bottom: solid 2px;
}
body.event-session .session-navigation ul li {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 40px;
  padding: 0 10px;
  text-align: center;
  font-size: 15px;
  line-height: 1;
  font-weight: 700;
}
body.event-session .session-day-wrapper {
  min-height: 100vh;
  padding-top: 20px;
}
body.event-session .session-day .sessionlist {
  margin-bottom: 40px;
}
body.event-session .session-day .sessionlist h3 {
  margin-bottom: 20px;
  text-align: center;
  font-size: 26px;
  line-height: 1;
  font-weight: 900;
}
body.event-session .sessionlist .session-item {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 80%;
  height: auto;
  margin: 0 auto 20px;
  box-sizing: border-box;
  padding: 15px;
  border-radius: 5px;
  border: solid 2px;
}
body.event-session .sessionlist .session-item::after {
  position: absolute;
  z-index: 2;
  content: '';
  width: calc(100% + 4px);
  height: 5px;
  left: -2px;
  top: -2px;
  border-top-left-radius: 5px;
  border-top-right-radius: 5px;
}
body.event-session .sessionlist .session-time {
  display: none;
}
body.event-session .sessionlist .session-title {
  margin-bottom: 10px;
  font-size: 18px;
  line-height: 1.3;
  font-weight: 700;
}
body.event-session .sessionlist .session-title a {
  font-weight: 700;
}
body.event-session .sessionlist .session-summary {
  display: none;
}
body.event-session .sessionlist .speaker-container {
  margin-top: 12px;
  margin-bottom: 20px;
}
body.event-session .sessionlist .session-speaker {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    position: relative;
}
body.event-session .sessionlist .session-speaker .speaker-photo {
    width: 80px;
}
body.event-session .sessionlist .session-speaker .speaker-photo:not([src='']) {
    margin-bottom: 15px;
}
body.event-session .sessionlist .session-speaker > div {
    width: calc(100% - 90px);
    font-size: 11px;
    line-height: 1.5;
}
body.event-session .sessionlist .session-bottom {
  margin: auto 0 0;
}
body.event-session .sessionlist .session-link {
  display: flex;
  justify-content: center;
  margin-bottom: 20px;
}
body.event-session .sessionlist .session-link a {
  display: flex;
  align-items: center;
}
body.event-session .sessionlist .session-link a svg {
  width: 20px;
  height: 20px;
}
body.event-session .sessionlist .session-link a span {
  margin-left: 5px;
  font-size: 11px;
  line-height: 1;
}
body.event-session .sessionlist .session-button {
  display: block;
  width: 160px;
  height: 16px;
  margin: 0 auto;
  padding: 10px 0;
  text-align: center;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
}
body.event-session .session-overlay {
  position: fixed;
  z-index: 40;
  display: none;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  overflow: auto;
}
body.event-session .session-overlay > div {
  position: absolute;
  width: 100%;
  min-height: 100%;
  left: 0;
  top: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  padding: 20px;
}
body.event-session .session-overlay .session-item {
  position: relative;
  width: 100%;
  height: auto !important;
  box-sizing: border-box;
  padding: 15px;
  border-radius: 5px;
  border: solid 2px;
}
body.event-session .session-overlay .session-item::after {
	position: absolute;
	z-index: 2;
	content: '';
	width: calc(100% + 4px);
	height: 5px;
	left: -2px;
	top: -2px;
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
}
body.event-session .session-overlay .session-time {
  margin-bottom: 10px;
  font-size: 16px;
  line-height: 1.2;
  font-weight: 700;
}
body.event-session .session-overlay .session-title {
  margin-bottom: 10px;
  font-size: 18px;
  line-height: 1.3;
  font-weight: 700;
}
body.event-session .session-overlay .session-summary {
  margin-bottom: 20px;
  font-size: 14px;
  line-height: 1.6;
}
body.event-session .session-overlay .session-speaker {
    position: relative;
    min-height: 80px;
    padding-left: 90px;
}
body.event-session .session-overlay .session-speaker + .session-speaker {
    margin-top: 15px;
}
body.event-session .session-overlay .session-speaker .speaker-photo {
    position: absolute;
    width: 80px;
    left: 0;
    top: 0;
}
body.event-session .session-overlay .session-overlay-close {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 160px;
  height: 40px;
  margin-top: 20px;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
}
body.event-session .caution-overlay {
  position: fixed;
  z-index: 50;
  display: none;
  width: 100%;
  height: 100%;
  left: 0;
  top: 0;
  overflow: auto;
}
body.event-session .caution-overlay > div {
  position: absolute;
  width: 100%;
  min-height: 100%;
  left: 0;
  top: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
  padding: 20px;
}
body.event-session .caution-overlay .caution-text {
  position: relative;
  width: 100%;
  height: auto !important;
  box-sizing: border-box;
  padding: 25px 15px;
  border-radius: 5px;
  border: solid 2px;
}
body.event-session .caution-overlay .caution-text h4 {
  margin-bottom: 20px;
  text-align: center;
  font-size: 18px;
  line-height: 1.3;
  font-weight: 700;
}
body.event-session .caution-overlay .caution-text p {
  margin-bottom: 20px;
  font-size: 13px;
  line-height: 1.6;
}
body.event-session .caution-overlay .caution-text ul li {
  padding-left: 1em;
  text-indent: -1em;
  font-size: 13px;
  line-height: 1.6;
}
body.event-session .caution-overlay .caution-text ul li + li {
  margin-top: 15px;
}
body.event-session .caution-overlay .caution-text .caution-check {
  margin: 30px auto;
  text-align: center;
}
body.event-session .caution-overlay .caution-text input[type='checkbox'] {
  position: absolute;
  width: 0;
  height: 0;
  opacity: 0;
  pointer-events: none;
}
body.event-session .caution-overlay .caution-text .checkbox-text {
  display: inline-block;
  position: relative;
  padding-left: 25px;
  text-align: left;
  font-size: 14px;
  line-height: 1.2;
  cursor: pointer;
}
body.event-session .caution-overlay .caution-text .checkbox-text::before {
  position: absolute;
  content: '';
  top: 0;
  left: 0;
  width: 15px;
  height: 15px;
  border: 1px solid;
  border-radius: 5px;
}
body.event-session .caution-overlay .caution-text input[type='checkbox']:checked + .checkbox-text::after {
  position: absolute;
  content: '';
  top: -3px;
  left: 6px;
  width: 5px;
  height: 13px;
  transform: rotate(40deg);
  border-bottom: 3px solid;
  border-right: 3px solid;
}
body.event-session .caution-overlay .caution-text .caution-button {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 160px;
  height: 40px;
  margin: 20px auto 0;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
}
body.event-session .caution-overlay .caution-text .caution-button {
  transition: background 0.5s;
}
@media (width > 767px){
  body.mypage.event-session .event-menuArea.wide.open {
    transition-duration: 0s;
  }
  body.event-session .session-navigation-wrapper {
      height: 50px;
      margin-bottom: 40px;
  }
  body.event-session .session-navigation {
      height: 47px;
  }
  body.event-session .session-navigation ul li {
      height: 47px;
      padding: 0 40px;
      font-size: 22px;
      transition: color 0.5s;
  }
  body.event-session .session-navigation ul li:not(.current):hover {
      cursor: pointer;
  }
  body.event-session .session-day .sessionlist {
      width: 94%;
      margin: 0 auto 40px;
  }
  body.event-session .session-day .sessionlist h3 {
      margin-left: 10px;
      text-align: left;
      font-size: 32px;
  }
  body.event-session .item-container {
      display: flex;
      flex-wrap: wrap;
  }
  body.event-session .sessionlist .session-item {
      transition: transform 0.5s,box-shadow 0.5s,border 0.5s;
  }
  body.event-session .sessionlist .session-item:hover {
      transform: translateY(-5px);
  }
  body.event-session .item-container.item2 li {
      width: calc(50% - 20px);
  }
  body.event-session .item-container.item3 li {
      width: calc(33.3% - 20px);
  }
  body.event-session .item-container.item4 li {
      width: calc(25% - 20px);
  }
  body.event-session .item-container.item5 li {
      width: calc(20% - 20px);
  }
  body.event-session .session-day .sessionlist .session-item {
      margin: 0 10px 20px;
  }
	body.event-session .sessionlist .session-speaker > div {
		font-size: 12px;
	}
  body.event-session .sessionlist .session-link a:hover {
      cursor: pointer;
  }
  body.event-session .sessionlist .session-button {
      transition: background 0.5s;
      cursor: pointer;
  }
  body.event-session .session-overlay > div {
      height: 100%;
  }
  body.event-session .session-overlay .session-item {
      width: 750px;
      padding: 20px;
  }
  body.event-session .session-overlay .session-title {
      font-size: 20px;
  }
  body.event-session .session-overlay .flexWrap {
      display: flex;
      justify-content: space-between;
  }
  body.event-session .session-overlay .session-summary {
      width: 364px;
      margin: 0;
      padding-right: 20px;
      border-right: solid 1px;
  }
  body.event-session .session-overlay .speaker-container {
      width: 300px;
  }
  body.event-session .session-overlay .session-overlay-close {
      transition: background 0.5s;
  }
  body.event-session .session-overlay .session-overlay-close:hover {
      cursor: pointer;
  }
  body.event-session .caution-overlay > div {
      height: 100%;
  }
  body.event-session .caution-overlay .caution-text {
      width: 600px;
      padding: 20px;
  }
  body.event-session .caution-overlay .caution-text h4 {
      font-size: 20px;
  }
  body.event-session .caution-overlay .caution-text p {
      font-size: 15px;
  }
  body.event-session .caution-overlay .caution-text ul li {
      font-size: 15px;
  }
  body.event-session .caution-overlay .caution-text .caution-button {
      transition: background 0.5s;
  }
  body.event-session .caution-overlay .caution-text .caution-button:hover {
      cursor: pointer;
  }
}
@media (width >= 1080px) {
  body.mypage.event-session main.wide,
  body.mypage.event-session footer.wide {
      width: calc(100% - 251px);
  }
}

/* 動画視聴ページ */
body.event-session .movie-A {
    margin-bottom: 30px;
}
body.event-session .movie-B .movie-text h2 {
    margin: 0 auto 15px;
    text-align: left;
    font-size: 18px;
    line-height: 1.3;
    font-weight: 900;
}
body.event-session .movie-A .movie-space {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 56.25%;
}
body.event-session .movie-container {
    text-align: center;
}
body.event-session .movie-A .movie-container {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
}
body.event-session .movie-A .thumbnail-container {
    display: none;
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
}
body.event-session .movie-A .movie-container:empty + .thumbnail-container {
    display: flex;
    justify-content: space-evenly;
    align-items: center;
}
body.event-session .movie-A .thumbnail-container img {
    width: 80%;
}
body.event-session .movie-B {
    margin-bottom: 40px;
}
body.event-session .movie-B .movie-text {
    width: 90%;
    margin: 0 auto;
}
body.event-session .movie-B .movie-text h2 {
    margin: 0 auto 15px;
    text-align: left;
    font-size: 18px;
    line-height: 1.3;
    font-weight: 900;
}
body.event-session .movie-B .movie-text .movie-title .title-container {
    display: flex;
    align-items: center;
}
body.event-session .movie-B .movie-text .movie-date {
    font-size: 15px;
    line-height: 1;
}
body.event-session .movie-B .movie-info {
    margin-top: 30px;
}
body.event-session .session_pop {
    border: 1px solid;
}
body.event-session .movie-B .movie-item {
    margin: 0 auto 20px;
}
body.event-session .border_size_summary {
    border-right: 1px solid;
}
body.event-session .movie-B .movie-item h3 {
    position: relative;
    font-size: 16px;
    line-height: 1;
    font-weight: 700;
    box-sizing: border-box;
    padding: 15px;
}
body.event-session .movie-B .movie-item h3 span {
    float: right;
    transition: transform 0.2s;
}
body.event-session .movie-B .movie-item h3 span.open {
    transform: rotate(90deg);
}
body.event-session .movie-B .movie-item .toggleArea {
    display: none;
    padding: 5px 15px 15px;
    transition: opacity 0.2s;
    opacity: 0;
}
body.event-session .movie-B .movie-item.open .toggleArea {
    opacity: 1;
}
body.event-session .movie-B .movie-summary {
    font-size: 15px;
    line-height: 1.6;
}
body.event-session .movie-B .movie-document .movie-doc-item {
    position: relative;
    margin: 0 auto;
}
body.event-session .movie-B .movie-document .movie-doc-item + .movie-doc-item {
    margin-top: 15px;
}
body.event-session .movie-B .movie-document .movie-doc-item a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 100%;
    box-sizing: border-box;
    padding: 8px;
    border: solid 1px;
    border-radius: 5px;
}
body.event-session .movie-B .movie-document .movie-doc-text {
    width: calc(100% - 135px);
    margin: 0 10px;
}
body.event-session .movie-B .movie-document .movie-doc-download {
    width: 25px;
}
body.event-session .movie-B .movie-document .movie-doc-download svg {
    width: 25px;
    height: 25px;
}
body.event-session .movie-B .movie-document .movie-doc-download span {
    display: none;
}
body.event-session li.movie-doc-item.removeParentLink:hover {
    transform: translateY(-4px);
    transition: transform 0.5s,box-shadow 0.5s;
    border-radius: 4px;
}
body.event-session .speaker_area {
    border: 1px solid;
}
body.event-session .movie-B .movie-speaker .movie-speaker-item {
    position: relative;
    display: flex;
    align-items: flex-start;
    margin-bottom: 40px;
}
body.event-session .movie-B .movie-speaker .movie-speaker-item + .movie-speaker-item {
    margin-top: 15px;
}
body.event-session .movie-B .movie-speaker .movie-speaker-item .movie-speaker-photo {
    width: 80px;
    margin-right: 10px;
}
body.event-session .movie-B .movie-speaker .movie-speaker-item .movie-txt {
    width: calc(100% - 90px);
}
body.event-session .movie-txt span {
    font-size: 12px;
}

@media (width > 767px) {
	body.event-session .movie-wrapper {
	    max-width: 1400px;
	    margin: 0 auto;
	}
	body.event-session .movie-A {
	    display: flex;
	    justify-content: space-between;
	    padding: 30px 30px 0;
	}
	body.event-session .movie-A .movie-main {
	    width: calc(100% - 400px);
	}
	body.event-session .movie-A .movie-main.nochat {
	    width: 100%;
	    margin: 0 auto;
	}
	body.event-session .movie-B {
	    margin-bottom: 60px;
	    padding: 0 30px;
	}
	body.event-session .movie-B .movie-text {
	    position: relative;
	    width: 100%;
	}
	body.event-session .movie-B .movie-text .movie-title {
	    padding-right: 180px;
	}
	body.event-session .movie-B .movie-text h2 {
	    font-size: 24px;
	}
	body.event-session .movie-B .movie-text .movie-date {
	    font-size: 16px;
	}
	body.event-session .movie-B .movie-info {
	    display: flex;
	    justify-content: flex-start;
	}
	body.event-session .movie-B .movie-tab {
	    overflow: hidden;
	}
	body.event-session .movie-B .movie-tab > div {
	    display: flex;
	    justify-content: space-between;
	    width: 200%;
	    height: 100%;
	}
	body.event-session .movie-B .movie-item {
	    margin: 0;
	}
	body.event-session .movie-B .movie-tab .movie-item {
	    width: 50%;
	}
	body.event-session .h3_width {
	    width: 49.95% !important;
	}
	body.event-session .movie-B .movie-item h3 {
	    font-size: 18px;
	}
	body.event-session .movie-B .movie-tab .movie-item h3 {
	    width: 50%;
	    text-align: center;
	    transition: color 0.3s;
	}
	body.event-session .movie-B .movie-tab.p2 .movie-item h3.movie-summary-h3:hover {
	    cursor: pointer;
	}
	body.event-session .movie-B .movie-item h3 span {
	    float: none;
	    display: inline-block;
	    margin-left: 10px;
	    transition: none;
	    transform: scale(0.7) rotate(90deg);
	}
	body.event-session .movie-B .movie-tab .movie-item h3 span {
	    transition: color 0.3s;
	}
	body.event-session .movie-B .movie-item .toggleArea {
	    display: block !important;
	    opacity: 1;
	}
	body.event-session .movie-B .movie-tab .movie-item .toggleArea {
	    padding-top: 15px;
	}
	body.event-session .movie-B .movie-document-space h3 {
	    margin: 0 0 0 auto;
	    transform: translateX(-200%);
	}
	body.event-session .movie-B .movie-tab .movie-item h3.movie-document-h3:hover {
	    cursor: pointer;
	}
	body.event-session .movie-B .movie-tab.p2 .movie-item h3.movie-document-h3:hover {
	    cursor: default;
	}
	body.event-session .movie-B .movie-tab.p2 .movie-item .toggleArea {
	    transform: translateX(-100%);
	}
	body.event-session .movie-B .movie-document .movie-doc-item a {
	    transition: border 0.3s;
	}
	body.event-session .movie-B .movie-document .movie-doc-download svg {
	    transition: fill 0.3s;
	}
	body.event-session .movie-B .movie-speaker-space {
	    flex-shrink: 0;
	    width: 275px;
	    margin-left: 30px;
	}
	body.event-session .movie-B .movie-speaker-space h3 span {
	    display: none;
	}
}
@media (width >= 1180px) {
	body.event-session .movie-B {
	    display: flex;
	    justify-content: space-between;
	}
	body.event-session .movie-B .movie-text {
	    margin: 0;
	}
}
@media (width < 768px) {
	body.event-session .session_pop {
	    border: none;
	}
	body.event-session .movie-item.movie-summary-space {
	    border: 1px solid;
	}
	body.event-session .border_size_summary {
	    border-right: none;
	}
	body.event-session .movie-item.movie-summary-space.open h3 {
	    border-bottom: 1px solid;
	}
	body.event-session .movie-item.movie-document-space {
	    border: 1px solid;
	}
	body.event-session .border_size_document {
	    border-left: none;
	}
	body.event-session .movie-item.movie-document-space.open h3 {
	    border-bottom: 1px solid;
	}
	body.event-session .speaker_area.open h3 {
	    border-bottom: 1px solid;
	}
}