/* =========================================================
   PiratenLimburg / CodyChat custom.css
   opgeschoonde versie met Jitsi + chat input fix
   ========================================================= */

/* ------------------------------
   Onderste menu opschonen
   ------------------------------ */
#my_menu{
  min-height:74px !important;
  height:auto !important;
  padding:10px 12px !important;
  display:flex !important;
  align-items:center !important;
  gap:0 !important;
}

#my_menu .footer_item{
  min-height:54px !important;
  padding:10px 10px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}

#my_menu .bcell_mid,
#my_menu > .footer_item:empty,
#my_menu #mstream_audio,
#my_menu #mstream_call,
#my_menu #rlist_open,
#mstream_audio,
#mstream_call,
#rlist_open,
#rlist_open i.fa-bars,
.footer_play,
img[src*="callmin.svg"],
img[src*="audiohide.svg"]{
  display:none !important;
  visibility:hidden !important;
  opacity:0 !important;
  pointer-events:none !important;
  width:0 !important;
  min-width:0 !important;
  max-width:0 !important;
  height:0 !important;
  min-height:0 !important;
  padding:0 !important;
  margin:0 !important;
  border:0 !important;
  flex:0 0 0 !important;
}

.my_menu{
  justify-content:flex-end !important;
}

/* ------------------------------
   Player bovenaan midden
   ------------------------------ */
#player_menu{
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;

  position:fixed !important;
  top:52px !important;
  left:50% !important;
  right:auto !important;
  bottom:auto !important;
  transform:translateX(-50%) !important;
  transform-origin:center top !important;

  width:1450px !important;
  max-width:79% !important;
  height:220px !important;
  max-height:220px !important;

  padding:6px 21px !important;
  border-radius:0 !important;
  background:rgba(0,0,76,0.54) !important;
  backdrop-filter:blur(12px) !important;
  border:1px solid rgba(255,255,255,0.5) !important;
  box-shadow:0 18px 60px rgba(0,0,0,.55) !important;
  overflow:hidden !important;
  z-index:85494 !important;
}

#player_menu_content,
#player_menu .float_content,
#player_menu .player_wrap{
  width:100% !important;
  margin:0 !important;
  padding:0 !important;
  overflow:visible !important;
}

#player_menu #current_player,
#player_menu .cur_play,
#player_menu .btable.bborder.vpad10{
  display:flex !important;
  align-items:center !important;
  width:100% !important;
  gap:16px !important;
  margin:0 !important;
  padding:0 !important;
  border:0 !important;
}

#player_menu #player_actual_status{ padding:3px !important; }
#player_menu #current_play_btn,
#player_menu #player_actual_status i{
  font-size:41px !important;
  line-height:1 !important;
}

#player_menu #current_station{
  font-size:24px !important;
  font-weight:700 !important;
  margin:0 !important;
}

#player_menu .text_xsmall{
  font-size:14px !important;
  margin:0 !important;
  opacity:.85 !important;
}

#player_menu .pl_nowplaying{
  display:flex !important;
  align-items:center !important;
  gap:19px !important;
  flex:1 1 auto !important;
  min-width:0 !important;
}

#player_menu #pl_cover.pl_cover,
.pl_cover{
  width:120px !important;
  height:120px !important;
  border-radius:7px !important;
  object-fit:cover !important;
}

#player_menu #pl_meta.pl_meta{
  min-width:0 !important;
  max-width:750px !important;
}

#player_menu #pl_artist,
#player_menu #pl_title{
  margin:0 !important;
  line-height:1.41 !important;
  overflow:hidden !important;
  text-overflow:ellipsis !important;
}

#player_menu #pl_artist{
  font-size:20px !important;
  opacity:.85 !important;
  white-space:nowrap !important;
}

#player_menu #pl_title{
  font-size:26px !important;
  font-weight:800 !important;
  white-space:normal !important;
  display:-webkit-box !important;
  -webkit-line-clamp:2 !important;
  -webkit-box-orient:vertical !important;
}

#player_menu .player_volume{
  display:flex !important;
  align-items:center !important;
  gap:10px !important;
  margin-left:auto !important;
  transform:scale(.81) !important;
  transform-origin:right center !important;
}

#player_menu #player_volume{
  width:420px !important;
}

body.cc_hide_player #player_menu,
body.cc_hide_player #dj_cam_wrap{
  display:none !important;
}

/* ruimte boven content voor vaste player */
#wrap_content{
  padding-top:285px !important;
}

@media (max-width:1100px){
  #player_menu{
    top:12px !important;
    width:94% !important;
    max-width:94% !important;
    height:170px !important;
    max-height:170px !important;
  }

  #player_menu #pl_cover.pl_cover{
    width:86px !important;
    height:86px !important;
  }

  #player_menu #pl_title{ font-size:18px !important; }
  #player_menu #pl_artist{ font-size:14px !important; }
  #player_menu #player_volume{ width:220px !important; }

  #wrap_content{
    padding-top:225px !important;
  }
}

