@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap');



/* font setting */

@font-face {
font-family: 'googlefont-r';
font-style: normal;
font-weight: normal;
src: url('https://storage.aiasahi.jp/zdnet/2024/google/fonts/GoogleSans-Regular.ttf') format('truetype');
}


@font-face {
font-family: 'googlefont-m';
font-style: normal;
font-weight: normal;
src: url('https://storage.aiasahi.jp/zdnet/2024/google/fonts/GoogleSans-Medium.ttf') format('truetype');
}


@font-face {
font-family: 'googlefont-b';
font-style: normal;
font-weight: normal;
src: url('https://storage.aiasahi.jp/zdnet/2024/google/fonts/GoogleSans-Bold.ttf') format('truetype');
}


body {
position: relative;
    word-wrap: break-word;
    color: #444;
    /*font-family: Arial, "游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;*/
font-family: 'googlefont-r', 'Noto Sans JP', sans-serif !important;
    font-weight: 400;
    font-style: normal;
    font-size: 16px;
    line-height: 1.8;
    overflow-wrap: break-word;
background:#fff !important;
}



.container {
width: 100%;
position:relative;
}



.container-fluid {
max-width: 1300px;
margin: 0 auto;
background:transparent;
color:#202124;
}

.container-fluid a{
color:#f4593f;
}

#social_bkm_wrap_top {
margin-bottom: 0;
height: auto;
border: none;
}



/* header ******************************************************************************/


.event-header{
max-width:1300px;
height:500px;
display:flex;
justify-content:space-around;
align-items:center;
background-color:#f8f8f8;
border-radius:30px;
margin:0 auto;
padding:0 10px;
position:relative;
}



.event-header h1{
position: relative;
z-index:100;
font-size:2rem;
color:#202124;
line-height:1.5;
display:flex;
flex-direction:column;
justify-content:center;
width:fit-content;
margin:0 auto;
font-feature-settings: "palt" 1;
}

.event-header h1 small{
font-size:70%;
}


.event-header .header-visual{
max-width:100%;
/*animation: fade-right 0.3s linear 0.3s forwards;
opacity: 0;*/
}



.event-header .header-visual img{
max-width:500px;
padding-right:20px;
}

.info-date {
margin:15px 0;
padding: 5px 30px;
font-size: 1.25rem;
background-color: #4285f4;
color:#fff;
line-height:1.4;
width:fit-content;
border-radius:50px;
position:relative;
z-index:1000;
}

.info-date strong{
font-size:150%;
}


@keyframes fade-left{
  0% {
    opacity: 0;
transform:translateX(-50px);
}

  100% {
    opacity: 1;
transform:translateX(0);
}
}

@keyframes fade-right{
  0% {
    opacity: 0;
transform:translateX(50px);
}

  100% {
    opacity: 1;
transform:translateX(0);
}
}



/* 開催概要 ******************************************************************************/


.closed-text{
color: #202124;
font-weight: bold;
text-align:center;
padding: 40px 0;
text-align:center;
position:relative;
z-index:10;
}


.event-summary{
padding: 40px 20px 0;
position:relative;
z-index:10;
}


.event-summary p {
font-size: 16px;
line-height: 1.8;
position:relative;
z-index:10;
}



.event-overview{
/*background: #f8f8f8;*/
margin:0 auto;
padding:25px 0 0;
}


dl.information {
font-size:1rem;
margin:0 auto;
padding:15px 0;
display:flex;
flex-wrap: wrap;
justify-content:space-between;
}

dl.information dt {
width:26%;
color:#202124;
padding:10px;
font-weight:normal;
background:#e8e8e8;
}

dl.information dd {
width:72%;
margin:0 0 10px 10px;
padding:10px;
line-height:1.6;
color:#202124;
background:#f5f5f5;
}



/* 見出し ******************************************************************************/


