:root {
  --ba-theme-color: orange;
}


/* spacial black alps fonts */
/* ----------------- */

@font-face {
  font-family: 'Barlow Condensed';
  src: url(../fonts/BarlowCondensed-Regular.ttf) format('truetype');
  font-weight: 400;
  font-style: normal;
}
@font-face {
  font-family: 'Barlow Condensed';
  src: url(../fonts/BarlowCondensed-Italic.ttf) format('truetype');
  font-weight: 400;
  font-style: italic;
}
@font-face {
  font-family: 'Barlow Condensed';
  src: url(../fonts/BarlowCondensed-Bold.ttf) format('truetype');
  font-weight: 700;
  font-style: normal;
}
@font-face {
  font-family: 'Barlow Condensed';
  src: url(../fonts/BarlowCondensed-BoldItalic.ttf) format('truetype');
  font-weight: 700;
  font-style: italic;
}
@font-face {
  font-family: 'Barlow Condensed';
  src: url(../fonts/BarlowCondensed-ExtraBold.ttf) format('truetype');
  font-weight: 800;
  font-style: normal;
}
@font-face {
  font-family: 'Barlow Condensed';
  src: url(../fonts/BarlowCondensed-ExtraBoldItalic.ttf) format('truetype');
  font-weight: 800;
  font-style: italic;
}

@font-face {
  font-family: Airstrike;
  src: url(../fonts/airstrike.ttf);
}

@font-face {
  font-family: Data;
  src: url(../fonts/data-latin.ttf);
}

@font-face {
  font-family: 'Lora';
  src: url(../fonts/lora.ttf) format('truetype');
  font-weight: 100 900;
  font-style: normal;
}
@font-face {
  font-family: 'Lora';
  src: url(../fonts/lora-italic.ttf) format('truetype');
  font-weight: 100 900;
  font-style: italic;
}

@font-face {
  font-family: 'Montserrat';
  src: url(../fonts/montserrat.ttf) format('truetype');
  font-weight: 100 900;
  font-style: normal;
}
@font-face {
  font-family: 'Montserrat';
  src: url(../fonts/montserrat-italic.ttf) format('truetype');
  font-weight: 100 900;
  font-style: italic;
}

@font-face {
  font-family: 'Open Sans';
  src: url(../fonts/open-sans.ttf) format('truetype');
  font-weight: 100 900;
  font-style: normal;
}
@font-face {
  font-family: 'Open Sans';
  src: url(../fonts/open-sans-italic.ttf) format('truetype');
  font-weight: 100 900;
  font-style: italic;
}


html{
  scroll-padding-top: 100px; 
}

/* body */
/* ----------------- */
body{
  font-family: "Open Sans";
  /*font-family: Calibri;*/
  font-size: 14px;
}
@media (min-width: 768px) {
  body {
    font-size: 16px;
  }
}

a {
  text-decoration: none;
}

img{
  border-radius: 10px;
}

.savethedate{
  color:orange;
  border-color:orange;
}
.ba-theme-colored{
  color: var(--ba-theme-color);
  border-color: var(--ba-theme-color);
}

.vertical-align {
  display: flex;
  align-items: center;
}

td{
  padding: 0 2em 0 0;
  vertical-align: top;
}

/*
#top-left-cervin svg:hover path {
fill: red;
}
*/

/* footer */
/* ----------------- */

footer{
  border-top: solid 1px #666;
  background: #161616;
  padding:20px 0 20px 0;
  margin:0px 0 0px 0;
}

footer, footer a{
  color: #BBB;
}
footer a:hover{
  color: #FFF; /*#0FF;*/
}
footer .no-padding{
  padding:0;
}



/* standard HEADS */
/* ----------------- */
.blackalps-head {
  display: table;
  width: 100%;
  height: 400px;
  color: white;
  background-color: black;

  background-position: center 30%;
  background-repeat: no-repeat;
  background-size: cover;
}
.blackalps-head h1 {
  font-size: 50px;
  font-family:Airstrike;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  background-attachment: fixed;
  border-bottom: none;
  line-height: 1.2ex;
  margin: 10px;
}
.blackalps-head h2 {
  font-size: 30px;
  font-family: Airstrike;
  margin: 0px 0 0px 0;

}
.blackalps-head p {
  font-size: 18px;
  /* font-family:Data; */ 
  text-align: center;
  margin: 3px;
}
@media (min-width: 768px) {
  .blackalps-head h1 {
    font-size: 80px;
  }
  .blackalps-head p {
    font-size: 22px;
  }
}


/* standard CONTENTS */
/* ----------------- */
/*
div.blackalps-content {
padding: 5px 20px 60px 20px;
}
@media (min-width: 768px) {
div.blackalps-content {
padding: 10px 45px 120px 45px;
}
}
*/
div.blackalps-content {
  margin: 10px 0 30px 0;
}
@media (min-width: 768px) {
  div.blackalps-content {
    margin: 20px 0 50px 0;
  }
}



/* Banner2024 */
/* ----------------- */
/*

#blackalps .blackalps-head .row{
  background: url(../../img/background/ba-slide-transp.png) no-repeat bottom right scroll;
  background-size:cover;
  padding: 0px 0px 12% 0px;
}
#welcome-ba .blackalps-head .row {
  background: url(../../img/background/welcome-archive.jpg) no-repeat bottom center scroll;
  padding: 70px 0 80px 0;
}
*/
#blackalps img, #welcome-ba .blackalps-head img, #ba-summer .blackalps-head img{
  width: 30%;
  margin: 7ex 0 4ex 0;
  border-radius: 0px;
}
#blackalps h1, #welcome-ba h1, #ba-summer h1 {
  font-size: 0px;
}
#blackalps h2 {
  font-family: Helvetica;
  text-transform: none;
  font-weight: normal ;
  font-size: 22px;
  margin:0px;
  padding:0px;
}
#blackalps p {
  font-family: Helvetica;
  text-transform: none;
  font-size: 18px;
}
@media (min-width: 768px) {
  #blackalps h2 {
    font-size: 30px;
  }
  #blackalps p {
    font-size: 22px;
  }
}