/* ------------------------------
   LED banner
   ------------------------------ */
#pl_led_banner{
  width:100%;
  height:26px;
  overflow:hidden;
  background:#0b0000;
  border-top:1px solid #220000;
  border-bottom:1px solid #220000;
  box-shadow:inset 0 0 12px rgba(255,0,0,.5);
}

#pl_led_banner .pl_led_track{
  white-space:nowrap;
  display:inline-block;
  padding-left:100%;
  animation:pl_led_scroll 18s linear infinite;
  font-family:"Courier New", monospace;
  font-weight:bold;
  letter-spacing:2px;
  text-transform:uppercase;
  font-size:13px;
  color:#ff2a2a;
  text-shadow:
    0 0 4px rgba(255,0,0,.8),
    0 0 8px rgba(255,0,0,.6);
  line-height:26px;
}

@keyframes pl_led_scroll{
  0% { transform:translateX(0); }
  100% { transform:translateX(-100%); }
}

/* ------------------------------
   Username glow
   ------------------------------ */
.rank_70 .username,
.rank_80 .username,
.rank_90 .username,
.rank_100 .username{
  text-shadow:
    0 0 2px rgba(255,255,255,.6),
    0 0 8px rgba(255,0,128,.45),
    0 0 16px rgba(255,0,128,.30);
}

.username,
.user_name,
.busername,
.chatusername,
.name,
.user,
.userlink{
  text-shadow:
    0 0 2px rgba(255,255,255,.55),
    0 0 6px rgba(0,170,255,.45),
    0 0 12px rgba(0,170,255,.35),
    0 0 18px rgba(0,170,255,.25);
}

/* ------------------------------
   Jitsi strip
   ------------------------------ */
#pl_jitsi_bar{
  position:relative;
  margin:0 0 10px 0;
  padding:8px 10px 10px;
  border-top:1px solid rgba(255,255,255,.10);
  border-bottom:1px solid rgba(255,255,255,.10);
  background:linear-gradient(180deg, rgba(4,16,52,.96), rgba(2,8,30,.94));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04), 0 6px 18px rgba(0,0,0,.22);
  flex:0 0 auto !important;
  z-index:2 !important;
}

#pl_jitsi_bar[data-open="0"]{
  padding-bottom:8px;
}

#pl_jitsi_bar .pl_jitsi_head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:8px;
}

#pl_jitsi_bar .pl_jitsi_title{
  display:flex;
  align-items:center;
  gap:8px;
  color:#f2f5ff;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:1px;
  font-size:12px;
}

#pl_jitsi_bar .pl_jitsi_live{
  width:9px;
  height:9px;
  border-radius:50%;
  background:#ff3232;
  box-shadow:0 0 10px rgba(255,50,50,.9);
  animation:pl_jitsi_pulse 1.4s infinite;
}

#pl_jitsi_bar .pl_jitsi_controls{
  display:flex;
  align-items:center;
  gap:6px;
  flex-wrap:wrap;
}

#pl_jitsi_bar .pl_jitsi_btn{
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#fff;
  border-radius:8px;
  padding:6px 10px;
  font-size:12px;
  font-weight:700;
  line-height:1;
  cursor:pointer;
  text-decoration:none !important;
  transition:background .15s ease,border-color .15s ease,transform .15s ease;
}

#pl_jitsi_bar .pl_jitsi_btn:hover{
  background:rgba(255,255,255,.12);
  border-color:rgba(255,255,255,.24);
  transform:translateY(-1px);
}

#pl_jitsi_bar .pl_jitsi_btn.pl_jitsi_active{
  background:rgba(255,42,42,.18);
  border-color:rgba(255,42,42,.45);
  color:#ffd9d9;
}

#pl_jitsi_bar .pl_jitsi_frame_wrap{
  width:100%;

  /* videokader */
  aspect-ratio:16 / 9;

  min-height:180px;
  max-height:70vh;

  resize:vertical;
  overflow:hidden;

  border:1px solid rgba(255,255,255,.10);
  border-radius:12px;

  background:#000; /* zwarte balken ipv crop */
}

#pl_jitsi_bar[data-open="0"] .pl_jitsi_frame_wrap{
  display:none;
}

#pl_jitsi_bar #pl_jitsi_frame{
  display:block;
  width:100%;
  height:100%;
  border:0;

  /* behoud video verhouding */
  object-fit:contain;

  background:#000;
}

@keyframes pl_jitsi_pulse{
  0%{ transform:scale(1); opacity:1; }
  50%{ transform:scale(1.08); opacity:.72; }
  100%{ transform:scale(1); opacity:1; }
}

/* ------------------------------
   DEFINITIEVE chat + input fix
   ------------------------------ */
#chat_center,
#container_chat,
#wrap_chat{
  height:100% !important;
  min-height:0 !important;
}

