@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
*{
    padding:0px;
    margin:0px;
    box-sizing:border-box;
}
body {
    font-family: "Inter", sans-serif;
    font-optical-sizing: auto;
    font-weight: 400;
    font-style: normal;
    font-size: .8rem;
    line-height: 1.3;
    background-color: #fefefe;
    color: #000000;
    position: relative;
}

h1, h2, h3, h4, h5, h6{
    font-weight: 700;
    font-style: normal;
    font-optical-sizing: auto;
}
h1{
    font-size: 3.3rem;
    line-height: 1;
    margin-bottom: 0.5em;
    font-weight: 900;
    color: #1180c1;
    
}
h2{
    font-size: 2.8rem;
    line-height: 1;
    margin-bottom:1em;
    font-weight: 800;
    color: #1180c1;
}

a{
    color:inherit;
    text-decoration: none;
    transition: all 0.3s ease-in-out;
}
a:hover{
    color:#d9910c !important;
    text-decoration: none;
}

.readmore{
    display: inline-block;
    padding: 0.8em 1.5em;
    background: #FBAD18;
    color: #fff;
    border-radius: 30px;
    font-weight: 700;
    transition: all 0.3s ease-in-out;
}
.readmore:hover{
    background: #d9910c;
    color:#fff !important;
}

.aligncenter{
    text-align: center;
}


.hpattern{
    position: relative;
    width: fit-content;
    margin: 1em auto;
}
.hpattern::after{
    content: url(../images/horizontal_pattern.png);
    position: absolute;
    width: 200px;
    height: 100%;
    right: -5em;
}
.hpattern::before{
    content: url(../images/horizontal_pattern.png);
    position: absolute;
    width: 200px;
    height: 100%;
    left: -5em;
}

header, .container12, footer{
    display:block;
    width:100%;
    float:left;
    position:relative;
}
article{
    width:85%;
    margin:0 auto;
}
header{
    position:absolute;
    top:0px;
    left:0px;
    width:100%;
    z-index:10;
}
header .logo{
    background: #fff;
    width: 30em;
    height: 17vh;
}
header .logo img{
    width: 47%;
    object-fit: contain;
    margin: 1.3em 0 0px 8em;
}
header .navigation{
    width: 75%;
    left: 17em;
    top: 3em;
    position: absolute;
}

.side-menu {
  display: none;
} /* Hide checkbox */
.hamb {
  display: none;
} /* Hide hamburger icon */

header .navigation nav ul{
    display: flex;
    justify-content: end;
    list-style: none;
    gap:3em;
    padding: 0px;
    margin: 0px;
}
header .navigation nav ul li a{
    color:#fff;
}
header .navigation nav ul li:last-child a{
    background: #FBAD18;
    padding: 0.8em 1.8em;
    border-radius: 30px;
    color:#fff;
}
header .navigation nav ul li:last-child a:hover{
    background: #d9910c;
    color:#fff !important;
}

.banner{
    width:100%;
    overflow:hidden;
    margin-bottom: 3em;
}
.bannerimg{
    height:48vh;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    width: 110%;
    position:relative;
    background-blend-mode: multiply;
}
.banner .bannerimg .bannercap{
    position: absolute;
    bottom: 1em;
    color: #fff;
    left: 3em;
    font-size: 3em;
    font-weight: 700;
    line-height: 45px;
    text-shadow: 2px 2px 5px #000000eb;
}
.banner .bannerimg .bannercap h1{
    color:#fff;
    margin-bottom:0px;
}
.banner .bannerimg .bannercap p{
    font-size: 0.8em;
    color:#FBAD18;
}
.pattern{
    position: absolute;
    right: 3em;
    top: 3em;
    width: 40px;
}

.banner .bannerimg .bannercap .cursor {
display: inline-block;
font-weight: 300;
color: #fffefe;
animation: blink 0.7s steps(1) infinite;
}

@keyframes blink {
    50% {
    opacity: 0;
    }
}

.diagonal-right-edge{
    clip-path: polygon(0 0, 100% 0, 74% 100%, 0% 100%);
}

