@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@100..900&display=swap');


/* base ******************************************************************************/

body {
    position: relative;
    word-wrap: break-word;
    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #151515;
    font-family: "Outfit", Arial, "游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 16px;
    line-height: 1.8;
    overflow-wrap: break-word;
    background-color:#fff;
}


.container {
width: 100%;
position:relative;

}

.container::before{
position:fixed;
top:0;
left:0;
width:100%;
height:100%;
background:url(/info/event/ibsf/202410/media/img_bg_main.jpg) center bottom no-repeat;
background-size:cover;
opacity:0.5;
}


.container-fluid {
max-width: 1150px;
margin: 0 auto;
padding:0 !important;
background:transparent;
}

.container-fluid a{
color:#f4593f;
}

#social_bkm_wrap_top {
margin: 0 auto;
height: auto;
border: none;
}



/* header ******************************************************************************/


@keyframes slide{
0% {
height:0;
}
100% {
height:100%;
}
}

.event-header{
width:100%;
height:100%;
padding:0;
background:url(/info/event/ibsf/202410/media/img_mainvisual.jpg) center center no-repeat;
position:relative;
overflow:hidden;
}


.event-header #canvas{
position:absolute;
top:-15%;
left:0;
}

.event-header .header-inner{
max-width:1200px;
height:500px;
display:flex;
flex-direction:column;
justify-content:center;
margin: 0 auto;
padding:10px;
text-align:center;
width:fit-content;
position:relative;
z-index:10;
}


.event-header .ttl-headline{
font-size:clamp(1.25rem, 0.75rem + 1.25vw, 2rem);
font-family: "Outfit", sans-serif;
/*font-weight:bold;*/
color:#2b9bf4;
margin:0 auto;
padding-bottom:20px;
width:fit-content;
position:relative;
z-index:1;
}


.event-header h1{
position: relative;
z-index:100;
font-size:clamp(1.25rem, 0.75rem + 1.25vw, 2rem);
font-family: "Outfit", Arial, "游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
color:#050505;
line-height:1.4;
display:flex;
flex-direction:column;
justify-content:center;
width:fit-content;
}

.event-header h1 small{
font-size:70%;
}


.info-date {
margin:20px auto 25px;
padding: 5px 30px;
font-size: 1.25rem;
color:#050505;
line-height:1.4;
width:fit-content;
position:relative;
z-index:100;
}

.info-date::before{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:0;
background:rgba(255,255,255,0.85);
border-radius:15px;
box-shadow: 0 15px 15px -10px #999;
z-index:-1;
animation: slide 0.5s ease-in 0.5s forwards;
}


.info-date span{
font-size:210%;
/*font-weight:bold;*/
}



.event-summary{
margin: 0 auto;
padding:10px 0;
background:rgba(43,155,244,0.6);
backdrop-filter: blur(5px);
position:relative;
}

.event-summary p {
max-width:1100px;
margin:0 auto;
font-size: 16px;
line-height: 1.8;
padding: 15px;
color:#fff;
font-family:"游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
position:relative;
z-index:10;
}




/* 開催概要 ******************************************************************************/



.closed-text{
color: #151515;
font-weight: bold;
text-align:center;
padding: 40px 0;
text-align:center;
position:relative;
z-index:10;
}

.event-overview{
padding-bottom:40px;
background: linear-gradient(0deg, rgba(255,255,255,0.5) 10%, rgba(193,234,252,1) 100%);
text-align: center;
position:relative;
}


.information {
margin:45px auto 0;
padding:30px 0 0;
font-size: 1rem;
position:relative;
z-index:100;
}

.information th,
.information td{
border:1px solid #050505;
/*background:rgba(255,255,255,0.5);*/
background:none;
padding:20px;
}

.information th {
/*display:flex;
align-items:center;*/
color:#050505;
font-weight:bold;
text-align:left;
position:relative;
}


.information td {
/*margin: 0 0 16px 12em;*/
color:#050505;
font-weight:bold;
margin:0 0 10px !important;
text-align:left;
}



/* 見出し ******************************************************************************/


