/*@import url('https://fonts.googleapis.com/css2?family=Abel&display=swap');*/
/*@import url('https://fonts.googleapis.com/css2?family=Alatsi&display=swap');*/


@import url('https://fonts.googleapis.com/css2?family=Alata&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: "Alata", 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{
position:relative;
width:100%;
}


.container::before{
content:"";
position:absolute;
bottom:0;
left:0;
width:100%;
height:100%;
background: #EDFFF6;
background: linear-gradient(90deg,rgba(220, 249, 235, 1) 0%, rgba(255, 255, 255, 1) 100%);
/*background: #F0F0F0;
background: linear-gradient(90deg,rgba(240, 240, 240, 1) 0%, rgba(255, 255, 255, 1) 100%);*/
z-index:-1;
}


/*.container::after{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
background:url(/info/event/aiagent/202507/media/img_head_background.png) center top no-repeat;
background-size:cover;
z-index:1;
}*/


.container-fluid {
max-width: 1000px;
margin: 0 auto;
background:transparent;
}

.container-fluid a{
color:#f4593f;
}

#social_bkm_wrap_top {
margin-bottom: 0;
height: auto;
border: none;
}

.notice{
text-align:center;
}


/* parallax */


.fixed-bg {
position: fixed;
top:0;
right:-3%;
width: 100%;
height: 100vh;
background: url(/info/event/aiagent/202507/media/img_kv_background.png) right 0 no-repeat;
transition: background-position 0.3s linear; /* スムーズな動き */
}






/* header ******************************************************************************/


.event-header{
width:100%;
padding:0;
position:relative;
}

.event-header::before{
content:"";
position:fixed;
top:0;
left:0;
width:100%;
height:100%;
background:url(/info/event/aiagent/202507/media/img_head_background.png) left top no-repeat;
z-index:-1;
}

.event-header .header-inner{
max-width:1300px;
color:#000;
display:flex;
flex-direction:column;
justify-content:center;
/*align-items:center;*/
margin: 0 auto;
padding:3% 15px;
position:relative;
z-index:10;
}


.event-header .ttl-headline{
font-size:clamp(2rem, 5vw, 5rem);
font-family: "Alata", sans-serif !important;
margin:0;
padding:0;
width:fit-content;
line-height:1.2;
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: "Alata", Arial, "游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
line-height:1.5;
text-align:left;
width:fit-content;
margin:20px 0;
}


.event-header .ttl-main span.number{
display:block;
background-color:#00967c;
color:#fff;
font-size:2.5rem;
width:fit-content;
margin:0 15px 0 0;
padding:10px 20px;
}


.event-header .info-date {
margin:10px 0 30px;
padding:10px 25px;
font-size:clamp(1rem, 0.5rem + 1.25vw, 1.75rem);
font-family: "Alata", Arial, "游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
line-height:1.4;
text-align:left;
width:fit-content;
position:relative;
z-index:1000;
}

.event-header .info-date::before{
content:"";
position:absolute;
top:0;
left:0;
background-color:#baf4d9;
width:0;
height:100%;
transform:skew(-15deg);
z-index:-1;
animation: line 0.5s ease-out 0.7s forwards;
}


.event-header .info-date span{
font-size:160%;
}


@keyframes line{
0%{
width:0;
}
100%{
width:100%;
}
}

.event-summary{
width:100%;
margin:0 auto;
padding:25px 15px;
position:relative;
background:rgba(255,255,255,0.7);
backdrop-filter: blur(6px);
/*box-shadow:0 10px 10px -5px #a5a5a5;*/
z-index:10;
}

.event-summary p {
max-width:750px;
font-size: 1.15rem;
font-weight:bold;
line-height: 1.8;
margin:0 auto;
padding: 5px;
color:#151515;
font-family:"游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
position:relative;
z-index:10;
}




/* 開催概要 ******************************************************************************/


.event-outline{
position:relative;
/*background: rgba(255, 255, 255, 1);*/
/*backdrop-filter:blur(5px);*/
/*background:#fff url(/info/event/aiagent/202507/media/img_parts_background.png) left top no-repeat;*/
}