h2 {
text-align:left;
margin:0 auto 45px;
padding:15px 0;
font-size: 1.75rem;
font-weight:normal;
border: none;
position: relative;
/*background:#afcbfa;*/
/*background:#669df6;*/
background:#fff;
color:#202124;
border-bottom:10px solid #669df6;
z-index:10;
}





/* 講演内容 ******************************************************************************/



.event-session{
padding:0 0 45px;
position:relative;
}


.session-program{
margin:45px auto;
padding:0;
position:relative;
z-index:10;
}

.session-program .session-total-time{
padding:5px;
font-size:2rem;
color:#4285f4;
width:fit-content;
position:relative;
}



.session-program table{
margin:30px auto;
/*background-color:#fff;
border:1px solid #e5e5e5;*/
position:relative;
z-index:10;
}


.session-program th,
.session-program td {
vertical-align:top;
border:none !important;
margin:0 0 0 5%;
}

.session-program th {
  width: 5%;
  padding:20px;
  text-align: center;
  background: #f8f8f8;
}

.session-program .session-head{
display:flex;
align-items:center;
}

.session-program .session-time{
font-size:1.5rem;
color:#4285f4;
position:relative;
}

.session-program .session-label{
width:fit-content;
margin:0 10px 0 0;
padding:5px 10px;
font-size:14px;
text-align:center;
background-color:#4285f4;
color:#fff;
}


.session-program td.session {
background-color:#f8f8f8;
padding: 50px;
border-radius:30px;
line-height: 1.3 !important;
position: relative;
}


.session-program td.session .session-title {
padding: 30px 0;
line-height:1.4;
font-size: 1.75rem;
font-weight:bold;
font-feature-settings: "palt" 1;
}


.session-program td.session .session-sub-title {
padding: 40px 0 20px;
line-height:1.4;
font-size: 1.5rem;
font-weight:bold;
font-feature-settings: "palt" 1;
}


.session-program td.session .session-summary {
letter-spacing: 0;
font-size:1rem;
line-height:1.6;
}

.session-program td.session .session-profile{
padding-top:50px;
}

.session-program td.session .session-profile .profile_thumb {
margin: 0 20px 0 0;
width:150px;
height:150px;
float:left;
}

.session-program td.session .session-profile .profile_thumb img{
display:block;
border-radius:20px;
}

.session-program td.session .session-profile .profile_name {
line-height: 1.5;
font-size:1.15rem;
}

.session-program td.session .session-profile .profile_name span{
font-size:100%;
font-weight: bold;
padding-top:4px;
display:block;
}

.session-program td.session .session-profile .profile_accordion {
margin: 3px 0 0 170px;
line-height: 1.6;
}

.session-program td.session .session-profile .js-profile-trigger {
position: relative;
display: inline-block;
font-size:13px;
font-weight:normal;
padding:0 15px;
background:#afcbfa;
border-radius:20px;
color: #fff;
cursor: pointer;
width:fit-content;
font-feature-settings:"palt";
}


.session-program td.session .session-profile .js-profile-detail{
font-size:14px;
margin:10px 0 0 0;
}






/* 申し込み ******************************************************************************/


.event-entry{
position:relative;
}


.privacy-note {
margin:0 0 45px 0;
padding: 30px;
border:1px solid #e5e5e5;
color:#444;
font-size: 12px;
text-align:left;
position:relative;
z-index:10;
}

.privacy-note p{
margin:0 0 5px 0;
}

.privacy-note p a{
color:#1a73e8;
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:30px auto;
padding: 15px;
font-weight: bold;
font-size: 20px;
line-height: 20px;
/*background:#1a73e8;*/
background:#4285f4;
color: #fff !important;
text-align: center;
border-radius: 50px;
cursor: pointer;
position:relative;
z-index:100;
}

.btn:hover{
background:#F5FAFE;
color: #4285f4 !important;
transition:0.3s;
}




.btn::before,
.btn::after {
	position: absolute;
	z-index: -1;
	display: block;
	content: '';
}
.btn,
.btn::before,
.btn::after {
	box-sizing: border-box;
	transition: all .3s;
}


