@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@100..900&display=swap');


/* base ******************************************************************************/

header,
footer{
    font-family: Arial, "游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
}


body {
    position: relative;
    word-wrap: break-word;
    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    color: #252525;
    font-family: 'Outfit', "Noto Sans JP", Arial, "游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    font-style: normal;
    font-size: 16px;
    line-height: 1.8;
    overflow-wrap: break-word;
    background-color:#fff;
}

.container{
position:relative;
width:100%;
/*background-color:#102a43;*/
color:#151515;
}


.container::before{
content:"";
position:fixed;
top:0;
left:0;
background:linear-gradient(90deg,rgba(12, 40, 109, 0.3) 0%, rgba(101, 17, 135, 0.85) 100%) , url(/info/event/macnica_thales/202512/media/img_main_bg.png) left top no-repeat;
background-size:cover;
width:100%;
height:100%;
z-index:-1;
}



.container-fluid {
max-width: 1050px;
margin: 0 auto;
padding:0 !important;
background:transparent;
}

.container-fluid a{
color:#577bff;
font-weight:bold;
text-decoration:underline;
}

.container-fluid a:hover{
text-decoration:none;
}

#social_bkm_wrap_top {
margin-bottom: 0;
height: auto;
border: none;
}

.notice{
text-align:center;
margin:10px auto;
color:#fff;
position:relative;
z-index:100;
}



/* header ******************************************************************************/


.event-header{
width:100%;
padding:0 5%;
color:#fff;
overflow:hidden;
position:relative;
}

.event-header .header-inner{
width:auto;
/*height:600px;*/
display:flex;
flex-direction:column;
justify-content:center;
text-align:center;
margin: 0 auto;
padding:5% 10px;
position:relative;
z-index:10;
}

.event-header .ttl-headline {
display:flex;
flex-direction:column;
font-size:clamp(1.8rem, 2.5vw, 2.5rem);
font-family: 'Outfit', sans-serif;
font-weight:bold;
line-height:1.3;
text-shadow:0 0 10px #151515;
}


.event-header h1{
display:flex;
flex-direction:column;
font-size:clamp(1.8rem, 2.7vw, 2.7rem);
/* font-size:clamp(2rem, 0.333rem + 1.67vw, 5rem); */
line-height:1.5;
position: relative;
z-index:100;
}



.event-header h1 span {
width: fit-content;
margin: 16px auto;
padding: 8px 16px;
color: #fff;
background-color: rgba(0, 0, 0, 0.3);
box-shadow: 0px 20px 20px -10px #000;
backdrop-filter: blur(8px);
}

.event-header h1 small{
font-size:70%;
}

.event-header h1 small span{
color:#0074aa;
font-size:120%;
}