h2 {
text-align:left;
margin:0 auto;
padding:30px 0 30px 25px;
color: #151515;
font-family: "Outfit", Arial, "游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
font-size: clamp(1.5rem, 0.833rem + 1.67vw, 2.5rem);
font-weight:normal;
border: none;
max-width:1150px;
position: relative;
z-index:10;
}

h2::before{
content:"";
position:absolute;
top:0;
left:0;
width:2px;
height:100%;
border-radius:0 0 5px 5px;
background-color:#050505;
}


h2 span{
font-size: clamp(1rem, 0.5rem + 1.25vw, 1.75rem);
font-family: "Outfit", Arial;
font-weight:normal;
color:#808080;
display:block;
z-index:-1;
}



h2.black{
color:#151515;
}
h2.white{
color:#fff;
}

h2.white::before{
background-color:#fff;
}
h2.white span{
color:#fff;
}




/* 講演内容 ******************************************************************************/


.fade {
	opacity: 0;
	transform: translateY(70px);
	transition: opacity 1.2s, transform 0.8s;
}
.fade.active {
	opacity: 1;
	transform: translateY(0px);
}



.event-session{
padding:0 0 45px 0;
position:relative;
background: linear-gradient(0deg, rgba(255,255,255,0.4) 20%, rgba(195,245,242,0.9) 100%);
z-index:1;
}





/*.event-session .container-fluid{
max-width:1000px;
}*/


.event-session .parts-left{
position:absolute;
top:10%;
left:0;
text-align:left;
}

.event-session .parts-left_bottom{
position:absolute;
bottom:-30%;
left:0;
text-align:left;
}

.event-session .parts-right{
position:absolute;
top:50%;
right:0;
text-align:right;
}



.session-program{
margin:45px auto;
padding:0;
position:relative;
z-index:10;
}


table th{background:none;}

.session-program table{
margin:8% auto;
/*box-shadow:0 20px 20px -10px #a0a0a0;*/
position:relative;
z-index:10;
}


.session-program th,
.session-program td {
vertical-align:middle;
border:none !important;
}



.session-program td {
background-color:#fff;
padding:35px;
border-radius:15px;
position: relative;
line-height: 1.3 !important;
}


.session-program .session-label{
position:absolute;
top:-20px;
left:25px;
background-color:#4f5bcc;
color:#fff;
font-size:16px;
margin:0 auto;
padding:10px 25px;
display:flex;
flex-direction:column;
justify-content:center;
text-align:center;
border-radius: 30px;
width:fit-content;
z-index:100;
}