.btn span{
display: flex;
align-items: center;
justify-content: center;
height: 100%;
font-weight:bold;
}



/*btn size setting*/

.large{
width: 80%;
height: 60px;
}

.small{
width: 30%;
height: 80px;
}




/* sponsor logo ******************************************************************************/


.event-sponsor {
padding: 0;
background-color: #fff;
position:relative;
z-index:10;
}

.event-sponsor h3 {
margin: 0 auto;
text-align: center;
color: #151515;
padding-bottom:5px;
font-size: 1.5rem;
font-weight:normal;
width:fit-content;
}

.event-sponsor ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
margin:0;
}
.event-sponsor li {
  /*width: 100%;*/
  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:center;
padding-bottom:45px;
}

.event-inquiry p{
position:relative;
z-index:10 !important;
margin:70px 0 0 0;
color:#444;
}

.event-inquiry p a{
color:#4182ed;
font-weight:bold;
}

footer{margin-top:0;}





/* responsive 
------------------------------------------------------------------------------- */



@media (max-width: 960px) {


.container-fluid{
padding:0 15px;
}



.event-header .header-visual img{
max-width:350px;
}

.event-header .ttl-headline {
margin:0;
font-size:1.25rem;
}

.event-header h1{
font-size:1.5rem;
}


.info-date {
font-size:1rem;
}


dl.information{
font-size:1rem;
}


h2 {
font-size: 1.5rem;
}


.large, .small{
width:70% !important;
margin:30px auto;
}



.sponsor li {
  width: 100%;
  margin-bottom: 24px;
}



.session-program .session-total-time{
font-size:1.5rem;
}


.session-program .session-time{
font-size:1.25rem;
}

.session-program td.session .session-title{
font-size:1.5rem;
}

.session-program td.session .session-sub-title {
font-size:1.25rem;
}


}



@media (max-width: 640px) {


.container-fluid {margin: 0;}


.event-header{
display:block;
margin:0 auto;
padding:15px;
height:auto;
text-align:center;
}

.event-header .header-inner{
margin:0 auto;
padding:20px 0 0;
}

.event-header h1{
font-size: 1.5rem;
}

.event-header .header-visual img{
padding-right:0;
}



.info-date {
font-size:1rem;
margin:15px auto;
}
.info-date span{
display:block;
}


.event-summary{
padding:15px;
}

.event-summary p{
padding:0;
}


dl.information{
padding:0;
}


h2{
font-size:1.5rem;
}

.information dt {
    clear: both;
    width: auto;
    float: none;
    font-size: .85rem;
    margin: 0 0 10px;
    width: auto;
}

.information dd {
margin: 0 0 10px 0 !important;
font-size: .875rem;
width: auto;
}


.session-program td.session{
padding:25px;
}


.session-program td.session .session-title{
font-size:1.25rem;
}

.session-program td.session .session-sub-title{
font-size:1rem;
}


.session-program td.session .session-label,
.session-program td.session .session-profile .profile_name,
.session-program td.session .session-profile .js-profile_detail {font-size: 0.85rem; line-height: 1.5;}

.session-program td.session .session_profile {font-size: 12px;}


.session-program td.session .session-profile .profile_thumb{
width:100px;
height:100px;
}

.session-program td.session .session-profile .profile_accordion{
margin:3px 0 0 120px;
}



.large, .small{
width:95% !important;
margin:30px auto;
}



}








/*************** login & video page ***************/



/*.event-header.webinar-header{
  height: 250px;
}*/


.event-header.webinar-header .header-visual img{
max-width:250px;
}


.event-header.webinar-header h1{
  font-size: 1.5rem;
}

.event-header.webinar-header .ttl-headline {
  font-size: 1.25rem;
}






.video_block{
position:relative;
}



.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:#e55844;
font-weight:bold;
}


.enq-text{
padding:20px 10px;
}


.support{
text-align:center;
padding:40px 0 0 0;
}






/* ヘッダー＆フッター広告表記 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;
}


}