.event-outline::before{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
background:#fff url(/info/event/aiagent/202507/media/img_parts_background.png) left top no-repeat;
}



table.information {
margin:25px auto 0;
padding:25px;
border: 1px solid #e0e0e0;
font-size: 16px;
/*box-shadow:0 15px 15px -10px #505050;*/
transform:translateY(80px);
opacity:0;
transition:0.5s ease;
position:relative;
z-index:100;
}

table.information th,
table.information td{
text-align:left;
background-color:#fff;
border: 1px solid #e0e0e0;
padding:15px;
font-weight:normal;
position:relative;
z-index:10;
}

table.information th.last,
table.information td.last{
border-bottom:none !important;
}


table.information th{
padding:0 15px;
width:25%;
position:relative;
}


table.information td{
padding:15px;
border-right:none !important;
}


.event-outline .notice{
text-align:center;
font-size:16px;
margin:20px auto;
color:#151515;
position:relative;
z-index:1000;
}

.event-outline table.fade-in{
transform:translateY(0);
opacity:1;
}



/* 見出し ******************************************************************************/


h2 {
padding:15px 0;
color:#333;
font-weight: normal;
font-size:5rem;
border: none;
background: none;
font-feature-settings: "palt" 1;
position: relative;
z-index:5;
}

h2::before{
content:"";
position:absolute;
bottom:10px;
left:0;
width:100%;
height:1px;
background-color:#666;
}


h2 span{
font-family: 'Alata', Arial, "游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
font-size: 1.25rem;
margin:0;
padding:10px 0;
color:#666;
display:block;
position:relative;
}

h2::first-letter{
color:#1b2758;
}

h2.inquiry::before{
display:none;
}



/* 講演内容 ******************************************************************************/


/*区切り*/
.custom-shape-divider-top-1747704658 {
    position: absolute;
    /*top: 0;*/
    left: 0;
    width: 100%;
    overflow: hidden;
    line-height: 0;
}

.custom-shape-divider-top-1747704658 svg {
    position: relative;
    display: block;
    width: calc(300% + 1.3px);
    height: 100px;
z-index:1000;
}

.custom-shape-divider-top-1747704658 .shape-fill {
    fill: #FFFFFF;
}
/*区切り*/


.event-session{
padding:40px 0 45px 0;
/*background:rgba(255,255,255,1);*/
backdrop-filter:blur(8px);
position:relative;
}




.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:20px auto;
padding:0;
position:relative;
z-index:10;
}


.session-program table{
margin:5% auto;
box-shadow:0 0 40px #a0a0a0;
position:relative;
transform:translateY(100px);
opacity:0;
transition:0.5s ease;
z-index:10;
}

.session-program table.fade-in{
transform:translateY(0);
opacity:1;
}


.session-program th,
.session-program td {
border:none !important;
color:#151515;
}


.session-program th {
width: 10%;
text-align: center;
font-weight:normal;
padding:0;
vertical-align:top;
background:none;
}

.session-program td {
padding:4%;
background-color:#fff;
position: relative;
line-height: 1.3 !important;
position:relative;
}


.session-program .session-time{
margin:0 auto;
padding:0;
text-align:center;
/*border-radius:50%;*/
font-size:2rem;
position:relative;
}