h1.ba-top-page, h2.ba-top-page {
  text-align: center;  
  font-family: Helvetica;
  border:none;
}
h1.ba-top-page{
  font-size: 30px;
  font-weight: normal;
  margin: 2ex 0 1ex 0;
}
h2.ba-top-page{
  text-transform: none;
  font-size: 44px;
  margin: 1ex 0 2ex 0;
}


/* BG IMAGES */
/* ----------------- */
/*
#about-blackalps .blackalps-head{
  background: url(../../img/background/about-blackalps.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#special-event .blackalps-head{
  background: url(../../img/background/business-event.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#cfp .blackalps-head{
  background: url(../../img/background/cfp.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#contact .blackalps-head {
  padding: 150px 0 150px 0;
  background: url(../../img/background/contact.jpg) no-repeat center center scroll;
}

#evenings .blackalps-head {
  background: url(../../img/background/evenings.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#hotel .blackalps-head {
  background: url(../../img/background/hotel.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#register .blackalps-head {
  background: url(../../img/background/register.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#schedule .blackalps-head {
  background: url(../../img/background/schedule.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#sponsors .blackalps-head {
  background: url(../../img/background/sponsors.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#summary .blackalps-head {
  background: url(../../img/background/summary.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#talks .blackalps-head {
  background: url(../../img/background/talks.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#previous-events .blackalps-head{
  background: url(../../img/background/welcome-archive.jpg) no-repeat bottom center scroll;
  padding: 150px 0 150px 0;
}

#program .blackalps-head {
  background: url(../../img/background/program.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#team .blackalps-head {
  background: url(../../img/background/team.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#venue .blackalps-head {
  background: url(../../img/background/venue.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#bbq-welcome .blackalps-head{ 
  background: url(../../img/background/bbq.jpg) no-repeat bottom center scroll; 
  padding: 150px 0 150px 0;
}
#bbq-summary .blackalps-head{ 
  background: url(../../img/background/bbq-summary.jpg) no-repeat bottom center scroll; 
  padding: 150px 0 150px 0;
}
#ba-summer .blackalps-head{ 
  background: url(../../img/background/summer2.jpg) no-repeat bottom center scroll; 
  padding: 70px 0 80px 0;
}
  */


/*
#welcome .blackalps-head .row{
  background: url(../../img/background/ba-slide-transp.png) no-repeat bottom center scroll;
  background-size:cover;
  padding: 0px 0px 170px 0px;
}
*/

#welcome .blackalps-head h1 {
  font-size: 0px;
}
#welcome .blackalps-head h2 {
  font-family: Helvetica, sans-serif;
  text-transform: none;
  font-size: 22px;
}
@media (min-width: 768px) {
  #welcome .blackalps-head h2 {
    font-size: 30px;
  }
}
#welcome .blackalps-head p {
  font-family: Helvetica, sans-serif;
  text-transform: none;
  font-size: 18px;
}
@media (min-width: 768px) {
  #welcome .blackalps-head p {
    font-size: 22px;
  }
}
#welcome .blackalps-head img {
  width: 90%;
  margin: 30px;
}
@media (min-width: 768px) {
  #welcome .blackalps-head img {
    width: 600px;
    /*margin: 60px 0px 20px 30px;*/
    /*padding: 150px 0 150px 0;*/
  }
}

/*
#welcome-archive .blackalps-head{
  background: url(../../img/background/welcome-archive.jpg) no-repeat bottom center scroll;
  padding: 85px 0 150px 0;
}

#welcome-archive-counter .blackalps-head{
  background: url(../../img/background/welcome-archive.jpg) no-repeat bottom center scroll;
  padding: 110px 10px 20px 0px;
  padding: 150px 0 150px 0;
}
@media (min-width: 768px) {
  #welcome-archive-counter .blackalps-head{
    background: url(../../img/background/welcome-archive.jpg) no-repeat bottom center scroll;
    padding: 160px 10px 10px 0px;
  }
}

#blackalps-ctf .blackalps-head {
  background: url(../../img/background/y-not-ctf.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}
#y-not-ctf .blackalps-head {
  background: url(../../img/background/y-not-ctf.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}

#y-security .blackalps-head {
  background: url(../../img/background/y-security.jpg) no-repeat center center scroll;
  padding: 150px 0 150px 0;
}
*/

/* BOXes */
/* ----------------- */
.ba-boxed, .ba-welcome-box, .ba-carousel-box{
  border: solid 1px var(--ba-theme-color);
  border-radius: 12px;
  background-color: #070707;
}

.ba-boxed{
  padding:10px;
  margin-bottom: 2ex;
}

.ba-welcome-box{
  margin: 2ex 10% 2ex 10%;
  min-height: 25ex;
}
.ba-welcome-box h2{
  font-size: 22px;
  font-weight: normal;
  margin:1ex 0 1ex 0;
  padding:0;
}
.ba-welcome-box p{
  margin-bottom:1ex;
}



.ba-carousel{
  padding: 2ex;
}
.ba-carousel-box{
  margin: 2ex;
  padding:1ex;
  min-height: 400px;
}
.ba-carousel-box h2{
  font-size: 22px;
  font-weight: normal;
  margin:1ex 0 1ex 0;
  padding:0;
}
.ba-carousel-box p{
  margin-bottom:1ex;
}

/* BUTTON */
/* ----------------- */
.btn, .network-name{
  margin: 10px;
  border-radius: 10px;
  color: black;
  background-color: white;
  text-transform: none;
  font-weight: 400;
}
.btn-default:hover{
  background-color: #444; /*#044; /*#42DCA3;*/
}
.btn-default .fa, .network-name {
  color: orange;
  background-color:transparent;
}

.network-user {
  font-family: "Lora", "Helvetica Neue", Helvetica, Arial, sans-serif;
  text-transform: none;
  font-size: 14px;
}

.btn td {
  padding: 0px 20px 0px 0px;
}