.about{
    margin-bottom:3em;
}
.about .intro{
    margin-bottom:3em;
}
.about .intro img.confimg{
    width: 100%;
    height: auto;
    object-fit: cover;
    margin-bottom:3em;
}
.about .intro .calbosdy{
    display: flex;
    gap:1em;
    width: 80%;
    margin: 0 auto;
}
.about .intro .calbosdy .calicon{
    width:6em;
}
.about .intro .calbosdy .calcont{
    font-weight:700;
    color:#1480C1;
    font-size: 14px;
}
.about .intro .calbosdy .calcont span{
    color:#119F8A;
}
.about .cont{
    padding:0px 0em 0 4em;
}
.addtocal{
    color:#1480C1;
    font-weight:700;
    font-size: 14px;
}


.sessions{
    margin-bottom:3em
}
.sessions .sessionbx{
    width: 100%;
    margin: 0 auto;
    background-color:#1480C1;
    color:#fff;
    display: flex;
}
.sessions .sessionbx h2{
    color:#fff;
}
.sessions .sessionbx .cont{
    padding: 0 4em;
    align-content: center;
    flex: 1;
    width: 44%;
    height: 69vh;
}
.sessions .sessionbx .cont ul{
    list-style: none;
    padding: 0px;
    margin: 0px;
}
.sessions .sessionbx .cont ul li{
    margin-bottom: 1em;
}
.sessions .sessionbx .sessionimg{
    width: 64%;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
}


.numbers{
    background-color: #FBAD18;
    padding:2em 0;
    margin-bottom: 3em;
}
.numbers .numbersboxes{
    display: flex;
    gap: 30px;
}
.numbers .numbersboxes .bx{
    flex: 1;
    width: 27%;
    padding: 2em;
    border-left:1px solid #000000;
}
.numbers .numbersboxes .bx:first-child{
    padding:0px;
    align-content: center;
    border:none;
}
.numbers .numbersboxes .bx h2{
    font-size: 58px;
    margin-bottom: 0px;
    line-height: 1;
}
.numbers .numbersboxes h2 span{
    color:#000000;
}
.numbers .numbersboxes .bx .num{
    font-weight:900;
    font-size:50px;
    color:#000000;
    letter-spacing: -2px;
}
.numbers .numbersboxes .bx .more{
    font-weight:900;
}


.speakers{
    margin-bottom:3em;
}
.speakers .speakersbx{
    display: flex;
    flex-wrap: wrap;
    margin-top:2em;
}
.speakers .speakersbx .speaker{
    width: 20%;
    position:relative;
}
.speakers .speakersbx .speaker .speakerimg{
    height: 15em;
    background-position: center;
    background-size: cover;
}
.speakers .speakersbx .speaker .speakerdesc{
    padding: 0 2em;
    background-color: #ebebeb8c;
    position:absolute;
    bottom:0px;
    width:100%;
    height:0;
    overflow: hidden;
    transition: height 0.5s ease, padding 0.5s ease;
}
.speakers .speakersbx .speaker .speakerdesc h4{
    font-size: 20px;
    margin-bottom: 6px;
}

.speakers .speakersbx .speaker .speakerimg:hover + .speakerdesc,
.speakers .speakersbx .speaker .speakerdesc:hover{
    height: 100%;
    padding: 2em;
    cursor: pointer;
}


.agenda{
    margin-bottom:3em;
}   
.agenda .progbar {
  margin-top: 3em;
}

.agenda .slots {
  display: flex;
  justify-content: center;
  border-bottom: solid 3px #fff;
  height: 5em;
  align-items: end;
}

.agenda .slots .slot {
    flex: auto;
    padding: 15px;
    background-color: #1480C1;
    color: #fff;
    font-size: 19px;
    font-weight: 700;
    transition: all 0.3s ease-in-out;
    border: solid 2px #fff;
    border-bottom: none;
    text-align: center;
    letter-spacing: -1px;
    width: inherit;
}

.agenda .dates .day span {
  font-weight: 300;
  font-size: 16px;
  letter-spacing: 4px;
}