.session-program .session-label{
background-color:#0e1d8d;
color:#fff;
font-size:0.85rem;
margin:10px auto;
padding:3px 60px;
text-align:center;
width:fit-content;
}
.session-label.keynote{background-color:#ef6133; color:#fff;}
.session-label.special{background-color:#0e1d8d; color:#fff;}


.session-program td.session .session-title {
margin: 25px 0;
padding: 0 0 10px 0;
border-bottom:1px dotted #fff;
font-size:2rem;
/*font-weight:bold;*/
line-height:1.5;
font-feature-settings: "palt" 1;
}


.session-program td .session-title span {
display: block;
font-size: 80%;
}


.session-program td.session .session-summary {
letter-spacing: 0;
font-size:1rem;
padding-bottom:25px;
line-height:1.6;
}

.session-program td.session .session_profile {
margin:0;
padding: 25px 0;
clear: both;
font-size:1.25rem;
display:flex;
flex-shrink: 0;
overflow: hidden;
}


.session-program td.session .host-label,
.session-program td.session .guest-label,
.session-program td.session .listener-label,
.session-program td.session .speaker-label{/*司会・ゲスト・聞き手・話し手*/
width: fit-content;
margin:0 0 10px;
padding: 5px 20px;
background-color: #fff;
border:1px solid #999;
color:#151515;
text-align: center;
font-size:13px;
font-weight:normal;
line-height: 1;
display:block;
}


.session-program td.session .profile_thumb {
margin: 0 35px 4px 0;
flex-shrink: 0;
position:relative;
z-index:1;
}
.session-program td.session .profile_thumb::before{
content:"";
position:absolute;
top:15px;
right:-15px;
width:250px;
height:250px;
background-color:#dcf9eb;
transform:rotate(5deg);
z-index:-1;
}


.session-program td.session .profile_thumb img{
/*border-radius:15px;*/
display:block;
}

.session-program td.session .profile_name {
margin:3% 0 0 0;
line-height: 1.5;
font-size:1rem;
}

.session-program td.session .profile_name strong{
font-size:130%;
font-weight: normal;
padding-top:4px;
display:block;
}

.session-program td.session .profile_name .profile_accordion {
margin: 0;
line-height: 1.6;
}

.session-program td.session .profile_name .profile-event {
position: relative;
display: inline-block;
font-size:1rem;
font-weight:normal;
margin:15px 0 0 0;
padding:0;
color: #151515;
border-radius:10px;
cursor: pointer;
width:fit-content;
font-feature-settings:"palt";
}
.session-program td.session .profile_name .profile-event:hover{
color: #999;
transition:0.3s;
}

.session-program td.session .profile_name .profile-event::before,
.session-program td.session .profile_name .profile-event::after{
    content: '';
    display: inline-block;
    position: absolute;
    top:5px;
    right:-15px;
    width: 1px;
    height: 15px;
    background-color: #151515;
}
.session-program td.session .profile_name .profile-event::after{
    transform: rotate(90deg);
}

.session-program td.session .profile_name .profile-event:hover::before,
.session-program td.session .profile_name .profile-event:hover::after{
    background-color: #999;
    transition:0.3s;
}

.session-program td.session .profile_name .on-detail::before{
display:none;
}
.session-program td.session .profile_name .on-detail::after{
    content: '';
    display: inline-block;
    position: absolute;
    width: 1px;
    height: 15px;
    background-color: #151515;
    transform: rotate(90deg);
}
.session-program td.session .profile_name .on-detial:hover::after{
    background-color: #999;
    transition:0.3s;
}


.session-program td.session .profile_name .profile-detail {
padding-top: 10px;
font-size:0.9rem;
font-weight:normal;
line-height:1.6;
color:#505050;
display:block;
position:realative;
}




.session-program td.session .profile_name .on-detail {

}


.event-session .notice{
text-align:center;
font-size:13px;
position:relative;
z-index:1000;
}





/* 申し込み ******************************************************************************/


/* 参加特典 */

.benefits-area{
color:#151515;
/*border:1px solid #151515;*/
margin:5% auto;
padding:45px 30px 20px;
max-width:1000px;
/*background-color:#fffbd8;*/
background-color:#fff;
border:10px solid #ff6d1d;
box-shadow:0 0 40px #a0a0a0;
box-sizing:border-box;
position:relative;
z-index:1000;
}

.benefits-area::before{
content:"参加特典";
position:absolute;
top:-50px;
left:calc(50% - 150px);
width:300px;
height:auto;
padding:15px 10px;
background-color:#ff6d1d;
clip-path: polygon(10% 0%, 100% 0%, 90% 100%, 0% 100%);
color:#fff;
text-align:center;
font-size:1.5rem;
font-weight:bold;
}


.benefits-area p{
margin:25px 15px;
font-size:0.9rem;
}

.benefits-area p strong{
/*color:#ff9813;*/
color:#ff6d1d;
}

.benefits-area p a{
color:#2247cf;
font-weight:bold;
}



.event-entry{
position:relative;
background: #8CE8B2;
background: linear-gradient(90deg,rgba(220, 249, 235, 0.8) 0%, rgba(140, 232, 178, 0.8) 100%);
backdrop-filter:blur(8px);
}


.event-entry::before{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
background:url(/info/event/aiagent/202507/media/img_parts_background.png) left top no-repeat;
}


.privacy-note {
margin:0 auto 45px;
padding: 30px;
background-color:#fff;
/*border:1px solid #151515;*/
color:#151515;
font-size: 12px;
text-align:left;
max-width:950px;
position:relative;
z-index:10;
}

.privacy-note p a{
color:#2247cf;
font-weight:bold;
}




/*btn default setting*/



.btn-register {
width: 100%;
margin: 0 auto;
padding:25px 0;
text-align:center;
position:relative;
z-index:10;
}

.btn-register-head{
width:fit-content;
}


.btn {
display: inline-block;
box-sizing: border-box;
margin:30px auto;
padding: 15px;
font-weight: bold;
line-height: 20px;
background-color:#2247cf;
color: #fff !important;
text-align: center;
cursor: pointer;
border-radius:50px;
position:relative;
z-index:100;
}

.btn:hover{
background-color:#1b2758;
color: #fff !important;
transform:translateY(-5px);
box-shadow:0 25px 25px -15px #a5a5a5;
}


.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-size:1.25rem;
margin:0 auto;
width:fit-content;
position:relative;
}

/*.btn span::after{
content:"";
position:absolute;
bottom: 5px;
left:0;
width: 100%;
height: 1px;
background-color:#fff;
transform: scale(0, 1);
transition:0.3s; 
}

.btn span:hover::after{
transform: scale(1, 1);
}*/


.btn-style{
width: 50%;
height: 90px;
}
.btn-register-head .btn-style{
width: 100%;
height: 50px;
margin:10px 0;
padding:0 30px;
}



/* sponsor logo ******************************************************************************/


.event-sponsor {
margin:0 auto;
padding:0 0 5% 0;
background:rgba(255,255,255,0.9);
position:relative;
z-index:10;
}

.event-sponsor h3 {
margin: 20px auto;
padding:10px 5px;
text-align: center;
color: #151515; 
border-top:1px solid #151515;
border-bottom:1px solid #151515;
font-size: 1.25rem;
font-weight:normal;
width:fit-content;
}

.event-sponsor ul {
display: flex;
flex-wrap: wrap;
justify-content: center;
margin:0 auto;
}

.event-sponsor li {
width: 24%;
text-align: center;
display: flex;
align-items: center;
justify-content: center;
background-color:#fff;
box-shadow:0 0 20px #d5d5d5;
margin:25px 15px;
padding:0 20px;
}

.event-sponsor li a{
display:block;
}


.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;
background:rgba(186,244,217,0.6);
color:#fff;
position:relative;
}