#team-content a .fa{
  color: #999;
}
#team-content a:hover .fa{
  color: #FFF;
  background: #444;
}




/* SPONSORS */
/* ----------------- */

.sponsors .photo-wrapper{
  margin: 0px;
  padding: 0px;
  display: inline-block;
  max-width: 100%;  
}

.sponsors a:hover img{
  background: linear-gradient(to right bottom, #000 60%, #444 100%);
}

#sponsors-content h2{
  background: #444;
}

/*
#sponsors-content .container{
background: #333;
}
*/


/* PEOPLE - TEAM - SPEAKER */
/* ----------------- */
.speaker {
  text-align: center;
  margin: 0 0 50px 0;
}
.speaker .photo-wrapper.rounded {
  border-radius: 50% !important;
  overflow: hidden;
}

.speaker .photo-wrapper {
  margin: 10px;
  display: inline-block;
  max-width: 100%;
  width: 100%;
}
.speaker .photo-wrapper img {
  width: 100%;
  aspect-ratio: 1/1;
  object-fit: cover;
  object-position: top;

}

.speaker h3.name {
  font-size: 18px;
  margin:10px;
  font-weight: bold;
  color:#FFF;
}
.speaker h3.name .firstname {
  text-transform: none;
}

.speaker p.company {
  margin:5px;
  color: #AAA;
}

.speaker p.about {
  margin: 10px;
  color: #AAA;
  font-size: 10pt;
  font-style: italic;
}


.speaker ul {
  margin:0px;
  padding:0px;
}

.speaker .speaker-socials li {
  margin: 0px;
  padding: 5px;
  display: inline-block;
}

.speaker .speaker-socials li .fa {
  width: 30px;
  height: 30px;
  line-height: 27px;
  border-radius: 50%;
  border: 2px solid;
}


.speaker-bio{
  text-align: justify;
  font-style: italic;
  white-space: pre-line;
}


#team-content .speaker .company a{
  color:#AAA;
}
#team-content .speaker .company a:hover{
  color:#FFF;
}
/*#team-content .speaker .about{
display:none;
} */ 




/* TALKS */
/* ----------------- */
#talks-content .talk-container{
  width:80%;
  margin-left: 18%;
  margin-right: 40px;
  margin-bottom: 40px;
  padding: 10px;
  border: dashed 2px #555;
}


#talks-content .track-keynote{
  background: #092020;/* rgba(10, 47, 45, 0.6); #1b4745;*/
} 
#talks-content .track-conf{
  background: #222;
}  
#talks-content .track-attacks{
  background: #200;
}  
#talks-content .track-ll{
  background: #002;
}  
#talks-content .track-event{
  background: #220;
}
#talks-content .track-workshop{
  background: #021002;
}


.talk-title{
  color:white;
  margin: 0 0 10px 0;
}

/*
.talk-content{

}
*/

p.talk-abstract{
  text-align: justify;  
  white-space: pre-line;
  /* 
width:80%;
margin:0 auto;
*/
}



/* ----------------------------------------------------------------------------
Counters
---------------------------------------------------------------------------- */
.counter-block {
  margin: 0px;
  vertical-align: top;
  display: inline-block;
  width: 168px;
  height: 168px;
  text-align: center;
}
#welcome .counter-block {
  width: 114px;
  height: 114px;
}
.counter-box {
  display: table;
  width: 100%;
  height: 100%;
  background-color: transparent;
  border: none;
}
.counter-box .counter-content {
  vertical-align: middle;
  display: table-cell;
  padding: 0;
}
.counter-box .counter-content > .count {
  display: inline-block;
  width: 100%;
  font-family: "PT Sans Caption", Arial, "Helvetica Neue", Helvetica, sans-serif;
  font-size: 60px;
  font-weight: 700;
  line-height: 100px;  
  color:#FFF;/*#099;*/
}

#clockdiv .counter-box .counter-content > .count {
  display: inline-block;
  width: 100%;
  font-family: "PT Sans Caption", Arial, "Helvetica Neue", Helvetica, sans-serif;
  font-size: 60px;
  font-weight: 700;
  line-height: 80px;
  color:#FFF;/*#099;*/
}

#welcome .counter-box .counter-content .count {
  font-size: 50px;
  line-height: 65px;
}
.counter-box .counter-content .title {
  margin: 0;
  font-family: "PT Sans Caption", Arial, "Helvetica Neue", Helvetica, sans-serif;
  font-size: 13px;
  line-height: 16px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.6em;
  text-align: center;
}
#welcome .counter-box .counter-content .title {
  color:#BBB;
}
@media (max-width: 767px) {
  .counter-block {
    width: 114px;
    height: 114px;
  }
  .counter-box .counter-content > .count {
    font-size: 50px;
    line-height: 65px;
  }

  #welcome-archive-counter #clockdiv .counter-box .counter-content > .count{
    display: inline-block;
    font-family: "PT Sans Caption", Arial, "Helvetica Neue", Helvetica, sans-serif;
    font-size: 30px;
    font-weight: 700;
    line-height: 50px;
    color:#FFF;/*#099;*/
  }

  #welcome-archive-counter #clockdiv .counter-box .counter-content .title {
    margin: 0;
    font-family: "PT Sans Caption", Arial, "Helvetica Neue", Helvetica, sans-serif;
    font-size: 70%;
    line-height: 16px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.6em;
    text-align: center;
  }

  #welcome .counter-block {
    width: 100px;
    height: 80px;
  }
  #welcome .counter-box .counter-content .count {
    font-size: 30px;
    line-height: 35px;
  }
}





/* HISTORY */
/* ----------------- */
#previous-events table{
  margin:0 auto;
  width:90%;
}

#previous-events table, 
#previous-events th, 
#previous-events tr, 
#previous-events td{
  border: 1px solid #666;
}

#previous-events td,
#previous-events th{
  padding: 0;
}
#previous-events th{
  background:#000;
  color:#666;
}




/* SCHEDULE */
/* ----------------- */