.agenda .slots .slot:hover, .agenda .slots .selected {
  background-color:#119F8A;
  cursor: pointer;
  height: 4.4em;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  font-size: 19px;
  padding-top: 25px;
  border: solid 2px #fff;
  border-bottom: none;
}

.agenda .slots .slot:first-child {
  border-top-left-radius: 20px;
}

.agenda .slots .slot:last-child {
  border-top-right-radius: 20px;
}

.agenda .schedulecont {
  padding: 1em 0;
  display: none;
}

.agenda .schedulecont span {
  font-weight: 300;
  color: var(--deepblue);
}

.agenda .progcont {
  background-color:#faf8f859;
  padding: 2em;
  color:#2a2a2a;
}

.agenda .progcont .active {
  display: block;
}

.agenda .caltime {
  width: 100%;
  display: flex;
  border-bottom: dotted 1px #cbcbcb;
}

.agenda .caltime .time {
  width: 200px;
  padding: 15px 0 0 0;
  text-align: right;
  font-weight:600;
  letter-spacing: -1px;;
}

.agenda .caltime .break {
  margin: 0 2em;
  border-right: 1px solid #d3d3d3;
}

.agenda .caltime .cont {
  padding: 10px 20px;
  width: 70%;
}
.agenda .progcont h4 {
    color:#1480C1;
    font-size: 21px;
    font-weight:800;
    letter-spacing:0px;
}

.agenda .progcont h4 span{
    color:#119F8A;
    font-weight:800;
}
.agenda .progcont .hbreak h4{
    color:#FBAD18
}


.sponsors{
    margin-bottom:3em;
}
.sponsors .sponsorslist{
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 30px;
    margin-bottom: 3em;
}
.sponsors .sponsorbx {
  margin: 17px;
  text-align: center;
  width: auto;
}

.sponsors .sponsorbx img {
      width: 167px;
    height: 100px;
  -o-object-fit: contain;
    object-fit: contain;
    filter: grayscale(100%);
    opacity: 0.1;

}


.tickets{
    padding:3em 0;
    margin-bottom:3em;
    background: #1480C1;
    background: linear-gradient(134deg, rgba(20, 128, 193, 1) 0%, rgba(9, 60, 91, 1) 100%);
    color:#fff;
    align-items: center;
    display: flex;
    justify-content: center;
}
.tickets .pattern{
    position: absolute;
    right: auto;
    left: 10em;
    top: 0em;
    width: 39px;
}
.tickets img{
    z-index: 2;
    position: absolute;
    bottom: 4.3rem;
    left: 3em;
    width: 36%;
}
.tickets .cost{
    font-weight:800;
    margin-bottom:2em;
}
.tickets .cost .desc{
    font-size:20px;
}
.tickets .cost .amount{
    font-size: 30px;
    font-weight:900;
    letter-spacing: -2px;
}
.tickets .cost .amount span{
    font-size: 40px;
}
.tickets .block{
    font-size:20px;
}


.contacts{
    margin-bottom:3em;
}


footer{
    padding-top:2em;
    background-color:#f3f3f3;
}
footer .footnav{
    margin:0px auto 3em auto;
}
footer .footnav ul{
    display: flex;
    justify-content: center;
    list-style: none;
    padding: 0px;
    margin: 0px;
    gap:30px;
}
footer .copy{
    text-align: center;
    padding: 1em 0;
    font-size: 13px;
}