.event-inquiry p{
margin:10px 0 0 0;
color:#151515;
position:relative;
z-index:10 !important;
}

.event-inquiry p a{
color:#2247cf;
font-weight:bold;
}

footer{
margin-top:0;
position:relative;
z-index:10;
}





/* report add 202509 ******************************************************************************/


.event-report{
max-width:1100px;
margin:0 auto 5%;
padding:20px;
position:relative;
z-index:10;
}

.event-report::before{
content:"";
position:absolute;
top:0;
left:0;
background:rgba(255,255,255,0.7);
backdrop-filter: blur(7px);
box-shadow:0 0 20px #a0a0a0;
width:100%;
height:100%;
z-index:1;
}


.event-report p {
margin:0 auto;
font-size: 1rem;
font-weight:bold;
line-height: 1.8;
padding: 5px;
color:#151515;
font-family:"游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
position:relative;
z-index:10;
}

.event-report p span{
color:#f91419;
}


.event-report p.graph{
display:flex;
flex-wrap:wrap;
justify-content:space-between;
}

.event-report p.graph img{
margin-bottom:20px;
}








/* responsive 
------------------------------------------------------------------------------- */



@media (max-width: 960px) {


.container-fluid {padding: 0 3%;}


.fixed-bg {
background-size:70%;
}

.event-header .header-inner{
padding:5%;
}

.event-summary p{
font-size:1rem;
}


h2 {
font-size: 3.5rem;
}



.event-session{
padding:15px 0 45px;
}


.session-program .session-time{
padding:0 20px;
}

.session-program td {
padding:4%;
}



.btn-style{
width:80%;
}


.event-report p.graph img{
text-align:center;
margin:0 auto;
}




}