#schedule-content table, 
#schedule-content th, 
#schedule-content tr, 
#schedule-content td{
  margin: 0px;
  padding: 0px;
  border: 1px solid #666;
}
#schedule-content table{
  margin:0 auto;
  width:90%;
}
#schedule-content tr{
  font-size:12pt;
  text-align:center;
  vertical-align:top;
}

table.schedule-table, 
.schedule-table th, 
.schedule-table tr, 
.schedule-table td{
  margin: 0px;
  padding: 0px;
  border: 1px solid #666;
}
table.schedule-table {
  margin:0 auto;
  width:90%;
}
.schedule-table tr{
  font-size:12pt;
  text-align:center;
  vertical-align:top;
}

.schedule-legend{
  font-size:10pt;
}

td.schedule-time{
  background:#000;
  color:#666;
}
td.schedule-break,
td.schedule-roomchange,
td.schedule-lunch,
td.schedule-travel{
  color:#666;
  font-style:italic;
}
td.schedule-opening{
  color:#fff;
  background:#444;
}
td.schedule-conf,
td.schedule-workshop{
  color:#fff;
  /*background: #444;*/
}
td.schedule-event,
span.schedule-event{
  color:#fff;
  background: #552;     
}
td.schedule-evening,
span.schedule-evening{
  color:#fff;
  background: #525;     
}