.session-program .session-label.keynote{background-color:#03b4a8;}


.session-program .session-time{
color:#151515;
margin:0;
padding:20px 0 5px 0;
font-family: "Outfit", Arial, "游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
font-size:2rem;
text-align:left;
/*border-bottom:1px solid #ccc;*/
width:fit-content;
position:relative;
}


.session-program td.session .session-title {
margin:0;
padding:20px 0;
font-size: 2rem;
line-height:1.4;
color:#151515;
font-feature-settings: "palt" 1;
}


.session-program td .session-title small {
display: block;
font-size: 80%;
font-weight: normal;
}



.session-program td.session .session-summary {
letter-spacing: 0;
color:#666;
font-size:1rem;
padding-bottom:25px;
line-height:1.6;
}


.session-program td.session .session_profile {
margin:0;
padding: 30px 0;
border-top:2px solid #4f5bcc;
/*border-top: 1px dotted #ccc;*/
font-size:1rem;
color:#151515;
display:flex;
overflow: hidden;
}
.session-program td.session .session_profile.keynote{border-top:2px solid #03b4a8;}


.session-program td.session .progress-label,
.session-program td.session .speaker-label {/*モデレータ ファシリテータ*/
    width: fit-content;
margin:15px 0 0 0;
    padding: 5px 10px;
    background-color: #07789e;
    color: #fff;
    text-align: center;
    font-size: 13px;
    line-height: 1;
display:block;
}
.session-program td.session .speaker-label {background-color: #E55845;}



.session-program td.session .profile_thumb {
margin: 0 24px 4px 0;
width:130px;
flex-shrink: 0;
}

.session-program td.session .profile_thumb img{
box-shadow:0 15px 15px -10px #e0e0e0;
border-radius:10px;
display:block;
}

.session-program td.session .profile_name {
line-height: 1.5;
}

.session-program td.session .profile_name span{
font-size:100%;
font-weight: bold;
padding-top:4px;
display:block;
}

.session-program td.session .profile_name .profile_accordion {
margin: 8px 0 0 0;
line-height: 1.6;
}

.session-program td.session .profile_name .js-profile-trigger {
position: relative;
display: inline-block;
font-size:12px;
font-weight:normal;
padding:2px 10px;
color: #666;
box-shadow:0 0 15px #ccc;
border-radius:5px;
cursor: pointer;
width:fit-content;
font-feature-settings:"palt";
}

.session-program td.session .profile_name .js-profile-trigger:hover{
background-color:#333;
color: #fff;
box-shadow:none;
transition:0.3s;
}


.session-program td.session .profile_name .js-profile-detail {
padding-top: 8px;
font-size:13px;
font-weight:normal;
color:#999;
}




/* 申し込み ******************************************************************************/


.event-entry{
position:relative;
background:#c1eafc;
}


.event-entry::before{
content:"";
position:absolute;
bottom:0;
left:0;
background:url(/info/event/ibsf/202410/media/img_bg_entry.png) center bottom no-repeat;
width:100%;
height:100%;
}


.privacy-note {
margin:0 auto 45px;
padding: 30px;
background-color:#fff;
color:#050505;
font-size: 12px;
text-align:left;
border-radius:10px;
max-width:850px;
position:relative;
z-index:10;
}

.privacy-note p a{
color:#544fcc;
font-weight:bold;
}




/*btn default setting*/



.btn-register {
width: 100%;
margin: 0 auto;
padding:0;
text-align:center;
position:relative;
z-index:10;
}


.btn {
display: inline-block;
box-sizing: border-box;
margin:45px auto;
padding: 30px 15px;
font-weight: bold;
font-size: 20px;
background-color:#0176d3;
color: #fff !important;
text-align: center;
border-radius: 15px;
cursor: pointer;
box-shadow: 0 15px 15px -10px #444;
position:relative;
z-index:100;
}



.btn::before {
content: "";
width: 100%;
height: 100%;
position: absolute;
top: 0;
left: 0;
z-index: -1;
background: #2b9bf4;
transform-origin: 0% 50%;
transform: scaleY(0);
transition: transform ease .3s;
border-radius:15px;
}


.btn:hover{
border-radius: 15px;
color: #fff !important;
}

.btn:hover::before {
transform-origin: 100% 50%;
transform: scaleY(1);
}



.btn span{
display: flex;
align-items: center;
justify-content: center;
line-height:1.5;
height: 100%;
font-weight:bold;
}



/*btn size setting*/

.large{
width: 80%;
height: 60px;
}

.small{
width: 25%;
/*height: 90px;*/
}




/* sponsor logo ******************************************************************************/


.event-sponsor {
padding: 0;
background-color: #fff;
position:relative;
z-index:10;
}

.event-sponsor h3 {
margin: 0 auto;
text-align: center;
background-color:#f8f8f8;
color: #151515; 
padding:15px 5px;
font-size: 1.5rem;
font-weight:normal;
width:100%;
}

.event-sponsor ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
padding:20px 0;
}
.event-sponsor li {
  width: 30%;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}


.privacy-area {
    border: 1px solid #ccc;
    margin: 50px auto 0;
    padding: 16px;
    height: 150px;
    overflow: auto;
}
.privacy-area p.content {
    font-size: 80%;
    margin: 15px auto;
    text-align: center;
}
.privacy-area p {
    font-size: 50%;
    line-height: 2.0;
}



/* inquiry */

.event-inquiry{
text-align:left;
background:rgba(212,210,245,0.8);
padding-bottom:45px;
}

.event-inquiry p{
color:#fff;
position:relative;
z-index:10 !important;
margin:10px 0 0 0;
}

.event-inquiry p a{
color:#544fcc;
font-weight:bold;
}

footer{
margin-top:0;
position:relative;
z-index:10;
}





/* responsive 
------------------------------------------------------------------------------- */



@media (max-width: 1000px) {



/*.event-header{
background-position:center top;
}*/


.info-date {
font-size:1rem;
}


.large, .small{
width:60% !important;
margin:30px auto;
}

.sponsor li {
  width: 100%;
  margin-bottom: 24px;
}


.event-overview,
.event-session,
.event-entry{
padding:0 15px 45px;
}


.event-session .parts-left img,
.event-session .parts-left_bottom img,
.event-session .parts-right img{
max-width:50%;
}




}



@media (max-width: 640px) {


.container-fluid {margin: 0;}


.event-header{
background-position:center top;
}

.event-header .header-inner{
padding:15px;
height:auto;
}


.info-date {
font-size:0.85rem;
}


.event-summary{
padding:15px;
}

.event-summary p{
padding:0;
}


.information {
display:block;
}


.information dt,
.information dd{
font-size: 1rem;
margin: 0 0 10px;
width: auto;
}

.information{
padding:10px;
}

.event-session .parts-left,
.event-session .parts-left_bottom,
.event-session .parts-right{
display:none;
}

.session-program{
margin:15px auto;
}

.session-program th,
.session-program td {
width:100%;
display:inline-block;
}


.session-program td.session{
padding:15px;
}

.session-program .session-time::before{
display:none;
}

.session-program td.session .session-title{
font-size:1.5rem;
}

.session-program .session-time{
font-size:1.5rem;
}


.session-program td.session .session-label,
.session-program td.session .profile_name,
.session-program td.session .profile_detail,
.session-program td.session .session_profile{
font-size: 13px;
}


.session-program td.session .profile_thumb{
width:100px;
height:100px;
}



.large, .small{
width:90% !important;
margin:30px auto;
}


.event-sponsor ul {
display:block;
}

.event-sponsor ul li{
margin:10px auto;
}



}





/*************** login page & video page ***************/





.event-header.webinar-header .header-inner{
height: 250px;
background:rgba(214,240,253,0.7);
padding:15px;
}


.event-header.webinar-header .ttl-headline,
.event-header.webinar-header h1{
font-size:1.5rem;
}



.video_block{
position:relative;
background: linear-gradient(0deg, rgba(255,255,255,0.5) 10%, rgba(193,234,252,1) 100%);
text-align: center;
}



.video {
  width:100%; 
  margin: 40px auto;
}
.video-wrapper {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 56.25%;
z-index:100;
}
.video-wrapper iframe,
.video-wrapper video {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}


.video_block p{
position:relative;
z-index:100;
}


.video_block p a{
color:#544fcc;
font-weight:bold;
}


.enq-text{
color:#050505;
padding:20px 10px;
}


.support{
text-align:center;
color:#050505;
padding:0 0 40px 0;
}




@media (max-width: 640px) {



}









/* ヘッダー＆フッター広告表記 2024～
-------------------------------------------------------------------------------------------------------*/

.header_sponsored_area{
    width:100%;
    background-color:#fff;
    color:#000;
    font-size:14px;
    text-align:right;
    padding:15px 20px;
    position:relative;
    z-index:1000;
}

.header_sponsored_area span{
    margin:0;
    line-height:1.3;
    display:block;
}


.block_sponsored_area{
    clear:both;
    background-color:#fff;
    color:#000;
    font-size:14px;
    border:1px solid #000;
    margin:25px auto;
    padding:15px 15px 10px;
    max-width:760px;
    position:relative;
    z-index:1000;
}

.block_sponsored_area span{
    margin:5px 0;
    text-align:left;
    display:block;
}


.block_sponsored_area:before{
    display: block;
    content: "PR";
    position: absolute;
    top: -12px;
    left: 30px;
    width: 40px;
    height: 30px;
    text-align: center;
    background-color: #fff;
}


@media screen and (max-width: 800px) {

.block_sponsored_area{
margin:25px;
}


}