@media (max-width: 640px) {


.container-fluid {margin: 0;}


.event-header .header-inner{
padding:25px 10px;
}


.event-header .ttl-headline{
font-size:2.5rem;
}

.event-summary{
margin:25px 0;
}

.event-summary p{
padding:0;
}

h2 span:nth-child(2){
font-size:1rem;
}


table.information{
margin:10px;
width:auto;
}

table.information th,
table.information td{
width:100%;
display:block;
padding:10px;
border:none;
}

table.information th{
width:100%;
background-color:#dcf9eb;
}


.btn-register{
padding:0 10px;
}

.btn span{
font-size:1rem;
}


.session-program{
margin:0 auto;
}

.session-program table{
margin:10% 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 .session-time{
font-size:1.25rem;
margin:10px auto;
padding:5px 0;
}

.session-program td.session .session-title{
font-size:1.25rem;
/*border-bottom:1px solid #ccc;*/
}



.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 .session_profile{
padding:25px 0;
display:block;
}

.session-program .session-label{
width:100%;
}

.session-program td.session .profile_thumb{
margin:0 auto;
}
.session-program td.session .profile_thumb::before{
display:none;
}

.session-program td.session .profile_thumb img{
margin:0 auto 15px;
}

.event-sponsor ul {
display:block;
}

.event-sponsor li{
width:80%;
margin:20px auto;
}



.benefits-area{
margin:20% 0 0;
padding:25px 0;
}
.benefits-area::before{
font-size:1.25rem;
}






}



/*************** login page & video page ***************/

.event-header.webinar-header{
padding:2% 0;
}

.event-header.webinar-header .header-inner{
position:relative;
padding:10px 20px;
}


.event-header.webinar-header .ttl-headline {
  font-size: 3rem;
}

.event-header.webinar-header h1,
.event-header.webinar-header .ttl-main span.number{
  font-size: 1.25rem;
}

.event-summary.webinar-summary p{
font-size:0.95rem;
}

.event-entry.webiner-block{
padding:0;
}




.video_block{
position:relative;
background:rgba(255,255,255,0.7);
backdrop-filter:blur(8px);
}


.video {
  width:100%; 
  margin: 40px auto 20px;
}
.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:#2247cf;
font-weight:bold;
}


.enq-text{
padding:20px 10px;
font-size:1.15rem;
font-weight:bold;
}

.support{
text-align:center;
padding:20px 0;
}


.closed-text{
color: #151515;
font-weight: bold;
text-align:center;
padding: 40px 0;
text-align:center;
position:relative;
z-index:10;
}





@media (max-width: 640px) {


.enq-text{
padding:20px 10px;
font-size:1rem;
}

.event-header.webinar-header .header-inner{
padding:10px;
}
.event-header.webinar-header .ttl-headline {
  font-size: 2rem;
text-shadow:
    2px 2px 0 #fff,
    -2px 2px 0 #fff,
    -2px -2px 0 #fff,
    2px -2px 0 #fff;
}

.event-header.webinar-header h1{
  margin:15px 0;
text-shadow:
    2px 2px 0 #fff,
    -2px 2px 0 #fff,
    -2px -2px 0 #fff,
    2px -2px 0 #fff;
}

.event-header.webinar-header h1,
.event-header.webinar-header .ttl-main span.number{
  font-size: 1rem;
}


}









/* ヘッダー＆フッター広告表記 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;
}


}