td.track-keynote,
span.track-keynote{
  background: #1b4745;
} 
td.track-attacks,
span.track-attacks{
  background: #500;
}
td.track-conf,
span.track-conf{
  background: #444;    
}
td.track-ll,
span.track-ll{
  background: #005;
}
td.track-workshop,
span.track-workshop{
  background: #050;    
}
td.track-neutral,
span.track-neutral{
  background: linear-gradient(to right bottom, #944 30%, #449 70%);
}

/*
#schedule-content td{
}
*/

#schedule-content td a{
  display:block;
  width:100%; 
  height:100%;
  overflow: auto;
  text-decoration: none;
}  
#schedule-content td.track-keynote a:hover,
.schedule-table td.track-keynote a:hover{
  background: #366;
}  
#schedule-content td.track-attacks a:hover,
.schedule-table td.track-attacks a:hover{
  background: #822;
}  
#schedule-content td.track-ll a:hover,
.schedule-table td.track-ll a:hover{
  background: #228;
}  
#schedule-content td.track-workshop a:hover,
.schedule-table td.track-workshop a:hover{
  background: #282;
}  
#schedule-content td.track-neutral a:hover,
.schedule-table td.track-neutral a:hover{
  background: linear-gradient(to right bottom, #533 30%, #335 70%);
}
#schedule-content td.schedule-event a:hover,
.schedule-table td.schedule-event a:hover{
  background: #994;
}
.schedule-table td a:hover div ,
.schedule-table td a:hover span {
  text-shadow: 0px 0px 10px black;
}
#schedule-content td.schedule-evening a:hover,
.schedule-table td.schedule-evening a:hover{
  background: #949;
}

.schedule-a{
  padding:10px;
}

.schedule-div-title{
  display:block;
}

.schedule-id{
  display:none;
}  
.schedule-title{
  font-weight: normal;
  color:#FFF;
}  
.schedule-lang{
  /*display:block;*/
  font-size: 10pt;
  font-weight:normal;
  color:#888;
}  

.schedule-div-authors{
  display:block;
  width:100%; 
  height:100%;
  margin:1ex 0 0  0;
  line-height: 1;
}  
.schedule-speaker{
  font-size: 10pt;
  font-weight:normal;
  color:#FFF;
  margin:1ex 0 0  0;
}  
.schedule-company{
  font-size: 10pt;
  font-weight:normal;
  color:#888;
  margin:0.3ex 0 0  0; 
}

table.schedule-table,
table.schedule-content  {
  table-layout: fixed;
  height: 1px;
}
table.schedule-table td:nth-of-type(1) {
  width: 8em;
  vertical-align: middle;
}
table.schedule-table a,
table.schedule-content a {
  display: block;
  height: 100%;
}
table.schedule-table td.schedule-break .schedule-a {
  padding: 2px 1em;
}


.menu-table tr{
  border-collapse: collapse;
}

.menu-table td {
  border: 1px solid white;
  text-align: center;
  height: 25px;
  vertical-align: top;
}

.menu-table th {
  border: 1px solid white;
  color: #FFFFFF;
  text-align: center;
}

.center-table{
  width:70%;
  margin-left:15%;
  margin-right:15%;
}

/* TALK PAGE */
    :root {
        --talk-surface: #111111;
        --talk-surface-2: #1a1a1a;
        --talk-border: #2a2a2a;
        --talk-accent: var(--ba-theme-color, orange);
        --talk-accent-dim: rgba(255, 165, 0, .12);
        --talk-text: #e8e8e8;
        --talk-muted: #777;
        --talk-radius: 4px;
    }

    .talk-page * {
        box-sizing: border-box;
        margin: 0;
        padding: 0;
    }

    .talk-page {
        background: #000;
        color: var(--talk-text);
        font-family: 'Open Sans', 'Helvetica Neue', Helvetica, sans-serif;
        font-size: 1rem;
        line-height: 1.7;
        min-height: 100vh;
        padding: 0 0 80px;
    }

    .talk-page .container {
        max-width: 1100px;
        margin-left: auto;
        margin-right: auto;
        padding-left: 24px;
        padding-right: 24px;
    }

    .talk-hero {
        padding: 15px 0 30px;
        border-bottom: 1px solid var(--talk-border);
    }

    .talk-meta-row {
        display: flex;
        align-items: center;
        gap: 12px;
        flex-wrap: wrap;
        margin-bottom: 22px;
    }

    .talk-badge {
        display: inline-block;
        font-family: 'Montserrat', 'Arial Narrow', Arial, sans-serif;
        font-size: .7rem;
        font-weight: 700;
        letter-spacing: .15em;
        text-transform: uppercase;
        padding: 4px 10px;
        border: 1px solid var(--talk-accent);
        color: var(--talk-accent);
        border-radius: var(--talk-radius);
    }

    .talk-meta-item {
        font-size: .9rem;
        letter-spacing: .08em;
        color: var(--talk-text);
        text-transform: uppercase;
    }

    .talk-meta-item svg {
        vertical-align: middle;
        margin-right: 5px;
        opacity: .6;
    }

    .talk-page h1.talk-title {
        font-family: 'Barlow Condensed';
        font-size: clamp(1.9rem, 4vw, 3.2rem);
        font-weight: 800;
        line-height: 1.1;
        letter-spacing: -.01em;
        color: #fff;
        max-width: 820px;
        margin: 0 0 10px;
    }

    .talk-body {
        padding-top: 52px;
        display: grid;
        grid-template-columns: 1fr 360px;
        gap: 56px;
        align-items: start;
    }

    @media (max-width: 900px) {
        .talk-body {
            grid-template-columns: 1fr;
            gap: 36px;
        }
    }

    .talk-section-label {
        font-family: 'Montserrat', sans-serif;
        font-size: .7rem;
        font-weight: 700;
        letter-spacing: .18em;
        text-transform: uppercase;
        color: var(--talk-accent);
        margin-bottom: 18px;
    }

    p.talk-abstract {
        font-size: 1rem;
        color: #c8c8c8;
        line-height: 1.8;
        white-space: pre-line;
        text-align: left;
    }

    .talk-video-wrap {
        margin-top: 40px;
        position: relative;
        padding-bottom: 56.25%;
        height: 0;
        overflow: hidden;
        border-radius: var(--talk-radius);
        border: 1px solid var(--talk-border);
        background: #000;
    }

    .talk-video-wrap iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border: 0;
    }

    .talk-slides-btn {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        margin-top: 24px;
        padding: 11px 22px;
        background: var(--talk-surface-2);
        border: 1px solid var(--talk-border);
        color: var(--talk-text);
        font-family: 'Open Sans', sans-serif;
        font-size: .88rem;
        letter-spacing: .06em;
        text-decoration: none;
        border-radius: var(--talk-radius);
        transition: border-color .2s, color .2s;
    }

    .talk-slides-btn:hover {
        border-color: var(--talk-accent);
        color: var(--talk-accent);
    }

    .talk-speaker-card {
        background: var(--talk-surface);
        border: 1px solid var(--talk-border);
        border-radius: var(--talk-radius);
        padding: 28px 24px;
        margin-bottom: 20px;
        transition: border-color .25s;
    }

    .talk-speaker-card:hover {
        border-color: #3a3a3a;
    }

    .talk-speaker-photo-wrap {
        width: 72px;
        height: 72px;
        border-radius: 50%;
        overflow: hidden;
        flex-shrink: 0;
        border: 2px solid var(--talk-border);
    }

    .talk-speaker-photo-wrap img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: top;
        display: block;
        border-radius: 0;
    }

    .talk-speaker-header {
        display: flex;
        gap: 16px;
        align-items: center;
        margin-bottom: 16px;
    }

    .talk-speaker-name {
        font-family: 'Montserrat', sans-serif;
        font-size: 1.15rem;
        font-weight: 700;
        color: #fff;
        line-height: 1.2;
    }

    .talk-speaker-role {
        font-size: .8rem;
        color: var(--talk-muted);
        margin-top: 3px;
    }

    .talk-speaker-company {
        font-size: .82rem;
        color: var(--talk-accent);
        margin-top: 2px;
    }

    .talk-speaker-bio {
        font-size: .85rem;
        color: #999;
        line-height: 1.7;
        margin-bottom: 16px;
    }

    .talk-socials {
        display: flex;
        gap: 10px;
        list-style: none;
        margin: 0;
        padding: 0;
    }

    .talk-socials a {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 32px;
        height: 32px;
        border: 1px solid var(--talk-border);
        border-radius: var(--talk-radius);
        color: var(--talk-muted);
        text-decoration: none;
        font-size: .85rem;
        transition: border-color .2s, color .2s;
    }

    .talk-socials a:hover {
        border-color: var(--talk-accent);
        color: var(--talk-accent);
    }

    .talk-nav {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 18px 0 0;
        margin-bottom: 4px;
    }

    .talk-nav-back,
    .talk-nav-all {
        display: inline-flex;
        align-items: center;
        gap: 7px;
        font-size: .8rem;
        font-family: 'Montserrat', sans-serif;
        font-weight: 600;
        letter-spacing: .1em;
        text-transform: uppercase;
        color: var(--talk-muted);
        text-decoration: none;
        transition: color .2s;
    }

    .talk-nav-back:hover,
    .talk-nav-all:hover {
        color: var(--talk-accent);
    }

    .talk-share-wrap {
        position: relative;
    }

    .talk-share-btn {
        display: inline-flex;
        align-items: center;
        gap: 7px;
        font-size: .8rem;
        font-family: 'Montserrat', sans-serif;
        font-weight: 600;
        letter-spacing: .1em;
        text-transform: uppercase;
        color: var(--talk-muted);
        background: none;
        border: 1px solid transparent;
        border-radius: var(--talk-radius);
        padding: 5px 10px;
        cursor: pointer;
        transition: color .2s, border-color .2s;
    }

    .talk-share-btn:hover,
    .talk-share-btn.active {
        color: var(--talk-accent);
        border-color: var(--talk-border);
    }

    .talk-share-dropdown {
        display: none;
        position: absolute;
        top: calc(100% + 8px);
        right: 0;
        background: var(--talk-surface-2);
        border: 1px solid var(--talk-border);
        border-radius: var(--talk-radius);
        min-width: 200px;
        z-index: 100;
        overflow: hidden;
        box-shadow: 0 8px 24px rgba(0, 0, 0, .5);
    }

    .talk-share-dropdown.open {
        display: block;
    }

    .talk-share-dropdown a,
    .talk-share-dropdown button {
        display: flex;
        align-items: center;
        gap: 10px;
        width: 100%;
        padding: 11px 16px;
        background: none;
        border: none;
        border-bottom: 1px solid var(--talk-border);
        color: var(--talk-text);
        font-family: 'Open Sans', sans-serif;
        font-size: .82rem;
        text-decoration: none;
        cursor: pointer;
        transition: background .15s, color .15s;
        text-align: left;
    }

    .talk-share-dropdown a:last-child,
    .talk-share-dropdown button:last-child {
        border-bottom: none;
    }

    .talk-share-dropdown a:hover,
    .talk-share-dropdown button:hover {
        background: rgba(255, 255, 255, .04);
        color: var(--talk-accent);
    }


