/* IPTV Belgique Commerce v2.7.11 — Client Sidebar Authority Module
   Single source of truth for the customer portal sidebar.
   commerce.css and client-unified.css must not style .iptvbc-client-nav-* anymore. */

.iptvbc-client-unified-v279 > nav.iptvbc-client-nav-v279,
.iptvbc-client-unified-v273 > nav.iptvbc-client-nav-v279,
.iptvbc-client-unified-v279 .iptvbc-client-nav-v279,
.iptvbc-client-unified-v273 .iptvbc-client-nav-v279{
  grid-column:1;
  grid-row:1 / -1;
  position:relative;
  align-self:stretch;
  display:flex;
  flex-direction:column;
  gap:14px;
  min-width:0!important;
  min-height:100%;
  height:auto;
  padding:28px 20px 24px;
  background:linear-gradient(180deg,#ffffff 0%,#fbfdff 66%,#fffaf0 100%);
  border-right:1px solid #e6edf5;
  overflow:hidden;
  isolation:isolate;
  writing-mode:horizontal-tb;
  text-orientation:mixed;
}

.iptvbc-client-unified-v279 > nav.iptvbc-client-nav-v279:before,
.iptvbc-client-unified-v279 > nav.iptvbc-client-nav-v279:after,
.iptvbc-client-unified-v273 > nav.iptvbc-client-nav-v279:before,
.iptvbc-client-unified-v273 > nav.iptvbc-client-nav-v279:after,
.iptvbc-client-unified-v279 .iptvbc-client-nav-v279:before,
.iptvbc-client-unified-v279 .iptvbc-client-nav-v279:after,
.iptvbc-client-unified-v273 .iptvbc-client-nav-v279:before,
.iptvbc-client-unified-v273 .iptvbc-client-nav-v279:after{
  content:none!important;
  display:none!important;
}

.iptvbc-client-sidebar-brand-v279{
  position:relative;
  display:grid;
  grid-template-columns:44px minmax(0,1fr);
  grid-template-areas:"logo title" "logo subtitle";
  column-gap:13px;
  align-items:center;
  margin:0 0 12px;
  padding:2px 2px 20px;
  border-bottom:1px solid #e6edf5;
  color:#0f172a;
  isolation:isolate;
}
.iptvbc-client-sidebar-brand-v279:before{
  content:"";
  position:absolute;
  inset:-18px -18px auto auto;
  width:94px;
  height:94px;
  border-radius:999px;
  background:radial-gradient(circle,rgba(255,176,0,.18),transparent 68%);
  z-index:-1;
  pointer-events:none;
}
.iptvbc-client-sidebar-logo-v279{
  grid-area:logo;
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:17px;
  background:linear-gradient(135deg,#fff7df,#fff);
  border:1px solid rgba(255,176,0,.38);
  color:#ff7a00;
  font-size:17px;
  box-shadow:0 14px 28px rgba(255,176,0,.13);
}
.iptvbc-client-sidebar-brand-v279 strong{
  grid-area:title;
  display:block;
  color:#0f172a;
  font-size:17px;
  line-height:.98;
  font-weight:900;
  letter-spacing:-.052em;
  text-transform:uppercase;
  white-space:normal;
}
.iptvbc-client-sidebar-brand-v279 em{
  grid-area:subtitle;
  display:block;
  margin-top:4px;
  color:#64748b;
  font-size:12px;
  line-height:1.1;
  font-style:normal;
  font-weight:850;
}

.iptvbc-client-sidebar-links-v279{
  display:grid;
  gap:9px;
  min-width:0!important;
}
.iptvbc-client-sidebar-links-v279 a{
  position:relative;
  display:flex;
  align-items:center;
  gap:12px;
  min-height:48px;
  width:100%;
  padding:0 14px;
  border:1px solid transparent;
  border-radius:17px;
  background:transparent;
  color:#1264d8;
  box-shadow:none;
  text-decoration:none!important;
  font-size:15px;
  line-height:1.15;
  font-weight:900;
  white-space:normal;
  transition:background .22s ease,color .22s ease,box-shadow .22s ease,transform .22s ease,border-color .22s ease;
}
.iptvbc-client-sidebar-links-v279 a span[aria-hidden="true"]{
  width:31px;
  height:31px;
  flex:0 0 31px;
  display:grid;
  place-items:center;
  border-radius:12px;
  background:#f4f7fb;
  color:#64748b;
  font-size:15px;
  box-shadow:inset 0 0 0 1px rgba(226,232,240,.68);
  transition:background .22s ease,color .22s ease,box-shadow .22s ease,transform .22s ease;
}
.iptvbc-client-sidebar-links-v279 a:hover{
  background:#f8fafc;
  border-color:#e6edf5;
  transform:translateX(2px);
}
.iptvbc-client-sidebar-links-v279 a.is-active{
  color:#fff;
  background:linear-gradient(135deg,#ff304f 0%,#df0b35 55%,#c90e22 100%);
  border-color:rgba(239,51,64,.34);
  box-shadow:0 18px 42px rgba(239,51,64,.24);
}
.iptvbc-client-sidebar-links-v279 a.is-active span[aria-hidden="true"]{
  background:rgba(255,255,255,.18);
  color:#fff;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.24);
  transform:scale(1.03);
}
.iptvbc-client-nav-badge{
  margin-left:auto;
  min-width:20px;
  height:20px;
  display:inline-grid;
  place-items:center;
  border-radius:999px;
  background:#fff;
  color:#ef3340;
  font-size:11px;
  font-weight:900;
}

.iptvbc-client-sidebar-vip-v279{
  position:relative;
  display:grid;
  gap:8px;
  margin-top:auto;
  padding:20px 17px 18px;
  min-height:154px;
  border:1px solid #ffd796;
  border-radius:26px;
  background:
    radial-gradient(circle at 50% 0%,rgba(255,190,61,.34),transparent 32%),
    linear-gradient(180deg,#fff8e6 0%,#fffdf8 100%);
  color:#111827;
  text-decoration:none!important;
  box-shadow:0 18px 42px rgba(255,176,0,.12);
  overflow:hidden;
  isolation:isolate;
}
.iptvbc-client-sidebar-vip-v279:before{
  content:"";
  position:absolute;
  top:-34px;
  left:50%;
  width:96px;
  height:96px;
  transform:translateX(-50%);
  border-radius:999px;
  background:radial-gradient(circle,rgba(255,176,0,.38),transparent 66%);
  z-index:-1;
  pointer-events:none;
}
.iptvbc-client-sidebar-vip-v279:after{
  content:"";
  position:absolute;
  right:-42px;
  bottom:-48px;
  width:110px;
  height:110px;
  border-radius:999px;
  border:1px solid rgba(255,176,0,.22);
  z-index:-1;
  pointer-events:none;
}
.iptvbc-client-sidebar-vip-v279 > span{
  width:44px;
  height:44px;
  display:grid;
  place-items:center;
  border-radius:17px;
  background:linear-gradient(135deg,#ffcf66,#ff9f1c);
  color:#fff;
  font-size:20px;
  box-shadow:0 16px 34px rgba(255,145,0,.20);
}
.iptvbc-client-sidebar-vip-v279 strong{
  display:block;
  color:#111827;
  font-size:14px;
  line-height:1.18;
  font-weight:900;
  letter-spacing:-.02em;
}
.iptvbc-client-sidebar-vip-v279 em{
  display:block;
  color:#334155;
  font-style:normal;
  font-size:12.5px;
  line-height:1.42;
  font-weight:780;
}
.iptvbc-client-sidebar-vip-v279 b{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:max-content;
  max-width:100%;
  min-height:32px;
  margin-top:2px;
  padding:0 12px;
  border-radius:999px;
  background:#fff;
  border:1px solid rgba(255,176,0,.34);
  color:#9a5a00;
  font-size:11px;
  line-height:1;
  font-weight:900;
  box-shadow:0 10px 24px rgba(15,23,42,.055);
}
.iptvbc-client-sidebar-vip-v279:hover{
  transform:translateY(-2px);
  box-shadow:0 24px 58px rgba(255,176,0,.18);
}

@media(max-width:920px){
  .iptvbc-client-unified-v279 > nav.iptvbc-client-nav-v279,
  .iptvbc-client-unified-v273 > nav.iptvbc-client-nav-v279,
  .iptvbc-client-unified-v279 .iptvbc-client-nav-v279,
  .iptvbc-client-unified-v273 .iptvbc-client-nav-v279{
    grid-column:auto;
    grid-row:auto;
    position:relative;
    top:auto;
    min-height:0;
    display:flex;
    flex-direction:row;
    align-items:center;
    gap:8px;
    padding:12px 14px;
    overflow-x:auto;
    border-right:0;
    border-bottom:1px solid #e6edf5;
    background:#fff;
    scrollbar-width:none;
  }
  .iptvbc-client-unified-v279 > nav.iptvbc-client-nav-v279::-webkit-scrollbar,
  .iptvbc-client-unified-v273 > nav.iptvbc-client-nav-v279::-webkit-scrollbar{display:none;}
  .iptvbc-client-sidebar-brand-v279,
  .iptvbc-client-sidebar-vip-v279{display:none!important;}
  .iptvbc-client-sidebar-links-v279{
    display:flex;
    flex:0 0 auto;
    gap:8px;
  }
  .iptvbc-client-sidebar-links-v279 a{
    flex:0 0 auto;
    width:auto;
    min-height:42px;
    padding:0 12px;
    border-radius:999px;
    font-size:13px;
    white-space:nowrap;
  }
  .iptvbc-client-sidebar-links-v279 a span[aria-hidden="true"]{
    width:28px;
    height:28px;
    flex-basis:28px;
    border-radius:999px;
  }
}