#wrap_chat{
  display:flex !important;
  flex-direction:column !important;
  position:relative !important;
}

#chat_toping,
#pl_jitsi_bar,
#top_chat_container{
  flex:0 0 auto !important;
}

#warp_show_chat{
  flex:1 1 auto !important;
  height:auto !important;
  min-height:0 !important;
  overflow:hidden !important;
  padding-top:0 !important;
  padding-bottom:0 !important;
}

#container_show_chat,
#inside_wrap_chat{
  height:100% !important;
  min-height:0 !important;
  padding-top:0 !important;
  padding-bottom:0 !important;
}

#show_chat{
  height:100% !important;
  min-height:0 !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
  box-sizing:border-box !important;
  padding-bottom:0 !important;
}

#top_chat_container{
  position:relative !important;
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
  z-index:30 !important;
  overflow:visible !important;
}

#container_input,
#main_input,
#main_input_box,
#chat_content,
#chat_logs_container,
#chat_right_data{
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
  overflow:visible !important;
}

.input_table{
  display:flex !important;
  align-items:center !important;
  width:100% !important;
  min-height:52px !important;
  position:relative !important;
  z-index:9999 !important;
  box-sizing:border-box !important;
  flex-shrink:0 !important;
}

.td_input,
#main_input_box{
  flex:1 1 auto !important;
  min-width:0 !important;
  width:auto !important;
}

#content{
  width:100% !important;
  box-sizing:border-box !important;
}

#ok_sub_item,
#emo_item,
#inputt_right,
.send_btn{
  position:relative !important;
  z-index:10000 !important;
}

/* oude testfixes neutraliseren */
.jitsi-wrapper,
#jitsi-meet-wrap,
#jitsi_container,
#pl_jitsi_wrap{
  position:relative !important;
  z-index:2 !important;
  width:100% !important;
  max-height:none !important;
  min-height:0 !important;
  overflow:hidden !important;
  resize:none !important;
}

.jitsi-wrapper iframe,
#jitsi-meet-wrap iframe,
#jitsi_container iframe,
#pl_jitsi_wrap iframe{
  width:100% !important;
  height:100% !important;
  border:0 !important;
  display:block !important;
}

/* ------------------------------
   Mobiel
   ------------------------------ */
@media (max-width:900px), (pointer:coarse){
  #pl_led_track,
  .pl_led_track,
  .pl-led-track,
  #pl_led_banner,
  .pl_led_banner,
  .led_track,
  .led_banner,
  [data-led-track]{
    display:none !important;
    visibility:hidden !important;
    height:0 !important;
    max-height:0 !important;
    min-height:0 !important;
    margin:0 !important;
    padding:0 !important;
    overflow:hidden !important;
    animation:none !important;
    -webkit-animation:none !important;
  }
}

@media (max-width:768px){
  .chat_wrap,
  .chat_container{
    padding:4px !important;
  }

  input,
  textarea{
    font-size:16px !important;
  }

  #player_menu{
    top:8px !important;
    width:96% !important;
    max-width:96% !important;
    height:132px !important;
    max-height:132px !important;
    padding:6px 10px !important;
  }

  #player_menu #pl_cover.pl_cover{
    width:58px !important;
    height:58px !important;
  }

  #player_menu #pl_title{
    font-size:14px !important;
    -webkit-line-clamp:2 !important;
  }

  #player_menu #pl_artist,
  #player_menu .text_xsmall,
  #player_menu #current_station{
    font-size:12px !important;
  }

  #player_menu .player_volume{
    display:none !important;
  }

  #wrap_content{
    padding-top:165px !important;
  }

  #pl_jitsi_bar{
    padding:8px !important;
    margin-bottom:8px !important;
  }

  #pl_jitsi_bar .pl_jitsi_controls{
    width:100%;
  }

  #pl_jitsi_bar .pl_jitsi_btn{
    flex:1 1 auto;
    text-align:center;
    min-width:72px;
  }

  #pl_jitsi_bar .pl_jitsi_frame_wrap{
    height:220px;
    min-height:160px;
    max-height:55vh;
  }
}

#warp_show_chat{
  flex:1 1 auto !important;
  height:auto !important;
  min-height:0 !important;
  overflow-y:auto !important;
  overflow-x:hidden !important;
}
/* inputbalk altijd zichtbaar houden */
.input_table{
    position: sticky !important;
    bottom: 0 !important;
    z-index: 999 !important;
    background: #111 !important;
}
html, body{
    height:100%;
}

body{
    height:100dvh;
    overflow:hidden;
}

#container_show_chat{
    display:flex;
    flex-direction:column;
    height:100%;
}

#warp_show_chat{
    flex:1;
    min-height:0 !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling: touch;
}

.input_table{
    position:fixed;
    bottom:0;
    left:0;
    width:100%;
    z-index:999;
    background:#111;
}

#warp_show_chat{
    padding-bottom:80px;
}