@media handheld and (max-width: 480px), screen and (max-device-width: 480px), screen and (max-width: 767px) {
    body{
        width:auto;
    }
    .pattern {
        position: absolute;
        right: 1em;
        top: 0em;
        width: 40px;
    }

    header .logo {
        background: #fff;
        width: 25em;
        height: 15vh;
        float: left;
    }
    header .logo img {
        width: 176px;
        object-fit: contain;
        margin: 2em 0 0px 3em;
    }
    header .navigation {
        top: 0em;
        position:relative;
        right: 0px;
        left: auto;
        width:100%;
    }
    nav {
        display: none;
        background-color: rgba(2, 10, 18, 0.8705882353);
        color: #fff;
        padding-top: 6em;
        position: absolute;
        left: 0px;
        top: 0px;
        min-height: 100vh;
    }
    header .navigation nav ul {
    display: block;
    }
    nav ul li {
        display: block;
        margin: 0px 2.2em;
        float: left;
        width: 100%;
        margin-bottom: 3em;
        text-align: left;
    }
    nav ul li a {
        font-size: 22px;
    }
    .hamb {
        display:block;
        cursor: pointer;
        padding: 47px 20px;
        z-index: 10;
        position: absolute;
        right: 2em;
    } /* Style label tag */
    .hamb-line {
        display: block;
        height: 2px;
        position: relative;
        width: 24px;
    } /* Style span tag */
    .hamb-line::before {
        border-top: solid 3px #fff;
        border-bottom: solid 3px #fff;
        content: "";
        display: block;
        position: absolute;
        transition: all 0.2s ease-out;
        width: 42px;
        height: 13px;
    }
    .hamb-line::before {
        top: 5px;
    }
    .hamb-line::after {
        top: -5px;
    }
    .side-menu {
        display: none;
    } /* Hide checkbox */
    /* Toggle menu icon */
    .side-menu:checked ~ nav {
        max-height: 100%;
        display: block;
    }
    .side-menu:checked ~ .hamb .hamb-line {
        background: transparent;
    }
    .side-menu:checked ~ .hamb .hamb-line::before {
        transform: rotate(-45deg);
        top: 0;
    }
    .side-menu:checked ~ .hamb .hamb-line::after {
        transform: rotate(45deg);
        top: 0;
    }


    .bannerimg {
        width: 114%;
        clip-path: polygon(0 0, 108% 0, 72% 100%, 0% 100%);
    }
    .banner .bannerimg .bannercap{
        left: 1em;
        font-size: 2em;
        width: 70%;
        font-weight: 700;
        line-height: 26px;
    }
    .banner .bannerimg .bannercap h1 {
        font-size: 43px;
    }

    .about .intro img.confimg {
        margin-top: 3em;
    }
    .about .cont {
        padding: 0px;
    }

    .sessions .sessionbx {
        display: block;
    }
    .sessions .sessionbx .cont {
        padding: 3em;
        width: auto;
        height: auto;
    }
    .sessions .sessionbx .sessionimg {
        width:100%;
        height:40vh;
    }

    .numbers .numbersboxes {
        display: block;
    }
    .numbers .numbersboxes .bx {
        padding: 1em 2em;
        margin-left: 3em;
        width: 100%;
    }
    .numbers .numbersboxes .bx:first-child {
        margin-left: 0;
        margin-bottom: 1em;
    }


    .speakers .speakersbx .speaker {
        width: 50%;
    }

    .agenda .slots {
        display: block;
        height: auto;
    }
    .agenda .slots .slot:first-child {
        border-top-left-radius: 0;
    }
    .agenda .slots .slot:last-child {
        border-top-right-radius: 0;
    }
    .agenda .slots .slot:hover, .agenda .slots .selected {
        height:auto;
        padding:20px 0px;
        border-top-left-radius: 0px;
        border-top-right-radius: 0px;
    }

    .agenda .progcont {
        padding: 1em;
    }
    .agenda .caltime {
        width: 100%;
        display: block;
    }
    .agenda .caltime .time {
        width: 100%;
        text-align: left;
    }
    .agenda .caltime .cont {
        width: 100%;
    }
    .agenda .caltime {
        border-bottom: dotted 0.5px #434242;
        margin-bottom: 2em;
    }


    .sponsors .sponsorslist{
        gap: 9px;
        margin-bottom: 3em;
    }

    .tickets {
        text-align: center;
    }
    .tickets .col-lg-5{
        height:20vh;
    }
    .tickets img {
        width: 89%;
        height: auto;
        position: relative;
        left: 0em;
        top: -6em;
    }
    .tickets .pattern {
        display: none;
    }

    
    .hpattern {
        width: 100%;
    }
    .hpattern::after,
    .hpattern::before { 
        content: none;
    }

    footer .footnav ul {
    display: block;
    text-align: center;
    }
}