:root {
    --sp-acc:     orange;
    --sp-acc-dim: rgba(255,165,0,.08);
    --sp-s1:      #0d0d0d;
    --sp-s2:      #141414;
    --sp-b:       #222;
    --sp-b2:      #2e2e2e;
    --sp-mut: #999;
    --sp-txt:     #ddd;
    --sp-r:       3px;
}

.search-page { padding: 40px 0 80px; }

.search-page h1 {
    font-family: 'Arial Narrow', Arial, sans-serif;
    font-size: 2.4rem;
    font-weight: 900;
    color: #fff;
    letter-spacing: -.02em;
    margin-bottom: 28px;
}

.sp-form-wrap {
    border: 1px solid var(--sp-b);
    border-radius: var(--sp-r);
    overflow: hidden;
    margin-bottom: 24px;
}

.sp-search-row {
    display: flex;
    border-bottom: 1px solid var(--sp-b);
}
.sp-search-row input {
    flex: 1;
    background: var(--sp-s1);
    border: none;
    color: #fff;
    font-family: inherit;
    font-size: .92rem;
    padding: 12px 16px;
    outline: none;
    min-width: 0;
}
.sp-search-row input::placeholder { color: var(--sp-mut); }
.sp-search-row input:focus { background: var(--sp-s2); }
.sp-search-row button {
    background: var(--sp-acc);
    color: #000;
    border: none;
    font-family: 'Arial Narrow', Arial, sans-serif;
    font-size: .72rem;
    font-weight: 700;
    letter-spacing: .15em;
    text-transform: uppercase;
    padding: 0 24px;
    cursor: pointer;
    flex-shrink: 0;
    transition: background .15s;
}
.sp-search-row button:hover { background: #ffb733; }

.sp-filters {
    display: flex;
    flex-wrap: wrap;
    background: var(--sp-s2);
}
.sp-filters select,
.sp-filters .sp-check {
    background: transparent;
    color: #999;
    border: none;
    border-right: 1px solid var(--sp-b);
    color: var(--sp-mut);
    font-family: inherit;
    font-size: .78rem;
    padding: 9px 13px;
    cursor: pointer;
    outline: none;
    transition: color .15s, background .15s;
}
.sp-filters select:last-child,
.sp-filters .sp-check { border-right: none; }
.sp-filters select:hover,
.sp-filters select:focus,
.sp-filters .sp-check:hover { color: var(--sp-txt); background: rgba(255,255,255,.03); }
.sp-filters select option { background: #111; }

.sp-check {
    display: flex;
    align-items: center;
    gap: 7px;
    cursor: pointer;
    user-select: none;
}
.sp-check input { accent-color: var(--sp-acc); width: 13px; height: 13px; }

.sp-results-bar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-bottom: 11px;
    border-bottom: 1px solid var(--sp-b);
    margin-bottom: 0;
}
.sp-results-bar .sp-count {
    font-size: .7rem;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: var(--sp-mut);
}
.sp-results-bar .sp-count strong {
    color: #ccc;
    font-size: .84rem;
    font-weight: 600;
}

.sp-talk-list {
    margin-top: 0;
    border: 1px solid var(--sp-b);
    border-top: none;
    border-radius: 0 0 var(--sp-r) var(--sp-r);
    overflow: hidden;
}

.sp-talk-row {
    display: flex;
    align-items: baseline;
    gap: 0;
    border-bottom: 1px solid var(--sp-b);
    text-decoration: none;
    color: inherit;
    padding: 13px 18px;
    transition: background .15s;
    position: relative;
}
.sp-talk-row:last-child { border-bottom: none; }
.sp-talk-row:hover { background: var(--sp-s1); }
.sp-talk-row::before {
    content: '';
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 2px;
    background: var(--sp-acc);
    opacity: 0;
    transition: opacity .15s;
}
.sp-talk-row:hover::before { opacity: 1; }

.sp-talk-main { flex: 1; min-width: 0; }

.sp-talk-title {
    font-family: 'Arial Narrow', Arial, sans-serif;
    font-size: 1rem;
    font-weight: 700;
    color: #fff;
    line-height: 1.25;
    margin-bottom: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: color .15s;
}
.sp-talk-row:hover .sp-talk-title { color: var(--sp-acc); }

.sp-talk-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.sp-badge {
    display: inline-block;
    font-size: .58rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    padding: 2px 6px;
    border: 1px solid;
    border-radius: 2px;
    flex-shrink: 0;
}

.sp-badge.keynote    { border-color: #1b9;    color: #1b9; }
.sp-badge.workshop   { border-color: #88f;    color: #88f; }
.sp-badge.lang       { border-color: #2a2a2a; color: #888; }
.sp-badge.year { 
    border-color: transparent; 
    color: var(--sp-mut);
    font-size: .65rem; 
    letter-spacing: .06em; 
    padding-left: 0; 
}

.sp-speaker {
    font-size: .77rem;
    color: var(--sp-mut);
}
.sp-speaker strong { color: #999; font-weight: 600; }

.sp-talk-flags {
    flex-shrink: 0;
    padding-left: 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.sp-video {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: .6rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #e55;
}
.sp-video::before {
    content: '';
    width: 5px; height: 5px;
    border-radius: 50%;
    background: #e55;
    flex-shrink: 0;
}

.sp-state {
    padding: 56px 0;
    text-align: center;
    color: var(--sp-mut);
}
.sp-state p { font-size: .84rem; }

@media (max-width: 600px) {
    .sp-filters { flex-direction: column; }
    .sp-filters select,
    .sp-filters .sp-check { border-right: none; border-bottom: 1px solid var(--sp-b); }
    .sp-filters .sp-check { border-bottom: none; }
    .sp-talk-title { white-space: normal; }
}

.sp-talk-abstract {
    font-size: 0.85rem;
    color: #888;
    margin: 4px 0 6px;
    line-height: 1.4;
}

@media (max-width: 600px) {

    .container.search-page {
        padding: 20px 15px; 
    }

    .sp-form-wrap {
        border: none; 
        background: transparent;
    }

    .sp-search-row {
        border: 1px solid var(--sp-b);
        border-radius: var(--sp-r);
        margin-bottom: 12px;
        background: var(--sp-s1);
    }

    .sp-filters {
        background: transparent;
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        gap: 8px; 
        margin-bottom: 20px;
    }

    .sp-filters select,
    .sp-filters .sp-check {
        flex: 0 1 auto;
        background: #252525; 

        border: 1px solid rgba(255, 255, 255, 0.15); 
        border-radius: 20px; 
        color: #d1d1d1; 
        padding: 6px 14px; 
        font-size: 0.75rem; 
        appearance: none;
        text-align: center;
        transition: all 0.2s ease;
        box-shadow: 0 2px 4px rgba(0,0,0,0.1); 
    }

    .active-filter, 
    .sp-filters select:focus {
        border-color: var(--sp-acc) !important; 
        color: #ffffff !important;              
        background: rgba(255, 122, 0, 0.1) !important; 
        box-shadow: 0 0 10px rgba(255, 122, 0, 0.15);  
        outline: none;
    }

    .active-filter::before {
        content: "•";
        color: var(--sp-acc);
        margin-right: 5px;
        font-weight: bold;
    }

    .sp-talk-list {
        border: none; 
    }

    .sp-talk-row {
        background: var(--sp-s2);
        border: 1px solid var(--sp-b);
        border-radius: var(--sp-r);
        margin-bottom: 10px;
        padding: 15px;
        flex-direction: column; 
        align-items: flex-start;
    }

    .sp-talk-list .sp-talk-row:first-child {
        margin-top: 15px; 
    }

    .sp-talk-row::before {
        display: none; 
    }

    .sp-talk-title {
        white-space: normal; 
        font-size: 1.1rem;   
        margin-bottom: 8px;
    }

    .sp-talk-abstract {
        font-size: 0.8rem;
        margin-bottom: 12px;
        display: -webkit-box;
        -webkit-line-clamp: 3; 
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .sp-talk-meta {
        width: 100%;
        justify-content: flex-start;
        gap: 6px;
    }

    .sp-talk-flags {
        padding-left: 0;
        margin-top: 10px;
        width: 100%;
        justify-content: flex-end;
    }
}

.ba-table {
    width: 100%;
    border-collapse: collapse;
}

.ba-table th {
    text-align: left;
    padding: 10px;
    border-bottom: 2px solid #333;
}

.ba-table td {
    padding: 10px;
    border-bottom: 1px solid #222;
}

.ba-table tr:hover {
    background: rgba(255,255,255,0.03);
}

.ba-table tr.active {
    background: rgba(97, 218, 251, 0.08);
    border-left: 3px solid #61dafb;
}

.ba-link {
    color: white;
    text-decoration: none;
}

.ba-link:hover {
    color: #61dafb;
}

.ba-tabs {
    display: flex;
    gap: 25px;
    border-bottom: 1px solid #222;
    margin-bottom: 20px;
}

.ba-tab {
    position: relative;
    padding: 10px 0;
    text-decoration: none;
    color: #aaa;
    font-weight: 500;
    transition: 0.2s;
}

.ba-tab:hover {
    color: white;
}
.ba-tab::after {
    content: '';
    position: absolute;
    left: 0;
    bottom: -1px;
    width: 0%;
    height: 2px;
    background: #61dafb;
    transition: 0.3s;
}

.ba-tab.active {
    color: white;
}

.ba-tab.active::after {
    width: 100%;
}

  .arc-edition-bar {
        display: flex;
        align-items: center;
        gap: 1rem;
        padding: 1.75rem 0 1.5rem;
        flex-wrap: wrap;
        border-bottom: 1px solid rgba(255, 255, 255, .1);
        margin-bottom: 1.75rem;
    }

    .arc-edition-bar label {
        font-weight: 700;
        font-size: 1rem;
        letter-spacing: .07em;
        text-transform: uppercase;
        white-space: nowrap;
    }

    .arc-select-wrap {
        position: relative;
        flex: 1;
        max-width: 420px;
    }

    .arc-select-wrap select {
        appearance: none;
        -webkit-appearance: none;
        background: transparent;
        color: inherit;
        border: 2px solid rgba(255, 255, 255, .4);
        border-radius: 4px;
        padding: .7rem 2.5rem .7rem 1rem;
        font-size: 1rem;
        font-weight: 500;
        cursor: pointer;
        width: 100%;
        transition: border-color .15s;
    }

    .arc-select-wrap select:focus,
    .arc-select-wrap select:hover {
        outline: none;
        border-color: rgba(255, 255, 255, .85);
    }

    .arc-select-wrap::after {
        content: '▾';
        position: absolute;
        right: .9rem;
        top: 50%;
        transform: translateY(-50%);
        pointer-events: none;
        font-size: .85rem;
        opacity: .55;
    }

    .arc-edition-nav {
        margin-bottom: 1.25rem;
    }

    .arc-edition-nav h2 {
        font-size: 1.3rem;
        font-weight: 700;
        margin: 0 0 1rem;
    }

    .arc-btn-row {
        display: flex;
        flex-wrap: wrap;
        gap: .5rem;
        margin-bottom: 1.25rem;
    }

    .arc-btn {
        display: inline-block;
        padding: .55rem 1.5rem;
        border: 2px solid rgba(255, 255, 255, .3);
        border-radius: 4px;
        font-size: .9rem;
        font-weight: 700;
        letter-spacing: .06em;
        text-transform: uppercase;
        text-decoration: none;
        color: inherit;
        background: transparent;
        cursor: pointer;
        transition: background .15s, border-color .15s;
    }

    .arc-btn:hover {
        background: rgba(255, 255, 255, .08);
        border-color: rgba(255, 255, 255, .65);
        text-decoration: none;
        color: inherit;
    }

    .arc-btn.active {
        background: rgba(255, 255, 255, .12);
        border-color: rgba(255, 255, 255, .7);
    }

    .arc-panel {
        border: 1px solid rgba(255, 255, 255, .12);
        border-radius: 6px;
        margin-bottom: 2.5rem;
    }

    .arc-panel-body {
        padding: 1.5rem 1.25rem;
    }

    .arc-back {
        display: inline-flex;
        align-items: center;
        gap: .4rem;
        font-size: .82rem;
        font-weight: 600;
        letter-spacing: .05em;
        text-transform: uppercase;
        opacity: .5;
        text-decoration: none;
        color: inherit;
        margin-bottom: 1rem;
        transition: opacity .15s;
    }

    .arc-back:hover {
        opacity: .9;
        text-decoration: none;
        color: inherit;
    }

    .arc-collapsible {
        margin-top: 1rem;
    }

    .arc-collapsible summary {
        cursor: pointer;
        font-size: 1.5rem;
        font-weight: 800;
        padding: .6rem 0;
        border-bottom: 2px solid rgba(255, 255, 255, .1);
        margin-bottom: 1rem;
        list-style: none;
        display: flex;
        align-items: center;
        gap: .6rem;
        user-select: none;
        transition: opacity .15s;
    }

    .arc-collapsible summary::-webkit-details-marker {
        display: none;
    }

    .arc-collapsible summary:hover {
        opacity: .8;
    }

    .arc-collapsible summary::after {
        content: '▾';
        margin-left: auto;
        font-size: .85rem;
        opacity: .5;
        transition: transform .25s;
    }

    .arc-collapsible[open] summary::after {
        transform: rotate(180deg);
    }

        @keyframes countIn {
        from {
            opacity: 0;
            transform: translateY(10px);
        }

        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    .count {
        display: inline-block;
        font-weight: bold;
        opacity: 0;
        animation: countIn 0.5s ease-out forwards;
    }

    .counter-block:nth-child(1) .count {
        animation-delay: 0s;
    }

    .counter-block:nth-child(2) .count {
        animation-delay: 0.12s;
    }

    .counter-block:nth-child(3) .count {
        animation-delay: 0.24s;
    }

    .counter-block:nth-child(4) .count {
        animation-delay: 0.36s;
    }

.header-title {
  font-size: clamp(1.8rem, 3vw, 3rem) !important;
  line-height: 1.2;
}

.header-page {
  margin-top: 10px !important;
}

.header-subtitle {
  margin-top: 10px !important;
}
.video-wrapper {
    position: relative;
    width: 560px;
    height: 315px;
    overflow: hidden;
    margin: 0 auto;
    margin-top: 10px;
}

.video-wrapper iframe {
    width: 100%;
    height: 100%;
}

@media (max-width: 768px) {
    .video-wrapper {
        width: 100%;
        height: auto;
        padding-bottom: 56.25%;
    }

    .video-wrapper iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }
}

.ba-logo {
    width: 36%;
    max-width: 400px;
    height: auto;
}

@media (max-width: 768px) {
    .ba-logo {
        width: 70% !important;
    }
}

@media (max-width: 480px) {
    .ba-logo {
        width: 85% !important;
    }
}

.btn-social {
    width: 220px;   
    min-height: 120px;  
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
}

.btn-social .btn-text {
    margin-top: 10px;
    font-size: 16px;
    font-weight: 500;
}

.ba-search-hero {
    padding: 2rem 0 0rem;
}

.ba-search-hero>p {
    font-size: 14px;
    color: #888;
    margin: 0 0 0.75rem;
}

.ba-sh-wrap {
    display: flex;
    max-width: 560px;
    margin: 0 auto 0.75rem;
    border: 1px solid rgba(255, 255, 255, 0.15);
    border-radius: 10px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.05);
    transition: border-color 0.3s ease;
}

.ba-sh-wrap:focus-within {
    border: 1px solid rgba(255, 165, 0, 0.5);
}

.ba-sh-wrap input {
    flex: 1;
    border: none;
    background: transparent;
    padding: 0.7rem 1rem;
    font-size: 15px;
    color: #eee;
    outline: none;
}

.ba-sh-wrap button {
    padding: 0.7rem 1.1rem;
    border: none;
    border-left: 1px solid rgba(255, 255, 255, 0.1);
    background: rgba(255, 255, 255, 0.08);
    color: #eee;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.2s ease;
}

.ba-sh-wrap button:hover {
    background: #ffa500;
    color: #111;
}

.ba-sh-filters {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 8px;
    max-width: 560px;
    margin: 0 auto;
}

    .social-item {
        list-style: none;
        display: inline-block;
        margin-right: 8px;
    }

    .social-icon {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 32px;
        height: 32px;
        border-radius: 50%;
        border: 2px solid gray;
        text-decoration: none;
        color: #989898;
        font-size: 16px;
    }

    .social-icon:hover {
        color: white;
        border: 2px solid white;
    }


        .ba-year-switcher-container .dropdown-menu {
        min-width: 0;
        width: fit-content;
    }

    .ba-year-switcher-container .dropdown-item {
        padding: 0.25rem 0.75rem;
        font-size: 0.9rem;
    }

    .ba-year-switcher-container .dropdown {
        position: relative;
    }

    .ba-year-switcher-container .dropdown-menu {
        min-width: 0;
        width: fit-content;

        left: 50%;
        transform: translateX(-50%) !important;
        margin-top: 0.25rem;

        will-change: transform;
    }