.event-header .info-date {
margin:3% auto 0;
padding:10px 0 0;
font-size:clamp(1rem, 0.333rem + 1.67vw, 2rem);
font-family: 'Outfit', sans-serif;
text-align:center;
width:fit-content;
background:linear-gradient(transparent 75%, #48e75e 75%);
position:relative;
z-index:1000;
}


.event-header .info-date span{
padding:0 5px;
width:fit-content;
line-height:1.3;
text-shadow:0 0 8px #151515;
display:block;
position:relative;
z-index:1;
}

.event-header .info-date strong{
font-size:180%;
font-weight:normal;
}

.event-header .info-date img{
vertical-align: middle;
margin-right:5px;
}

@keyframes line{
0%{
opacity:0;
width:0;
}
100%{
opacity:1;
width:100%;
}
}


.event-summary{
width:100%;
margin:0 auto 40px;
padding:20px 15px;
background:rgba(0,0,0,0.6);
/*background-color:#2ec4b6;*/
position:relative;
z-index:10;
}

.event-summary p {
max-width:750px;
font-size: 1.125rem;
font-weight:bold;
line-height: 1.8;
margin:0 auto;
padding:25px;

color:#fff;
position:relative;
z-index:10;
}




/* 開催概要 ******************************************************************************/


.event-outline{
position:relative;
/*background-color:#102a43;*/
}


.information {
margin:20px auto;
padding:30px 0 20px;

position:relative;
z-index:100;
}


.information dl{
font-size:1rem;
display:flex;
flex-wrap:wrap;
justify-content:space-between;
}

.information dt,
.information dd{
text-align:left;
background-color:#fff;
padding:15px;
color:#151515;
margin:0 5px 10px;
font-weight:bold;
}


.information dt{
width:23%;
position:relative;
}

.information dd{
width:75%;
margin:0 0 10px 0 !important;
padding:15px;
}



.event-outline .notice{
text-align:center;
font-size:0.9rem;
margin:0 auto 40px;
position:relative;
z-index:1000;
}

.event-outline table.fade-in{
transform:translateY(0);
opacity:1;
}



/* 見出し ******************************************************************************/


h2 {
margin:0 auto;
padding:15px 0;
text-align:center;
font-size:clamp(1.5rem, 0.833rem + 1.67vw, 2.5rem);
border: none;
background: none;
font-feature-settings: "palt" 1;
color:#fff;
max-width:1000px;
line-height:1;
font-weight:bold;
position: relative;
z-index:5;
}

h2 span{
font-weight:normal;
font-family: 'Outfit', sans-serif;
font-size:80%;
color:#577bff;
margin-top:10px;
display:block;
position:relative;
}



/* 講演内容 ******************************************************************************/


.event-session{
padding:45px 0;
position:relative;
}

/*.event-session::before{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
background:rgba(0,0,0,0.6);
z-index:1;
}*/


.session-program{
margin:20px auto;
padding:0;
position:relative;
z-index:10;
}


.session-program table{
margin:5% auto;
background-color:rgba(0,0,0,0.4);
box-shadow: 0px 20px 20px -10px #000;
backdrop-filter: blur(8px);
position:relative;
z-index:10;
}

.session-program th,
.session-program td {
border:none !important;
/*background-color:#fff;*/
color:#fff;
}


.session-program th {
width: 10%;
text-align: center;
font-weight:normal;
padding:0;
vertical-align:top;
background:none;
}

.session-program td {
padding:2% 5% 5%;
position: relative;
line-height: 1.6 !important;
border-radius:20px;
position:relative;
}

.session-program .session-number{
font-size:2rem;
font-family: 'Outfit', sans-serif;
/*border-bottom:4px solid #fff;*/
margin:0 auto;
padding:10px 0;
text-align:center;
line-height:1;
width:fit-content;
position:relative;
}

.session-program .session-number::before{
content:"";
position:absolute;
top:-20px;
left:calc(50% - 1px);
width:1px;
height:15px;
background-color:#fff;
z-index:10;
}

.session-program .session-number::after{
content:"";
position:absolute;
bottom:-20px;
left:calc(50% - 1px);
width:1px;
height:15px;
background-color:#fff;
z-index:10;
}

.session-program .session-time{
margin:4% auto 0;
padding:0;
text-align:center;
font-size:1.25rem;
position:relative;
}

.session-program .session-label{
background-color:#577bff;
color:#fff;
font-size:0.9rem;
margin:10px auto;
padding:5px 20px;
width:fit-content;
}
.session-label.keynote{background-color:#48e75e; color:#151515;}
.session-label.special{background-color:#099586; color:#fff;}


.session-program td.session .session-title{
margin: 25px 0;
padding: 0;
/*background:rgba(46,196,182,0.6);*/
/*border-bottom:1px dotted #999;*/
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 {
font-size:1rem;
margin:0;
padding:0 0 15px 0; 
}

.session-program td.session .session_profile {
margin:0;
padding: 20px 0;
clear: both;
font-size:1.25rem;
display:flex;
flex-shrink: 0;
overflow: hidden;
}


.session-program td.session .profile_thumb {
margin: 0 30px 4px 10px;
flex-shrink: 0;
position:relative;
z-index:1;
}


.session-program td.session .profile_thumb img{
/*box-shadow:0 0 10px #999;*/
width:180px;
border-radius:10px;
display:block;
}

.session-program td.session .profile_name {
margin:0;
line-height: 1.5;
font-size:1rem;
}

.session-program td.session .profile_name strong{
font-size:150%;
font-weight: normal;
padding-top:4px;
display:block;
}

.session-program td.session .profile_name .profile_accordion {
margin: 0;
}

.session-program td.session .profile_name .js-profile-trigger {
position: relative;
display: inline-block;
font-size:0.85rem;
font-weight:normal;
background-color:#fff;
color:#151515;
margin:10px 0 0 0;
border-radius:5px;
padding:2px 15px;
cursor: pointer;
width:fit-content;
font-feature-settings:"palt";
}
.session-program td.session .profile_name .js-profile-trigger:hover{
background-color:#f991ff;
color:#151515;
transition:0.3s;
}

.session-program td.session .profile_name .js-profile-detail {
padding-top: 10px;
font-size:0.85rem;
font-weight:normal;
color:#fff;
display:block;
position:realative;
}


.session-program td.session .listener{
background-color:#858585;
color:#fff;
font-size:12px;
margin:0 0 10px 0;
padding:2px 10px;
border-radius:15px;
width:fit-content;
display:block;
}



.event-session .notice{
text-align:center;
font-size:13px;
position:relative;
z-index:1000;
}





/* 申し込み ******************************************************************************/


/* 参加特典 */

.benefits-area{
background-color:#fff;
color:#151515;
margin:3% auto 40px;
padding:40px 20px 20px;
max-width:1100px;
box-sizing:border-box;
border-radius:25px;
max-width:1050px;
position:relative;
z-index:1000;
}

.benefits-area::before{
content:"参加特典";
position:absolute;
top:-25px;
left:0;
width:100%;
height:auto;
padding:20px 10px;
background-color:#48e75e;
color:#151515;
text-align:center;
font-size:1.25rem;
font-weight:bold;
border-radius:20px 20px 0 0;
}


.benefits-area p{
margin:25px 15px;
font-size:0.9rem;
}

.benefits-area p.center{
text-align:center;
color:#151515;
padding:10px;
}

.benefits-area p span{
color:#23c83b;
font-weight:bold;
}

.benefits-area a{
color:#577bff;
}



.event-entry{
position:relative;
padding:30px 0;
}

/*.event-entry::before{
content:"";
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
background: linear-gradient(to bottom right, #151515, #1b4f72);
z-index:1;
opacity:0.8;
}*/


.privacy-note {
margin:60px auto;
padding: 30px;
background-color:#f8f8f8;
color:#151515;
font-size: 12px;
text-align:left;
position:relative;
z-index:10;
}

.privacy-note p a{
font-weight:bold;
}




/*btn default setting*/


.btn-register {
width: 100%;
margin: 0 auto;
padding:0;
text-align:center;
position:relative;
z-index:10;
}

.btn-register-head{
width:fit-content;
margin:0;
}


.btn {
display: inline-block;
box-sizing: border-box;
margin:30px auto;
padding: 5px;
font-weight: bold;
line-height: 20px;
background-color:#f991ff;
text-align: center;
cursor: pointer;
color: #151515 !important;
transition:0.3s;
text-decoration:none;
position:relative;
z-index:100;
}

.btn-style{
text-decoration:none !important;
}


.btn:hover{
background-color:#651187;
color: #fff !important;
transform:translateY(-5px);
transition:0.5s;
box-shadow:0 10px 10px  -5px #000;
}


.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-style{
width:100%;
height: 70px;
display:block;
}
.btn-register-head .btn-style{
width: 100%;
height: 50px;
margin:10px auto;
padding:0 30px;
}

.btn-register-head .btn::after{
display:none;
}



/* sponsor logo ******************************************************************************/


.event-sponsor {
margin:0 auto;
padding:0 0 30px 0;
position:relative;
z-index:10;
}

.event-sponsor h3 {
margin: 45px auto 20px;
padding:10px 5px;
text-align: center;
color: #fff; 
border-top:1px solid #fff;
border-bottom:1px solid #fff;
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:auto;
background-color:#fff;
text-align: center;
display: flex;
align-items: center;
justify-content: center;
margin:25px 15px;
padding:15px;
border-radius: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;
margin:40px auto 0;
padding:25px 0;
background-color:#fff;
color:#151515;
position:relative;
z-index:10;
}
.event-inquiry h2{
color:#0c286d;
}

.event-inquiry p{
margin:10px 0 0 0;
padding:45px 0;
color:#151515;
position:relative;
z-index:10 !important;
}

.event-inquiry p a{
font-weight:bold;
}

footer{
margin-top:0;
position:relative;
z-index:10;
}





/* responsive 
------------------------------------------------------------------------------- */



@media (max-width: 960px) {


.container-fluid {padding: 0 3%;}



.container::before{
content:"";
position:fixed;
top:0;
left:0;
background:linear-gradient(90deg,rgba(12, 40, 109, 0.3) 0%, rgba(101, 17, 135, 0.8) 100%) , url(/info/event/macnica_thales/202512/media/img_main_bg.png) 30% top no-repeat;
background-size:cover;
width:100%;
height:100%;
z-index:-1;
}


.event-header{
padding:0 3%;
}

.event-header .header-inner{
height:400px;
}



.event-summary p{
font-size:1rem;
}


.event-session{
padding:15px 0 45px;
}


.session-program td {
padding:4%;
}




}



@media (max-width: 640px) {


.container-fluid{
margin:0 10px;
}

.event-header .header-inner{
padding:25px 0;
}

.event-summary{
margin:0 0 15px 0;
}

.event-summary p{
font-size:0.9rem;
}

.information{
padding:15px 0 10px;
}

.information dl{
display:block;
}

.container dt{
margin:0;
}


.information dt,
.information dd{
width:100%;
}



.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:25px;
}


.session-program .session-number,
.session-program .session-time{
font-size:1.25rem;
}


.session-program td.session .session-title{
font-size:1.5rem;
margin:10px auto;
/*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 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 5%;
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 0;
height:280px;
}

.event-header.webinar-header .ttl-headline{
  font-size: 4rem;
}
.event-header.webinar-header h1{
  font-size: 1.25rem;
}

.event-summary.webinar-summary p{
font-size:0.95rem;
}

.event-entry.webiner-block{
padding:0;
}

.video_block{
position:relative;
}


.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{
color:#fff;
position:relative;
z-index:100;
}


.video_block p a{
color:#00c6f7;
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: #fff;
font-size:1rem;
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 {

}

.event-header.webinar-header h1{
  margin:15px 0;
}

.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;
    font-family: Arial, "游ゴシック Medium", "Yu Gothic Medium", YuGothicM, 游ゴシック体, YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
    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;
}


}

