﻿/* === CHAT COMPACT BUBBLES === */
/* BLACK SIX COMPACT CHAT BUBBLES â€” injected refinement */
#chat-modal .chat-bubble:not(.is-system){
  min-width:min(245px,62vw)!important;
  max-width:min(34%,390px)!important;
  padding:12px 18px 25px!important;
  border-radius:16px!important;
  font-size:.88rem!important;
  line-height:1.34!important;
}
#chat-modal .chat-bubble:not(.is-system) p{font-size:.88rem!important;margin-top:8px!important;}
#chat-modal .chat-bubble.is-owner::after,#chat-modal .chat-bubble.is-admin::after,#chat-modal .chat-bubble.is-user::after,#chat-modal .chat-bubble.is-vip::after{width:34px!important;height:34px!important;top:-13px!important;right:-7px!important;border-radius:10px!important;font-size:.86rem!important;}
#chat-modal .chat-bubble.is-owner::before,#chat-modal .chat-bubble.is-admin::before,#chat-modal .chat-bubble.is-user::before,#chat-modal .chat-bubble.is-vip::before{width:20px!important;height:20px!important;}
#chat-modal .chat-bubble.is-owner::before,#chat-modal .chat-bubble.is-admin::before{left:-11px!important;}
#chat-modal .chat-bubble.is-user::before,#chat-modal .chat-bubble.is-vip::before{right:-11px!important;}
#chat-modal .bs-chat-sender{font-size:.70rem!important;padding-bottom:6px!important;width:calc(100% - 26px)!important;}
#chat-modal .chat-bubble-meta{font-size:.64rem!important;right:16px!important;bottom:8px!important;}
#chat-modal .bs-chat-role-pill{font-size:.50rem!important;padding:1px 5px!important;}
#chat-modal .bs-chat-message-row{margin:14px 0 24px!important;}
#chat-modal .bs-chat-avatar{width:34px!important;height:34px!important;margin-right:8px!important;}
#chat-modal .bs-chat-avatar::before{font-size:.98rem!important;}
@media(max-width:760px){
  #chat-modal .chat-bubble:not(.is-system){max-width:78%!important;padding:11px 14px 24px!important;font-size:.82rem!important;}
  #chat-modal .chat-bubble:not(.is-system) p{font-size:.82rem!important;}
  #chat-modal .chat-bubble.is-owner::after,#chat-modal .chat-bubble.is-admin::after,#chat-modal .chat-bubble.is-user::after,#chat-modal .chat-bubble.is-vip::after{width:30px!important;height:30px!important;top:-10px!important;right:-6px!important;border-radius:9px!important;}
  #chat-modal .bs-chat-avatar{width:28px!important;height:28px!important;margin-right:5px!important;}
  #chat-modal .bs-chat-avatar::before{font-size:.82rem!important;}
  #chat-modal .bs-chat-sender{font-size:.58rem!important;width:calc(100% - 22px)!important;}
}
@media(max-width:440px){#chat-modal .chat-bubble:not(.is-system){max-width:82%!important;}#chat-modal .bs-chat-message-row{margin:10px 0 20px!important;}}



/* BLACK SIX CHAT SUPPORT FIX â€” bolle compatte, immagini controllate, max text UX */
#chat-modal .chat-thread{
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding-bottom:28px!important;
  scroll-padding-bottom:32px!important;
}
#chat-modal .chat-bubble:not(.is-system){
  min-width:clamp(168px,22vw,245px)!important;
  max-width:min(30%,330px)!important;
  padding:10px 15px 23px!important;
  border-radius:15px!important;
}
#chat-modal .chat-bubble:not(.is-system) p{
  max-width:100%!important;
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
  white-space:pre-wrap!important;
  line-height:1.32!important;
}
#chat-modal .chat-bubble.has-media,
#chat-modal .chat-bubble:has(.chat-img-shell){
  width:auto!important;
  min-width:0!important;
  max-width:min(28%,300px)!important;
  padding:9px 10px 22px!important;
}
#chat-modal .chat-img-shell{
  width:auto!important;
  max-width:min(220px,100%)!important;
  max-height:240px!important;
  margin-top:7px!important;
  border-radius:13px!important;
}
#chat-modal .chat-image-attachment{
  width:auto!important;
  max-width:220px!important;
  max-height:220px!important;
  object-fit:contain!important;
}
#chat-modal .chat-input-area textarea{
  max-height:96px!important;
  overflow-y:auto!important;
  resize:none!important;
}
@media(max-width:760px){
  #chat-modal .chat-bubble:not(.is-system){max-width:76%!important;min-width:150px!important;padding:10px 13px 22px!important;}
  #chat-modal .chat-bubble.has-media,#chat-modal .chat-bubble:has(.chat-img-shell){max-width:70%!important;}
  #chat-modal .chat-img-shell{max-width:min(190px,100%)!important;max-height:200px!important;}
  #chat-modal .chat-image-attachment{max-width:190px!important;max-height:190px!important;}
}
@media(max-width:440px){
  #chat-modal .chat-bubble:not(.is-system){max-width:80%!important;}
  #chat-modal .chat-bubble.has-media,#chat-modal .chat-bubble:has(.chat-img-shell){max-width:76%!important;}
  #chat-modal .chat-image-attachment{max-width:170px!important;max-height:170px!important;}
}

/* BLACK SIX SAFE FIX: globo lingua + navbar dentro il contenitore, senza toccare le card */
.site-header .container.header-shell {
    width: min(1460px, calc(100% - 48px));
}

.nav-wrap {
    max-width: 100%;
}

@media (min-width: 1025px) {
    .nav-wrap {
        margin-top: 42px !important;
    }
}

.bs-lang-trigger .bs-gear-wrap,
.bs-lang-trigger .bs-gear-icon,
.bs-lang-trigger .bs-globe-badge {
    display: none !important;
}

.bs-lang-trigger .bs-globe-wrap {
    position: relative;
    width: 22px;
    height: 22px;
    display: inline-grid !important;
    place-items: center;
}

.bs-lang-trigger .bs-globe-icon {
    display: block !important;
    font-size: 1.14rem;
    color: rgba(247,242,232,.95);
    filter: drop-shadow(0 0 12px rgba(244,212,140,.18));
    transition: transform .22s ease, color .22s ease;
}

.bs-lang-trigger .bs-globe-shine {
    position: absolute;
    inset: -3px;
    border-radius: 999px;
    border: 1px solid rgba(244,212,140,.18);
    box-shadow: inset 0 0 10px rgba(244,212,140,.08), 0 0 12px rgba(244,212,140,.06);
    pointer-events: none;
}

.bs-lang-fab.is-open .bs-globe-icon,
.bs-lang-trigger:hover .bs-globe-icon {
    color: var(--gold-soft);
    transform: rotate(-10deg) scale(1.04);
}

@media (min-width: 1151px) {
    .nav-wrap {
        gap: 16px !important;
        padding-inline: 16px !important;
    }
    .brand {
        flex: 0 0 auto !important;
    }
    .nav-links {
        flex: 1 1 auto !important;
        margin-left: 22px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: flex-end !important;
        gap: clamp(16px, 1.25vw, 24px) !important;
        min-width: 0 !important;
        flex-wrap: wrap !important;
    }
    .nav-links > a,
    .nav-links > .telegram-trigger,
    .nav-links > .bs-lang-fab {
        flex: 0 0 auto !important;
        margin: 0 !important;
        white-space: nowrap !important;
    }
    .nav-links > .bs-lang-fab {
        margin-left: 4px !important;
    }
}

@media (min-width: 1151px) and (max-width: 1280px) {
    .site-header .container.header-shell {
        width: min(100%, calc(100% - 28px));
    }
    .nav-links {
        gap: 12px !important;
        margin-left: 14px !important;
    }
    .nav-links > a,
    .nav-links > .telegram-trigger {
        font-size: .64rem !important;
        letter-spacing: .08em !important;
    }
    .brand-copy strong {
        font-size: 1.34rem !important;
    }
    .brand-mark {
        width: 42px !important;
        height: 42px !important;
    }
}

/* === BROADCAST MODAL === */
#broadcast-modal-shell.bs-broadcast-shell {
    position: fixed;
    inset: 0;
    z-index: 10050;
    display: grid;
    place-items: center;
    padding: max(22px, env(safe-area-inset-top)) max(18px, env(safe-area-inset-right)) max(22px, env(safe-area-inset-bottom)) max(18px, env(safe-area-inset-left));
    background: rgba(0, 0, 0, 0.72);
    backdrop-filter: blur(14px);
}
#broadcast-modal-shell[hidden] { display: none !important; }
.bs-broadcast-card {
    position: relative;
    width: min(75vw, 1120px);
    max-height: min(78vh, 760px);
    overflow: auto;
    border-radius: 34px;
    border: 1px solid rgba(244, 212, 140, 0.18);
    background: radial-gradient(circle at top right, rgba(255, 143, 82, 0.18), transparent 30%),
                radial-gradient(circle at bottom left, rgba(122, 217, 255, 0.10), transparent 34%),
                linear-gradient(180deg, rgba(18, 22, 31, 0.985), rgba(7, 9, 15, 0.99));
    box-shadow: 0 34px 90px rgba(0,0,0,.62), inset 0 1px 0 rgba(255,255,255,.07);
    padding: clamp(28px, 4vw, 52px);
}
.bs-broadcast-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    pointer-events: none;
    background: linear-gradient(135deg, rgba(255,255,255,.09), transparent 32%);
}
.bs-broadcast-close {
    position: absolute;
    top: 18px;
    right: 18px;
    z-index: 2;
    width: 42px;
    height: 42px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.12);
    background: rgba(8,10,15,.88);
    color: rgba(247,242,232,.92);
    cursor: pointer;
    display: inline-grid;
    place-items: center;
    box-shadow: 0 14px 30px rgba(0,0,0,.36), inset 0 1px 0 rgba(255,255,255,.06);
}
.bs-broadcast-close:hover { color: var(--gold-soft); border-color: rgba(244,212,140,.36); }
.bs-broadcast-kicker {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(244,212,140,.20);
    background: rgba(244,212,140,.075);
    color: var(--gold-soft);
    font-size: .74rem;
    font-weight: 900;
    letter-spacing: .16em;
    text-transform: uppercase;
}
.bs-broadcast-title {
    margin: 18px 52px 14px 0;
    font-family: "Bebas Neue", sans-serif;
    font-size: clamp(2.9rem, 7vw, 6.2rem);
    line-height: .96;
    letter-spacing: .045em;
    color: var(--text);
}
.bs-broadcast-message {
    margin: 0;
    padding: 22px 24px;
    border-radius: 24px;
    border: 1px solid rgba(255,255,255,.09);
    background: rgba(255,255,255,.04);
    color: rgba(247,242,232,.90);
    font-size: clamp(1rem, 1.45vw, 1.28rem);
    line-height: 1.75;
    white-space: pre-wrap;
}
.bs-broadcast-meta {
    margin-top: 18px;
    color: rgba(255,255,255,.58);
    font-size: .84rem;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}
@media (max-width: 820px) {
    .bs-broadcast-card { width: min(100%, 94vw); max-height: 82vh; border-radius: 26px; padding: 26px 20px; }
    .bs-broadcast-title { margin-right: 48px; }
}

/* === CHAT LAYOUT HARD FIX === */
/* BLACK SIX CHAT â€” hard layout fix: supporto stabile, niente overlay input, bolle compatte */
#chat-modal .bs-social-chat-card.chat-modal-card{
  display:grid!important;
  grid-template-rows:auto auto auto auto auto minmax(0,1fr) auto auto!important;
  min-height:min(88dvh,720px)!important;
  max-height:calc(100dvh - 24px)!important;
  overflow:hidden!important;
}
#chat-modal .chat-thread{
  grid-row:auto!important;
  align-self:stretch!important;
  min-height:0!important;
  height:100%!important;
  max-height:none!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  box-sizing:border-box!important;
  padding:18px 46px 30px 24px!important;
  margin:0 14px!important;
}
#chat-modal .chat-input-area{
  position:relative!important;
  z-index:6!important;
  flex:0 0 auto!important;
  margin:10px 14px 14px!important;
  box-sizing:border-box!important;
}
#chat-modal .bs-chat-message-row{
  width:100%!important;
  max-width:100%!important;
  box-sizing:border-box!important;
}
#chat-modal .bs-chat-message-row.is-mine{
  padding-right:22px!important;
}
#chat-modal .bs-chat-message-row.is-vip-row:not(.is-mine){
  padding-left:8px!important;
  justify-content:flex-start!important;
}
#chat-modal .bs-chat-message-row.is-admin-row{
  padding-left:8px!important;
}
#chat-modal .chat-bubble:not(.is-system){
  box-sizing:border-box!important;
  min-width:clamp(150px,20vw,220px)!important;
  max-width:min(32%,310px)!important;
  padding:9px 13px 22px!important;
  border-radius:14px!important;
  font-size:.84rem!important;
  line-height:1.30!important;
}
#chat-modal .chat-bubble:not(.is-system) p{
  margin:7px 0 0!important;
  font-size:.84rem!important;
  line-height:1.30!important;
  overflow-wrap:anywhere!important;
  word-break:break-word!important;
  white-space:pre-wrap!important;
}
#chat-modal .bs-chat-sender{
  font-size:.60rem!important;
  line-height:1.1!important;
  padding-bottom:5px!important;
  width:calc(100% - 22px)!important;
}
#chat-modal .bs-chat-role-pill{font-size:.46rem!important;padding:1px 5px!important;}
#chat-modal .chat-bubble-meta{font-size:.58rem!important;right:12px!important;bottom:7px!important;}
#chat-modal .chat-bubble.is-owner::after,
#chat-modal .chat-bubble.is-admin::after,
#chat-modal .chat-bubble.is-user::after,
#chat-modal .chat-bubble.is-vip::after{
  width:28px!important;height:28px!important;top:-10px!important;right:-5px!important;border-radius:9px!important;font-size:.74rem!important;
}
#chat-modal .chat-bubble.is-owner::before,
#chat-modal .chat-bubble.is-admin::before,
#chat-modal .chat-bubble.is-user::before,
#chat-modal .chat-bubble.is-vip::before{
  width:16px!important;height:16px!important;
}
#chat-modal .chat-bubble.is-user::before,
#chat-modal .chat-bubble.is-vip::before{right:-8px!important;}
#chat-modal .chat-bubble.is-owner::before,
#chat-modal .chat-bubble.is-admin::before{left:-8px!important;}
#chat-modal .chat-bubble.has-media,
#chat-modal .chat-bubble:has(.chat-img-shell){
  max-width:min(32%,290px)!important;
  min-width:0!important;
  padding:8px 9px 21px!important;
}
#chat-modal .chat-img-shell{max-width:min(190px,100%)!important;max-height:210px!important;overflow:hidden!important;border-radius:12px!important;}
#chat-modal .chat-image-attachment{display:block!important;max-width:190px!important;max-height:190px!important;width:auto!important;height:auto!important;object-fit:contain!important;}
#chat-modal #chat-input{maxlength:350;}
#chat-modal .chat-input-area textarea{
  min-height:44px!important;
  max-height:88px!important;
  overflow-y:auto!important;
  resize:none!important;
}
@media(max-width:760px){
  #chat-modal .bs-social-chat-card.chat-modal-card{height:calc(100dvh - 14px)!important;max-height:calc(100dvh - 14px)!important;}
  #chat-modal .chat-thread{padding:14px 32px 24px 14px!important;margin:0 9px!important;}
  #chat-modal .bs-chat-message-row.is-mine,#chat-modal .bs-chat-message-row.is-vip-row{padding-right:14px!important;}
  #chat-modal .chat-bubble:not(.is-system){max-width:76%!important;min-width:135px!important;padding:9px 12px 21px!important;font-size:.80rem!important;}
  #chat-modal .chat-bubble:not(.is-system) p{font-size:.80rem!important;}
  #chat-modal .chat-bubble.has-media,#chat-modal .chat-bubble:has(.chat-img-shell){max-width:70%!important;}
  #chat-modal .chat-img-shell{max-width:min(165px,100%)!important;max-height:180px!important;}
  #chat-modal .chat-image-attachment{max-width:165px!important;max-height:165px!important;}
  #chat-modal .chat-input-area{margin:8px 9px 10px!important;}
}
@media(max-width:440px){
  #chat-modal .chat-bubble:not(.is-system){max-width:82%!important;}
  #chat-modal .chat-bubble.has-media,#chat-modal .chat-bubble:has(.chat-img-shell){max-width:78%!important;}
}

/* === CHAT SAME LAYOUT FINAL FIX === */
/* BLACK SIX FINAL â€” Supporto e Community con IDENTICO telaio/layout */
#chat-modal .bs-social-chat-card.chat-modal-card{
  width:min(96vw,980px)!important;
  height:min(88dvh,820px)!important;
  min-height:min(88dvh,820px)!important;
  max-height:calc(100dvh - 24px)!important;
  display:grid!important;
  grid-template-rows:auto auto 44px 0 auto minmax(0,1fr) auto 18px!important;
  overflow:hidden!important;
  box-sizing:border-box!important;
}

/* La riga informativa Community resta riservata nello spazio anche in Supporto:
   cosÃ¬ il box messaggi non cambia altezza quando si passa da una chat all'altra. */
#chat-modal #group-chat-privacy-note,
#chat-modal #group-chat-privacy-note[hidden]{
  display:block!important;
  height:0!important;
  min-height:0!important;
  max-height:0!important;
  margin:0!important;
  padding:0!important;
  border:0!important;
  overflow:hidden!important;
  opacity:0!important;
  visibility:hidden!important;
  pointer-events:none!important;
}
#chat-modal:has([data-chat-tab="group"].is-active) #group-chat-privacy-note{
  display:block!important;
  height:0!important;
  margin:0!important;
  padding:0!important;
  opacity:0!important;
  visibility:hidden!important;
}

#chat-modal .bs-social-chat-head.chat-modal-head{
  min-height:78px!important;
  max-height:78px!important;
  box-sizing:border-box!important;
}
#chat-modal .bs-chat-tabs{
  min-height:88px!important;
  max-height:88px!important;
  box-sizing:border-box!important;
}
#chat-modal .bs-chat-context-row{
  height:44px!important;
  min-height:44px!important;
  max-height:44px!important;
  padding:0 18px!important;
  box-sizing:border-box!important;
}
#chat-modal .chat-thread{
  height:100%!important;
  min-height:0!important;
  max-height:none!important;
  margin:0 14px!important;
  padding:18px 46px 30px 24px!important;
  align-self:stretch!important;
  box-sizing:border-box!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
}
#chat-modal .bs-chat-selected-packages[hidden]{display:none!important;}
#chat-modal .bs-ticket-panel[hidden]{display:none!important;}
#chat-modal .bs-ticket-panel{
  margin:10px 14px 0!important;
  padding:12px!important;
  border:1px solid rgba(244,212,140,.18)!important;
  border-radius:18px!important;
  background:linear-gradient(135deg,rgba(244,212,140,.10),rgba(0,229,255,.045))!important;
  display:grid!important;
  gap:10px!important;
}
#chat-modal .bs-ticket-status{
  color:#d8e4ee!important;
  font-size:.78rem!important;
  line-height:1.35!important;
}
#chat-modal .bs-ticket-status strong{color:#f4d48c!important;}
#chat-modal .bs-ticket-form[hidden]{display:none!important;}
#chat-modal .bs-ticket-form{display:grid!important;gap:9px!important;}
#chat-modal .bs-ticket-grid{display:grid!important;grid-template-columns:1fr 1fr!important;gap:9px!important;}
#chat-modal .bs-ticket-grid label{display:grid!important;gap:5px!important;color:#9fb0bd!important;font-size:.68rem!important;font-weight:900!important;text-transform:uppercase!important;letter-spacing:.04em!important;}
#chat-modal .bs-ticket-panel select,
#chat-modal .bs-ticket-panel textarea{
  width:100%!important;
  border:1px solid rgba(255,255,255,.10)!important;
  border-radius:12px!important;
  background:rgba(7,11,18,.82)!important;
  color:#f7f2e8!important;
  padding:10px 11px!important;
  outline:none!important;
  box-sizing:border-box!important;
}
#chat-modal .bs-ticket-panel textarea{min-height:62px!important;max-height:86px!important;resize:vertical!important;text-transform:none!important;font-size:.84rem!important;}
#chat-modal .bs-ticket-panel textarea{
  min-height:78px!important;
  max-height:118px!important;
  line-height:1.45!important;
}
#chat-modal .bs-ticket-panel button{
  justify-self:end!important;
  display:inline-flex!important;
  align-items:center!important;
  gap:8px!important;
  border:0!important;
  border-radius:13px!important;
  padding:10px 14px!important;
  background:linear-gradient(135deg,#f4d48c,#ff8f52)!important;
  color:#05070b!important;
  font-weight:900!important;
  cursor:pointer!important;
}
#chat-modal .bs-ticket-panel button:disabled{opacity:.55!important;cursor:not-allowed!important;}
#chat-modal .bs-ticket-wait-card{
  width:min(720px, 82%)!important;
  margin:18px auto 0!important;
  padding:13px 18px!important;
  border-radius:999px!important;
  border:1px solid rgba(244,212,140,.24)!important;
  background:
    linear-gradient(135deg,rgba(244,212,140,.14),rgba(0,168,132,.08)),
    rgba(6,12,16,.72)!important;
  box-shadow:0 16px 40px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.06)!important;
  color:#c5d2dc!important;
  text-align:center!important;
  line-height:1.45!important;
}
#chat-modal .bs-ticket-wait-card .bs-vip-pill{
  margin-right:8px!important;
  background:rgba(244,212,140,.18)!important;
  border-color:rgba(244,212,140,.32)!important;
  color:#f4d48c!important;
  box-shadow:0 0 18px rgba(244,212,140,.08)!important;
}
#chat-modal .bs-ticket-wait-text{
  color:#aebdca!important;
  font-size:.78rem!important;
}
#chat-modal .chat-input-area[hidden]{display:none!important;}
#chat-modal .chat-input-area{
  height:72px!important;
  min-height:72px!important;
  max-height:72px!important;
  margin:10px 14px 14px!important;
  padding:8px 10px!important;
  box-sizing:border-box!important;
  display:flex!important;
  align-items:center!important;
}
#chat-modal .chat-input-area textarea{
  height:54px!important;
  min-height:54px!important;
  max-height:54px!important;
  overflow-y:auto!important;
  resize:none!important;
  box-sizing:border-box!important;
}
#chat-modal #chat-feedback{
  height:18px!important;
  min-height:18px!important;
  max-height:18px!important;
  margin:-10px 14px 0!important;
  overflow:hidden!important;
}

/* Stesse proporzioni bolle in Supporto e Community */
#chat-modal .bs-chat-message-row{width:100%!important;max-width:100%!important;box-sizing:border-box!important;}
#chat-modal .bs-chat-message-row.is-mine,
#chat-modal .bs-chat-message-row.is-vip-row{justify-content:flex-end!important;padding-right:22px!important;}
#chat-modal .bs-chat-message-row.is-admin-row{justify-content:flex-start!important;padding-left:8px!important;}
#chat-modal .chat-bubble:not(.is-system):not(.bs-vip-lock-panel):not(.bs-vip-status-card){
  min-width:clamp(150px,20vw,220px)!important;
  max-width:min(32%,310px)!important;
}
#chat-modal .chat-bubble.has-media,
#chat-modal .chat-bubble:has(.chat-img-shell){max-width:min(32%,290px)!important;}

@media(max-width:760px){
  #chat-modal .bs-social-chat-card.chat-modal-card{
    width:calc(100vw - 14px)!important;
    height:calc(100dvh - 14px)!important;
    min-height:calc(100dvh - 14px)!important;
    max-height:calc(100dvh - 14px)!important;
    grid-template-rows:auto auto 40px 0 auto minmax(0,1fr) auto 16px!important;
  }
  #chat-modal .bs-social-chat-head.chat-modal-head{min-height:66px!important;max-height:66px!important;}
  #chat-modal .bs-chat-tabs{min-height:64px!important;max-height:64px!important;}
  #chat-modal .bs-chat-context-row{height:40px!important;min-height:40px!important;max-height:40px!important;padding:0 12px!important;}
  #chat-modal .bs-ticket-grid{grid-template-columns:1fr!important;}
  #chat-modal .chat-thread{margin:0 9px!important;padding:14px 32px 24px 14px!important;}
  #chat-modal .chat-input-area{height:66px!important;min-height:66px!important;max-height:66px!important;margin:8px 9px 10px!important;}
  #chat-modal .chat-input-area textarea{height:50px!important;min-height:50px!important;max-height:50px!important;}
  #chat-modal .bs-chat-message-row.is-mine,#chat-modal .bs-chat-message-row.is-vip-row{padding-right:14px!important;}
  #chat-modal .chat-bubble:not(.is-system):not(.bs-vip-lock-panel):not(.bs-vip-status-card){max-width:76%!important;min-width:135px!important;}
}

/* === CHAT MOBILE WHATSAPP FULLSCREEN === */
/* BLACK SIX MOBILE CHAT â€” WhatsApp-like full screen only on phones */
@media (max-width: 760px) {
  body.modal-open:has(#chat-modal:not([hidden])) {
    overflow: hidden !important;
    height: 100dvh !important;
    touch-action: none;
  }

  #chat-modal.modal-shell {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    max-height: 100dvh !important;
    padding: 0 !important;
    display: block !important;
    overflow: hidden !important;
    background:
      radial-gradient(circle at 10% 0%, rgba(244,212,140,.10), transparent 28%),
      radial-gradient(circle at 100% 10%, rgba(0,255,232,.08), transparent 30%),
      #05080d !important;
  }

  #chat-modal .modal-backdrop {
    display: none !important;
  }

  #chat-modal .bs-social-chat-card.chat-modal-card {
    position: fixed !important;
    inset: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    max-height: 100dvh !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    display: grid !important;
    grid-template-rows:
      auto
      auto
      36px
      0
      auto
      minmax(0, 1fr)
      auto
      0 !important;
    overflow: hidden !important;
    box-sizing: border-box !important;
    background:
      radial-gradient(circle at 15% 4%, rgba(244,212,140,.11), transparent 30%),
      radial-gradient(circle at 95% 0%, rgba(0,168,132,.12), transparent 32%),
      linear-gradient(180deg, #101820 0%, #061015 100%) !important;
    box-shadow: none !important;
  }

  #chat-modal .bs-social-chat-head.chat-modal-head {
    min-height: 58px !important;
    max-height: none !important;
    padding:
      max(10px, env(safe-area-inset-top))
      max(12px, env(safe-area-inset-right))
      9px
      max(12px, env(safe-area-inset-left)) !important;
    border-bottom: 1px solid rgba(255,255,255,.07) !important;
    background: linear-gradient(180deg, rgba(23,34,42,.98), rgba(13,20,27,.98)) !important;
    backdrop-filter: blur(16px) saturate(130%) !important;
  }

  #chat-modal .bs-social-logo {
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
  }

  #chat-modal .bs-social-title-wrap {
    gap: 10px !important;
    min-width: 0 !important;
  }

  #chat-modal .bs-social-chat-head h2 {
    font-size: .98rem !important;
    line-height: 1.08 !important;
    letter-spacing: .01em !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-width: calc(100vw - 106px) !important;
  }

  #chat-modal .bs-social-chat-head p {
    display: block !important;
    margin-top: 2px !important;
    font-size: .68rem !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-width: calc(100vw - 106px) !important;
  }

  #chat-modal .chat-modal-dismiss {
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    min-height: 38px !important;
    border-radius: 50% !important;
  }

  #chat-modal .bs-chat-tabs {
    min-height: 54px !important;
    max-height: 54px !important;
    padding: 7px 9px !important;
    gap: 7px !important;
    background: rgba(5,9,14,.92) !important;
  }

  #chat-modal .bs-chat-tab {
    min-height: 40px !important;
    height: 40px !important;
    padding: 6px 8px !important;
    border-radius: 999px !important;
    font-size: .74rem !important;
  }

  #chat-modal .bs-chat-tab .bs-tab-icon {
    width: 23px !important;
    height: 23px !important;
    font-size: .76rem !important;
  }

  #chat-modal .bs-chat-context-row {
    height: 36px !important;
    min-height: 36px !important;
    max-height: 36px !important;
    padding: 0 10px !important;
    background: rgba(6,12,18,.88) !important;
    border-bottom: 1px solid rgba(255,255,255,.045) !important;
  }

  #chat-modal .bs-chat-members {
    min-width: 56px !important;
    padding-left: 6px !important;
  }

  #chat-modal .bs-chat-members span {
    width: 21px !important;
    height: 21px !important;
    margin-left: -6px !important;
    font-size: .46rem !important;
    border-width: 1px !important;
  }

  #chat-modal #user-chat-id-display {
    font-size: .62rem !important;
    max-width: 48vw !important;
  }

  #chat-modal .bs-chat-live-pill {
    padding: 4px 7px !important;
    font-size: .54rem !important;
  }

  #chat-modal .chat-thread {
    height: 100% !important;
    margin: 0 !important;
    padding: 12px 11px 14px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background:
      radial-gradient(circle at 18% 12%, rgba(244,212,140,.035), transparent 28%),
      radial-gradient(circle at 86% 22%, rgba(0,255,232,.055), transparent 30%),
      linear-gradient(180deg, #071116, #04090d) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
  }

  #chat-modal .chat-thread::-webkit-scrollbar { display: none !important; }

  #chat-modal .bs-chat-message-row {
    margin: 8px 0 16px !important;
  }

  #chat-modal .bs-chat-message-row.is-mine,
  #chat-modal .bs-chat-message-row.is-vip-row {
    padding-right: 8px !important;
  }

  #chat-modal .bs-chat-message-row.is-admin-row {
    padding-left: 2px !important;
  }

  #chat-modal .chat-bubble:not(.is-system):not(.bs-vip-lock-panel):not(.bs-vip-status-card) {
    max-width: 82% !important;
    min-width: 126px !important;
    padding: 9px 12px 20px !important;
    border-radius: 14px !important;
    font-size: .80rem !important;
    line-height: 1.28 !important;
  }

  #chat-modal .chat-bubble:not(.is-system) p {
    font-size: .80rem !important;
    line-height: 1.28 !important;
  }

  #chat-modal .chat-bubble.has-media,
  #chat-modal .chat-bubble:has(.chat-img-shell) {
    max-width: 74% !important;
  }

  #chat-modal .chat-img-shell {
    max-width: min(184px, 100%) !important;
    max-height: 190px !important;
  }

  #chat-modal .chat-image-attachment {
    max-width: 184px !important;
    max-height: 184px !important;
  }

  #chat-modal .chat-input-area {
    height: auto !important;
    min-height: 64px !important;
    max-height: none !important;
    margin: 0 !important;
    padding:
      8px
      max(10px, env(safe-area-inset-right))
      max(8px, env(safe-area-inset-bottom))
      max(10px, env(safe-area-inset-left)) !important;
    border: 0 !important;
    border-top: 1px solid rgba(255,255,255,.07) !important;
    border-radius: 0 !important;
    background: linear-gradient(180deg, rgba(12,20,27,.98), rgba(9,16,22,.99)) !important;
    box-shadow: 0 -18px 42px rgba(0,0,0,.38) !important;
    display: grid !important;
    grid-template-columns: 42px minmax(0, 1fr) 42px !important;
    gap: 7px !important;
    align-items: end !important;
  }

  #chat-modal .chat-input-area .file-btn,
  #chat-modal .chat-input-area button {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    border-radius: 50% !important;
  }

  #chat-modal .chat-input-area textarea {
    width: 100% !important;
    height: 42px !important;
    min-height: 42px !important;
    max-height: 92px !important;
    padding: 11px 14px !important;
    border-radius: 21px !important;
    font-size: 16px !important;
    line-height: 1.25 !important;
    overflow-y: auto !important;
  }

  #chat-modal #chat-feedback {
    display: none !important;
  }
}

@media (max-width: 380px) {
  #chat-modal .bs-social-chat-head h2 { font-size: .90rem !important; }
  #chat-modal .bs-social-chat-head p { font-size: .62rem !important; }
  #chat-modal .bs-chat-tab { font-size: .68rem !important; }
  #chat-modal .chat-bubble:not(.is-system):not(.bs-vip-lock-panel):not(.bs-vip-status-card) { max-width: 86% !important; }
}

/* === CHAT HIDDEN STATE === */
#chat-modal[hidden] { display: none !important; visibility: hidden !important; }
body:not(.modal-open) #chat-modal[hidden] { display: none !important; }

/* === CHAT FINAL RECOVERY: input sempre visibile + support pill pulita === */
#chat-modal .bs-social-chat-card.chat-modal-card {
  width: min(94vw, 980px) !important;
  height: min(86dvh, 800px) !important;
  min-height: 0 !important;
  max-height: calc(100dvh - 34px) !important;
  display: grid !important;
  grid-template-rows: auto auto 44px 0 auto minmax(0, 1fr) 64px 0 !important;
  overflow: hidden !important;
}

#chat-modal .bs-social-chat-head.chat-modal-head {
  min-height: 76px !important;
  max-height: 76px !important;
}

#chat-modal .bs-chat-tabs {
  min-height: 78px !important;
  max-height: 78px !important;
  padding: 12px 14px !important;
}

#chat-modal .bs-chat-tab {
  min-height: 52px !important;
  height: 52px !important;
}

#chat-modal .bs-chat-context-row {
  height: 44px !important;
  min-height: 44px !important;
  max-height: 44px !important;
}

#chat-modal .bs-ticket-panel {
  margin: 8px 14px 0 !important;
  padding: 12px !important;
  gap: 8px !important;
  flex: 0 0 auto !important;
}

#chat-modal .bs-ticket-panel textarea {
  min-height: 76px !important;
  max-height: 96px !important;
  resize: none !important;
}

#chat-modal .bs-ticket-panel button {
  min-height: 42px !important;
  padding: 9px 14px !important;
}

#chat-modal .chat-thread {
  min-height: 0 !important;
  height: auto !important;
  max-height: none !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  margin: 8px 14px 0 !important;
  padding: 18px 34px 20px 18px !important;
  box-sizing: border-box !important;
}

#chat-modal .bs-vip-status-card {
  margin: 0 0 12px !important;
  padding: 10px 14px !important;
  border-radius: 16px !important;
  max-width: none !important;
  box-sizing: border-box !important;
}

#chat-modal .bs-vip-status-top,
#chat-modal .bs-vip-status-meta {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  min-height: 0 !important;
  line-height: 1.2 !important;
  overflow: visible !important;
  color: #dfe8ef !important;
}

#chat-modal .bs-vip-status-top {
  margin-bottom: 7px !important;
  font-size: .78rem !important;
}

#chat-modal .bs-vip-status-meta {
  margin-top: 6px !important;
  font-size: .68rem !important;
  color: #9fb0bd !important;
}

#chat-modal .bs-vip-status-bar {
  width: min(360px, 100%) !important;
  height: 8px !important;
}

#chat-modal .bs-ticket-wait-card {
  width: fit-content !important;
  max-width: min(680px, calc(100% - 28px)) !important;
  min-width: 0 !important;
  margin: 18px auto 0 !important;
  padding: 9px 14px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  text-align: left !important;
}

#chat-modal .bs-ticket-wait-card .bs-vip-pill {
  flex: 0 0 auto !important;
  margin: 0 !important;
}

#chat-modal .bs-ticket-wait-text {
  display: inline !important;
  font-size: .78rem !important;
  line-height: 1.35 !important;
}

#chat-modal .chat-input-area {
  height: 56px !important;
  min-height: 56px !important;
  max-height: 56px !important;
  margin: 8px 14px 0 !important;
  padding: 7px 9px !important;
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) 42px !important;
  align-items: center !important;
  gap: 8px !important;
  box-sizing: border-box !important;
}

#chat-modal .chat-input-area .file-btn,
#chat-modal .chat-input-area button {
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
}

#chat-modal .chat-input-area textarea {
  width: 100% !important;
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  padding: 11px 14px !important;
  box-sizing: border-box !important;
}

#chat-modal #chat-feedback {
  display: none !important;
}

@media (max-width: 760px) {
  #chat-modal .bs-social-chat-card.chat-modal-card {
    height: 100dvh !important;
    max-height: 100dvh !important;
    grid-template-rows: auto auto 36px 0 auto minmax(0, 1fr) auto 0 !important;
  }

  #chat-modal .bs-ticket-panel {
    margin: 8px 10px 0 !important;
    padding: 10px !important;
  }

  #chat-modal .bs-ticket-panel textarea {
    min-height: 68px !important;
    max-height: 78px !important;
  }

  #chat-modal .chat-thread {
    margin: 0 !important;
    padding: 12px 11px 14px !important;
  }

  #chat-modal .bs-ticket-wait-card {
    width: auto !important;
    max-width: calc(100% - 16px) !important;
    margin-top: 14px !important;
    align-items: flex-start !important;
    border-radius: 18px !important;
  }

  #chat-modal .chat-input-area {
    height: auto !important;
    min-height: 62px !important;
    max-height: none !important;
    margin: 0 !important;
    padding: 8px max(10px, env(safe-area-inset-right)) max(8px, env(safe-area-inset-bottom)) max(10px, env(safe-area-inset-left)) !important;
  }
}

/* ====== COMMUNITY CHAT â€” WHATSAPP STYLE ALIGNMENT ====== */
/* Messaggi propri a destra, altri a sinistra */
#chat-modal .bs-chat-message-row.is-vip-row:not(.is-mine) {
  justify-content: flex-start !important;
  padding-left: 4px !important;
  padding-right: 0 !important;
}
/* Bolla "mia" nella community â€” sfondo teal/cyan (distinto) */
#chat-modal .bs-chat-message-row.is-mine .chat-bubble.is-user,
#chat-modal .bs-chat-message-row.is-mine .chat-bubble.is-vip {
  border: 1px solid rgba(0,229,144,.68) !important;
  background:
    radial-gradient(circle at 92% 2%, rgba(0,229,144,.22), transparent 28%),
    linear-gradient(145deg, rgba(0,80,58,.60), rgba(4,11,16,.98) 76%) !important;
  box-shadow:
    0 0 0 1px rgba(0,229,144,.10),
    0 0 26px rgba(0,229,144,.26),
    0 18px 38px rgba(0,0,0,.38),
    inset 0 0 22px rgba(0,229,144,.06) !important;
}
/* Bolla altri VIP nella community â€” sfondo grigio scuro */
#chat-modal .bs-chat-message-row.is-vip-row:not(.is-mine) .chat-bubble.is-user,
#chat-modal .bs-chat-message-row.is-vip-row:not(.is-mine) .chat-bubble.is-vip {
  border: 1px solid rgba(160,180,200,.28) !important;
  background:
    radial-gradient(circle at 8% 2%, rgba(100,120,150,.18), transparent 28%),
    linear-gradient(145deg, rgba(18,24,32,.92), rgba(8,12,18,.98) 76%) !important;
  box-shadow:
    0 0 0 1px rgba(160,180,200,.06),
    0 12px 28px rgba(0,0,0,.36) !important;
}
/* Avatar VIP altri (non mine) â€” visibile a sinistra */
#chat-modal .bs-chat-message-row.is-vip-row:not(.is-mine) .bs-chat-avatar {
  display: grid !important;
}

/* ====== TICKET PANEL â€” DOOMSDAY GAME STYLE ====== */
#chat-modal .bs-ticket-panel {
  margin: 8px 10px 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  display: grid !important;
  gap: 0 !important;
}

#chat-modal .bs-ticket-status {
  margin: 0 4px 8px !important;
  padding: 9px 14px !important;
  border-radius: 12px !important;
  background: linear-gradient(135deg, rgba(244,212,140,.13), rgba(0,200,130,.07)) !important;
  border: 1px solid rgba(244,212,140,.22) !important;
  font-size: .76rem !important;
  color: #c5d2dc !important;
  position: relative !important;
  overflow: hidden !important;
}
#chat-modal .bs-ticket-status::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, #f4d48c, #ff8f52);
  border-radius: 3px 0 0 3px;
}

#chat-modal .bs-ticket-form[hidden] { display: none !important; }
#chat-modal .bs-ticket-form {
  display: grid !important;
  gap: 0 !important;
  background: linear-gradient(170deg, rgba(10,18,28,.97) 0%, rgba(5,10,16,.99) 100%) !important;
  border: 1px solid rgba(244,212,140,.20) !important;
  border-radius: 18px !important;
  padding: 14px 12px 12px !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow:
    0 0 40px rgba(244,184,68,.08),
    0 8px 32px rgba(0,0,0,.40),
    inset 0 1px 0 rgba(255,255,255,.05) !important;
}
/* decorazione grid Doomsday */
#chat-modal .bs-ticket-form::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(244,212,140,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(244,212,140,.04) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  border-radius: inherit;
}
/* Striscia header form */
#chat-modal .bs-ticket-form::after {
  content: 'âš  APRI TICKET SUPPORTO';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 24px;
  background: linear-gradient(90deg, rgba(244,164,60,.18), rgba(255,100,50,.10), transparent);
  border-bottom: 1px solid rgba(244,212,140,.12);
  border-radius: 17px 17px 0 0;
  font-size: .52rem;
  font-weight: 900;
  letter-spacing: .14em;
  color: rgba(244,212,140,.55);
  display: flex;
  align-items: center;
  padding-left: 12px;
  line-height: 24px;
  pointer-events: none;
}

#chat-modal .bs-ticket-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
  margin-top: 26px !important;
  margin-bottom: 8px !important;
}
#chat-modal .bs-ticket-grid label {
  display: grid !important;
  gap: 4px !important;
  font-size: .60rem !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: rgba(244,212,140,.70) !important;
}
#chat-modal .bs-ticket-panel select {
  width: 100% !important;
  background: rgba(5,10,16,.92) !important;
  border: 1px solid rgba(244,212,140,.22) !important;
  border-radius: 10px !important;
  color: #f0e6cc !important;
  padding: 9px 11px !important;
  font-size: .80rem !important;
  outline: none !important;
  box-sizing: border-box !important;
  cursor: pointer !important;
  transition: border-color .2s !important;
}
#chat-modal .bs-ticket-panel select:focus {
  border-color: rgba(244,212,140,.55) !important;
  box-shadow: 0 0 0 2px rgba(244,212,140,.10) !important;
}
#chat-modal .bs-ticket-panel select option {
  background: #080e16 !important;
}
#chat-modal .bs-ticket-panel textarea {
  width: 100% !important;
  background: rgba(5,10,16,.92) !important;
  border: 1px solid rgba(244,212,140,.18) !important;
  border-radius: 10px !important;
  color: #e8dcc8 !important;
  padding: 10px 12px !important;
  font-size: .82rem !important;
  line-height: 1.45 !important;
  outline: none !important;
  box-sizing: border-box !important;
  resize: none !important;
  min-height: 72px !important;
  max-height: 100px !important;
  margin-bottom: 8px !important;
  font-family: inherit !important;
  transition: border-color .2s !important;
}
#chat-modal .bs-ticket-panel textarea::placeholder {
  color: rgba(180,160,120,.45) !important;
}
#chat-modal .bs-ticket-panel textarea:focus {
  border-color: rgba(244,212,140,.45) !important;
  box-shadow: 0 0 0 2px rgba(244,212,140,.08) !important;
}
/* Bottone Doomsday style */
#chat-modal #support-ticket-open-btn {
  justify-self: stretch !important;
  width: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 9px !important;
  border: 0 !important;
  border-radius: 11px !important;
  padding: 12px 18px !important;
  background: linear-gradient(135deg, #e8b840 0%, #d4612a 100%) !important;
  color: #04070b !important;
  font-weight: 900 !important;
  font-size: .86rem !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  position: relative !important;
  overflow: hidden !important;
  box-shadow: 0 0 24px rgba(244,164,60,.35), 0 4px 14px rgba(0,0,0,.40) !important;
  transition: transform .12s, box-shadow .2s !important;
}
#chat-modal #support-ticket-open-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,.12) 0%, transparent 50%);
  border-radius: inherit;
}
#chat-modal #support-ticket-open-btn:hover:not(:disabled) {
  transform: translateY(-1px) !important;
  box-shadow: 0 0 36px rgba(244,164,60,.50), 0 6px 20px rgba(0,0,0,.45) !important;
}
#chat-modal #support-ticket-open-btn:disabled {
  opacity: .45 !important;
  cursor: not-allowed !important;
}

/* Separatori sezioni nel form */
#chat-modal .bs-ticket-pkg-separator {
  font-size: .58rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .10em;
  color: rgba(244,212,140,.40);
  padding: 4px 2px 2px;
  pointer-events: none;
}

/* ====== TICKET FORM ESPANSO (nessun ticket attivo) ====== */
/* Quando il chat-thread Ã¨ nascosto, il ticket panel occupa tutto lo spazio */
#chat-modal .bs-ticket-panel:has(~ #chat-thread[hidden]),
#chat-modal .bs-ticket-panel:has(~ #chat-thread[style*="display: none"]) {
  flex: 1 1 auto !important;
  align-self: stretch !important;
  overflow-y: auto !important;
}
/* Fallback: se :has non Ã¨ supportato, usa classe aggiunta via JS */
#chat-modal.no-ticket-thread .bs-ticket-panel {
  flex: 1 1 auto !important;
  align-self: stretch !important;
  overflow-y: auto !important;
}
/* grid-row espanso per il ticket panel */
#chat-modal .bs-social-chat-card:has(#chat-thread[hidden]) {
  grid-template-rows: auto auto 44px 0 1fr auto 18px !important;
}
#chat-modal .bs-social-chat-card:has(#chat-thread[hidden]) .bs-ticket-panel {
  min-height: 0 !important;
  height: 100% !important;
}
#chat-modal #chat-thread[hidden] {
  display: none !important;
}

/* ====== TICKET FORM â€” textarea espansa quando nessun thread ====== */
#chat-modal .bs-social-chat-card:has(#chat-thread[hidden]) #support-ticket-message {
  min-height: 140px !important;
  max-height: 260px !important;
}
/* Ticket panel: height 100% in modalitÃ  espansa */
#chat-modal .bs-social-chat-card:has(#chat-thread[hidden]) #support-ticket-panel {
  display: flex !important;
  flex-direction: column !important;
  justify-content: flex-start !important;
}
#chat-modal .bs-social-chat-card:has(#chat-thread[hidden]) .bs-ticket-form {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}
#chat-modal .bs-social-chat-card:has(#chat-thread[hidden]) .bs-ticket-form #support-ticket-message {
  flex: 1 !important;
}

/* ====== TICKET STATUS CARD â€” stato attesa / in lavorazione ====== */
#chat-modal .bs-ticket-status-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
#chat-modal .bs-ticket-status-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
#chat-modal .bs-ticket-status-label {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: .80rem;
  font-weight: 900;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #f4d48c;
  background: rgba(244,212,140,.12);
  border: 1px solid rgba(244,212,140,.28);
  border-radius: 999px;
  padding: 5px 12px;
}
#chat-modal .bs-ticket-status-label.is-active {
  color: #00e5a0;
  background: rgba(0,229,160,.12);
  border-color: rgba(0,229,160,.32);
}
#chat-modal .bs-ticket-status-cat {
  font-size: .72rem;
  color: #8fa4b5;
  font-weight: 700;
  letter-spacing: .04em;
}
#chat-modal .bs-ticket-status-pkg {
  font-size: .76rem;
  color: #c8d8e4;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  background: rgba(255,255,255,.04);
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,.07);
}
#chat-modal .bs-ticket-status-pkg i { color: #f4d48c; }
#chat-modal .bs-ticket-status-msg {
  font-size: .76rem;
  color: #8fa4b5;
  font-style: italic;
  line-height: 1.45;
  padding: 0 4px;
}
#chat-modal .bs-ticket-status-hint {
  font-size: .72rem;
  color: #6a8a9a;
  display: flex;
  align-items: flex-start;
  gap: 6px;
  line-height: 1.4;
  padding: 6px 10px;
  background: rgba(0,180,120,.06);
  border-radius: 8px;
  border: 1px solid rgba(0,180,120,.14);
}
#chat-modal .bs-ticket-status-hint i { color: #00b478; margin-top: 2px; flex: 0 0 auto; }

/* ====================================================
   BLACK SIX â€” FULL-PAGE CHAT + VOICE + EMOJI REACTIONS
   Inspired by Black Six chat architecture
   ==================================================== */

/* FULL-PAGE: sempre full-screen su tutti i device */
#chat-modal.modal-shell {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100dvh !important;
  padding: 0 !important;
  display: flex !important;
  align-items: stretch !important;
  justify-content: stretch !important;
  background: #030508 !important;
  z-index: 9998 !important;
}
#chat-modal[hidden] { display: none !important; }
#chat-modal .modal-backdrop { display: none !important; }
#chat-modal .bs-social-chat-card.chat-modal-card {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  max-width: 100vw !important;
  height: 100dvh !important;
  min-height: 100dvh !important;
  max-height: 100dvh !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  display: grid !important;
  grid-template-rows: auto auto 44px 0 auto minmax(0,1fr) auto 0 !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
  background:
    radial-gradient(circle at 15% 4%, rgba(244,212,140,.09), transparent 30%),
    radial-gradient(circle at 95% 0%, rgba(0,168,132,.10), transparent 32%),
    linear-gradient(180deg, #101820 0%, #061015 100%) !important;
  box-shadow: none !important;
}

/* chat-form grid: file | text | mic | send */
#chat-modal .chat-input-area {
  grid-template-columns: 42px minmax(0,1fr) 42px 42px !important;
}

/* ====================================================
   EMOJI REACTIONS â€” WhatsApp style
   ==================================================== */
.bs-reactions-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 4px;
}
.bs-reactions-bar.mine { justify-content: flex-end; }
.bs-msg-reaction {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 7px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.07);
  cursor: pointer;
  font-size: 13px;
  transition: transform .12s, border-color .15s;
  user-select: none;
}
.bs-msg-reaction:hover { transform: scale(1.10); border-color: rgba(244,212,140,.4); }
.bs-msg-reaction.my-reaction {
  border-color: rgba(244,212,140,.55);
  background: rgba(244,212,140,.14);
}
.bs-msg-reaction .rc { font-size: 10px; font-weight: 700; color: #a1a1aa; }
.bs-msg-reaction.my-reaction .rc { color: #f4d48c; }

.bs-emoji-picker {
  position: fixed;
  z-index: 99999;
  display: flex;
  gap: 4px;
  padding: 7px 10px;
  background: rgba(18,24,32,.97);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  box-shadow: 0 8px 32px rgba(0,0,0,.55);
  backdrop-filter: blur(16px);
  animation: pickIn .18s cubic-bezier(.16,1,.3,1);
}
@keyframes pickIn { from { opacity:0; transform: scale(.8) translateY(6px); } to { opacity:1; transform: scale(1) translateY(0); } }
.bs-emoji-picker button {
  width: 34px; height: 34px;
  border: 0; background: transparent;
  border-radius: 50%; cursor: pointer; font-size: 18px;
  display: flex; align-items: center; justify-content: center;
  transition: transform .12s, background .12s;
}
.bs-emoji-picker button:hover { background: rgba(255,255,255,.10); transform: scale(1.22); }

/* ====================================================
   VOICE MESSAGES
   ==================================================== */
.bs-voice-rec-bar {
  display: none;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: rgba(12,20,27,.98);
  border-top: 1px solid rgba(255,255,255,.07);
}
.bs-voice-rec-bar.is-active { display: flex !important; }
.bs-voice-pulse {
  width: 10px; height: 10px;
  border-radius: 50%; background: #ef4444;
  animation: vPulse .8s ease-in-out infinite;
  flex-shrink: 0;
}
@keyframes vPulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.7)} }
.bs-voice-waves {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 2px;
  height: 20px;
  overflow: hidden;
}
.vw {
  width: 2.5px;
  background: rgba(255,255,255,.38);
  border-radius: 2px;
  height: 8px;
  animation: vwave .6s ease-in-out infinite alternate;
  flex-shrink: 0;
}
@keyframes vwave { from { height: 4px; } to { height: 18px; } }
.bs-voice-timer {
  font-family: monospace;
  font-size: 12px;
  font-weight: 700;
  color: white;
  min-width: 34px;
  text-align: center;
}
.bs-voice-cancel, .bs-voice-send {
  width: 36px; height: 36px;
  border: 0; border-radius: 50%; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 15px; flex-shrink: 0;
  transition: background .15s, transform .12s;
}
.bs-voice-cancel { background: rgba(239,68,68,.18); color: #f87171; }
.bs-voice-cancel:hover { background: rgba(239,68,68,.32); transform: scale(1.08); }
.bs-voice-send { background: rgba(244,212,140,.85); color: #04070b; }
.bs-voice-send:hover { background: #f4d48c; transform: scale(1.08); }

/* Voice message bubble player â€” Black Six chat style */
.bs-voice-player {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 4px 0;
  min-width: 0;
  width: 100%;
  box-sizing: border-box;
  overflow: hidden;
}
.chat-bubble:has(.bs-voice-player) { min-width: 210px; }
@media (max-width: 480px) { .chat-bubble:has(.bs-voice-player) { min-width: 180px; } }

.bs-voice-play-btn {
  width: 36px; height: 36px; min-width: 36px; min-height: 36px;
  border-radius: 50%;
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font-size: 13px;
  transition: transform .15s, background .15s;
}
.bs-voice-play-btn:active { transform: scale(0.88); }
.chat-bubble.is-user  .bs-voice-play-btn,
.chat-bubble.is-vip   .bs-voice-play-btn  { background: rgba(0,0,0,.18); color: #fff; }
.chat-bubble.is-owner .bs-voice-play-btn,
.chat-bubble.is-admin .bs-voice-play-btn  { background: rgba(244,212,140,.20); color: #f4d48c; }
.chat-bubble.is-owner .bs-voice-play-btn:hover,
.chat-bubble.is-admin .bs-voice-play-btn:hover  { background: rgba(244,212,140,.36); }

.bs-voice-waveform {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 2px;
  height: 28px;
  min-width: 0;
  overflow: hidden;
}
.bs-voice-waveform-bar {
  width: 3px;
  border-radius: 99px;
  transition: background .12s;
  flex-shrink: 0;
}
@media (max-width: 480px) {
  .bs-voice-waveform { gap: 1.5px; }
  .bs-voice-waveform-bar { width: 2.5px; }
  .bs-voice-play-btn { width: 32px; height: 32px; min-width: 32px; min-height: 32px; }
}
@media (pointer: coarse) {
  .bs-voice-play-btn { min-height: 44px; min-width: 44px; width: 44px; height: 44px; }
}
/* Color: user side (own) */
.chat-bubble.is-user  .bs-voice-waveform-bar,
.chat-bubble.is-vip   .bs-voice-waveform-bar  { background: rgba(255,255,255,.22); }
.chat-bubble.is-user  .bs-voice-waveform-bar.played,
.chat-bubble.is-vip   .bs-voice-waveform-bar.played  { background: rgba(255,255,255,.75); }
/* Color: admin/owner side */
.chat-bubble.is-owner .bs-voice-waveform-bar,
.chat-bubble.is-admin .bs-voice-waveform-bar  { background: rgba(255,255,255,.16); }
.chat-bubble.is-owner .bs-voice-waveform-bar.played,
.chat-bubble.is-admin .bs-voice-waveform-bar.played  { background: #f4d48c; }

.bs-voice-dur {
  font-size: 11px;
  font-weight: 600;
  min-width: 32px;
  text-align: right;
  opacity: .65;
  flex-shrink: 0;
}
@media (max-width: 480px) { .bs-voice-dur { font-size: 10px; min-width: 26px; } }

/* ====================================================
   PHOTO VIEWER OVERLAY â€” full screen on tap
   ==================================================== */
.bs-photo-overlay {
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(0,0,0,.96);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 16px;
  animation: bsPhotoIn .18s ease;
}
.bs-photo-overlay.visible { display: flex; }
@keyframes bsPhotoIn { from { opacity:0; } to { opacity:1; } }
.bs-photo-overlay img {
  max-width: 95vw;
  max-height: 90dvh;
  max-height: 90vh;
  object-fit: contain;
  border-radius: 14px;
  box-shadow: 0 20px 60px rgba(0,0,0,.7);
  touch-action: pinch-zoom;
}
.bs-photo-close {
  position: absolute; top: 14px; right: 14px; z-index: 10;
  width: 40px; height: 40px;
  border: none; border-radius: 50%; cursor: pointer;
  background: rgba(255,255,255,.12);
  backdrop-filter: blur(10px);
  color: #fff; font-size: 17px;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, transform .15s;
}
.bs-photo-close:hover { background: rgba(255,255,255,.24); transform: scale(1.08); }

/* ====================================================
   CHAT PHOTO in bubble â€” tap-friendly
   ==================================================== */
.chat-image-attachment {
  border-radius: 14px !important;
  max-width: 100% !important;
  max-height: 260px !important;
  object-fit: cover !important;
  display: block !important;
  cursor: pointer !important;
  transition: transform .18s, opacity .18s !important;
}
.chat-image-attachment:active { transform: scale(.95) !important; opacity: .85 !important; }
@media (max-width: 480px) { .chat-image-attachment { max-height: 200px !important; } }

/* ====================================================
   VOICE MIC BUTTON in input bar
   ==================================================== */
#chat-mic-btn {
  width: 42px; height: 42px;
  min-width: 42px;
  border: 0;
  border-radius: 50%;
  background: transparent;
  color: rgba(255,255,255,.45);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  transition: color .15s, background .15s;
}
#chat-mic-btn:hover { color: #f4d48c; background: rgba(244,212,140,.10); }
#chat-mic-btn.is-recording { color: #ef4444; background: rgba(239,68,68,.14); }

/* Full-page chat header back-arrow button */
#chat-modal .bs-chat-back-btn {
  display: flex;
  width: 42px; height: 42px; min-width: 42px;
  align-items: center; justify-content: center;
  border: 0; background: transparent;
  color: rgba(255,255,255,.55); cursor: pointer;
  border-radius: 50%;
  font-size: 18px;
  transition: color .15s, background .15s;
  margin-right: 4px;
}
#chat-modal .bs-chat-back-btn:hover { color: white; background: rgba(255,255,255,.08); }

/* ====================================================
   BLACK SIX v2 â€” SINGLE COMMUNITY CHAT (no tabs)
   Max-width 900px centered, bubbles 68%, social style
   ==================================================== */

/* Hide old tab/ticket panel elements */
#chat-modal .bs-chat-tabs,
#chat-modal #bs-chat-tabs,
#chat-modal .bs-ticket-panel,
#chat-modal #support-ticket-panel,
#chat-modal #group-chat-privacy-note,
#chat-modal .bs-chat-tab,
#chat-modal .bs-vip-status-card { display: none !important; }

/* Simplified header */
#chat-modal .bs-social-chat-head.chat-modal-head {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 0 16px !important;
  min-height: 64px !important;
  max-height: 64px !important;
  border-bottom: 1px solid rgba(255,255,255,.07) !important;
  background: rgba(10,16,24,.97) !important;
}
.bs-chat-head-right {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
  flex-shrink: 0;
}

/* Context row compact */
#chat-modal .bs-chat-context-row {
  height: 36px !important;
  min-height: 36px !important;
  max-height: 36px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 0 16px !important;
  background: rgba(6,12,18,.90) !important;
  border-bottom: 1px solid rgba(255,255,255,.04) !important;
}

/* Chat grid: header + context + thread + voicebar + inputbar */
#chat-modal .bs-social-chat-card.chat-modal-card {
  grid-template-rows: 64px 36px minmax(0,1fr) auto auto 0 !important;
}

/* Thread: centered max 900px, wide enough */
#chat-modal .chat-thread {
  max-width: 900px !important;
  width: 100% !important;
  margin: 0 auto !important;
  padding: 20px 24px 24px !important;
  box-sizing: border-box !important;
  background: transparent !important;
}

/* WIDE BUBBLES â€” 68% max */
#chat-modal .chat-bubble:not(.is-system):not(.bs-vip-lock-panel) {
  min-width: clamp(140px, 22vw, 260px) !important;
  max-width: min(68%, 560px) !important;
  padding: 10px 14px 22px !important;
  border-radius: 16px !important;
  font-size: .88rem !important;
  line-height: 1.38 !important;
}
#chat-modal .chat-bubble:not(.is-system) p {
  font-size: .88rem !important;
  line-height: 1.38 !important;
  overflow-wrap: anywhere !important;
  word-break: break-word !important;
  white-space: pre-wrap !important;
}
#chat-modal .chat-bubble.has-media,
#chat-modal .chat-bubble:has(.chat-img-shell) {
  max-width: min(60%, 480px) !important;
  min-width: 0 !important;
}
#chat-modal .chat-img-shell { max-width: 320px !important; max-height: 280px !important; }
#chat-modal .chat-image-attachment { max-width: 320px !important; max-height: 280px !important; }

/* Row alignment â€” own messages right, others left */
#chat-modal .bs-chat-message-row { margin: 6px 0 20px !important; }
#chat-modal .bs-chat-message-row.is-mine,
#chat-modal .bs-chat-message-row.is-vip-row.is-mine { justify-content: flex-end !important; padding-right: 0 !important; }
#chat-modal .bs-chat-message-row.is-vip-row:not(.is-mine),
#chat-modal .bs-chat-message-row.is-admin-row { justify-content: flex-start !important; padding-left: 0 !important; }

/* Input bar centered */
#chat-modal .chat-input-area {
  max-width: 900px !important;
  width: 100% !important;
  margin: 0 auto !important;
  padding: 10px 16px max(10px, env(safe-area-inset-bottom)) !important;
  height: auto !important;
  min-height: 62px !important;
  max-height: none !important;
  grid-template-columns: 42px minmax(0,1fr) 42px 42px !important;
  box-sizing: border-box !important;
  background: rgba(8,14,22,.98) !important;
  border-top: 1px solid rgba(255,255,255,.07) !important;
}
#chat-modal .chat-input-area textarea {
  height: 42px !important;
  min-height: 42px !important;
  max-height: 100px !important;
  border-radius: 21px !important;
  font-size: 15px !important;
}

/* Voice bar centered */
#chat-modal .bs-voice-rec-bar {
  max-width: 900px !important;
  width: 100% !important;
  margin: 0 auto !important;
  box-sizing: border-box !important;
}

/* VIP lock panel */
#chat-modal .bs-vip-lock-panel {
  max-width: 480px !important;
  margin: 40px auto !important;
  padding: 32px 24px !important;
  border-radius: 24px !important;
  background: rgba(10,16,24,.90) !important;
  border: 1px solid rgba(244,212,140,.20) !important;
  text-align: center !important;
}

/* Nav support button */
.bs-support-nav-btn {
  position: relative;
  width: 38px; height: 38px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.65);
  cursor: pointer;
  display: inline-flex;
  align-items: center; justify-content: center;
  font-size: 15px;
  transition: background .15s, color .15s, border-color .15s;
}
.bs-support-nav-btn:hover { background: rgba(244,212,140,.14); color: #f4d48c; border-color: rgba(244,212,140,.3); }
.bs-support-nav-badge {
  position: absolute;
  top: -3px; right: -3px;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: #ef4444;
  border: 2px solid var(--body-bg, #060a10);
  font-size: 8px;
  font-weight: 900;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ====================================================
   SUPPORT TICKET MODAL (Black Six chat style)
   ==================================================== */
#bs-support-modal.modal-shell {
  position: fixed !important;
  inset: 0 !important;
  z-index: 10200 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 16px !important;
  background: rgba(0,0,0,.80) !important;
  backdrop-filter: blur(12px) !important;
}
#bs-support-modal[hidden] { display: none !important; }
.bs-support-card {
  position: relative;
  width: min(100%, 460px);
  max-height: min(84vh, 720px);
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(170deg, rgba(13,20,30,.98), rgba(6,10,16,.99));
  box-shadow: 0 32px 80px rgba(0,0,0,.65);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.bs-support-close {
  position: absolute;
  top: 14px; right: 14px;
  width: 36px; height: 36px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 50%;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.55);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px;
  z-index: 10;
  transition: background .15s;
}
.bs-support-close:hover { background: rgba(255,255,255,.12); color: white; }

/* List view */
.bs-support-list-view {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
.bs-support-list-head {
  padding: 22px 22px 14px;
  border-bottom: 1px solid rgba(255,255,255,.07);
  flex-shrink: 0;
}
.bs-support-list-head h2 { margin: 4px 0 2px; font-size: 1.5rem; }

/* New ticket accordion */
.bs-support-new-ticket {
  border-bottom: 1px solid rgba(255,255,255,.07);
  flex-shrink: 0;
}
.bs-support-new-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 22px;
  cursor: pointer;
  font-size: .80rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: #f4d48c;
  user-select: none;
}
.bs-support-new-head:hover { background: rgba(244,212,140,.06); }
.bs-support-form-body {
  padding: 0 22px 16px;
}
.bs-support-form-body .bs-ticket-grid { margin-top: 8px !important; margin-bottom: 8px !important; }
.bs-support-form-body textarea {
  width: 100%;
  min-height: 72px;
  max-height: 120px;
  resize: none;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: white;
  padding: 10px 12px;
  font-size: .84rem;
  outline: none;
  box-sizing: border-box;
  margin-bottom: 10px;
  font-family: inherit;
}
.bs-support-form-body textarea:focus { border-color: rgba(244,212,140,.4); }
.bs-support-form-body #support-ticket-open-btn {
  width: 100%;
  padding: 12px;
  border-radius: 14px;
  border: 0;
  background: linear-gradient(135deg, #e8b840, #d4612a);
  color: #04070b;
  font-weight: 900;
  font-size: .86rem;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.bs-support-form-body #support-ticket-open-btn:disabled { opacity: .5; cursor: not-allowed; }

/* Tickets scrollable list */
.bs-support-tickets-list {
  flex: 1;
  overflow-y: auto;
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Ticket card */
.bs-support-ticket-card {
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.09);
  background: rgba(255,255,255,.04);
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.bs-support-ticket-card:hover { background: rgba(255,255,255,.08); border-color: rgba(244,212,140,.25); }
.bs-support-ticket-card .tc-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}
.bs-support-ticket-card .tc-date { font-size: .68rem; color: rgba(255,255,255,.4); font-mono: monospace; }
.bs-support-ticket-card .tc-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 82px;
  font-size: .60rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .04em;
  line-height: 1.05;
  text-align: center;
  padding: 5px 9px;
  border-radius: 999px;
  border: 1px solid;
}
.tc-status.open { color: #f87171; border-color: rgba(248,113,113,.3); background: rgba(248,113,113,.10); }
.tc-status.in_progress { color: #34d399; border-color: rgba(52,211,153,.3); background: rgba(52,211,153,.10); }
.tc-status.waiting_user { color: #fbbf24; border-color: rgba(251,191,36,.3); background: rgba(251,191,36,.10); }
.tc-status.resolved, .tc-status.closed { color: rgba(255,255,255,.35); border-color: rgba(255,255,255,.12); background: rgba(255,255,255,.04); }
.bs-support-ticket-card .tc-msg { font-size: .80rem; color: rgba(255,255,255,.75); line-height: 1.35; overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; }
.bs-support-ticket-card .tc-cat { font-size: .68rem; color: rgba(244,212,140,.65); margin-bottom: 4px; font-weight: 700; }
.bs-support-ticket-card .tc-reason {
  margin-top: 8px;
  color: rgba(255,255,255,.48);
  font-size: .72rem;
  line-height: 1.35;
}
.bs-support-ticket-cancel {
  margin-top: 10px;
  border: 1px solid rgba(239,83,80,.35);
  background: rgba(239,83,80,.10);
  color: #ff8a80;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: .70rem;
  font-weight: 900;
  cursor: pointer;
}
.bs-support-ticket-cancel:hover { background: rgba(239,83,80,.18); border-color: rgba(239,83,80,.58); }

/* Archive section */
.bs-support-archive { padding: 0 16px 16px; flex-shrink: 0; }
.bs-support-archive-toggle {
  width: 100%;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.45);
  font-size: .76rem;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: background .15s;
}
.bs-support-archive-toggle:hover { background: rgba(255,255,255,.08); }
#bs-support-resolved-list { margin-top: 8px; display: flex; flex-direction: column; gap: 8px; }
.bs-support-archive-note {
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  color: rgba(255,255,255,.45);
  font-size: .74rem;
  line-height: 1.35;
}
.bs-ticket-cancel-overlay {
  position: fixed;
  inset: 0;
  z-index: 100000;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(0,0,0,.68);
  backdrop-filter: blur(8px);
}
.bs-ticket-cancel-card {
  width: min(420px, 100%);
  border: 1px solid rgba(244,212,140,.24);
  border-radius: 18px;
  background: #10141d;
  box-shadow: 0 24px 80px rgba(0,0,0,.45);
  padding: 20px;
}
.bs-ticket-cancel-card h3 { margin: 0 0 6px; color: #f4d48c; font-size: 1.1rem; }
.bs-ticket-cancel-card p { margin: 0 0 14px; color: rgba(255,255,255,.56); font-size: .84rem; }
.bs-ticket-cancel-card select,
.bs-ticket-cancel-card textarea {
  width: 100%;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  color: #fff;
  padding: 12px;
  margin-bottom: 10px;
}
.bs-ticket-cancel-card textarea { min-height: 72px; resize: vertical; }
.bs-ticket-cancel-actions { display: flex; justify-content: flex-end; gap: 10px; }
.bs-ticket-cancel-actions button {
  border: 0;
  border-radius: 999px;
  padding: 10px 14px;
  font-weight: 900;
  cursor: pointer;
  background: #f4d48c;
  color: #05070b;
}
.bs-ticket-cancel-actions button.ghost { background: rgba(255,255,255,.08); color: rgba(255,255,255,.76); }

/* Chat view */
.bs-support-chat-view {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.bs-support-chat-head {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  flex-shrink: 0;
  background: rgba(8,14,22,.98);
}
.bs-support-chat-title {
  font-weight: 900;
  font-size: .88rem;
  color: white;
  display: block;
}
.bs-support-chat-status {
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  display: block;
  margin-top: 1px;
}
.bs-support-chat-area {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  background: rgba(4,8,14,.95);
}
.bs-support-chat-area .chat-bubble {
  max-width: 80% !important;
  min-width: 80px !important;
  padding: 9px 13px 20px !important;
  font-size: .84rem !important;
  line-height: 1.35 !important;
}
.bs-support-chat-input {
  padding: 10px 14px max(10px, env(safe-area-inset-bottom));
  background: rgba(8,14,22,.98);
  border-top: 1px solid rgba(255,255,255,.08);
  flex-shrink: 0;
}
.bs-support-input-form {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr) 40px 40px;
  gap: 8px;
  align-items: center;
}
#bs-support-chat-input {
  width: 100%;
  min-width: 0;
  min-height: 42px;
  max-height: 96px;
  resize: none;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 22px;
  color: white;
  padding: 10px 16px;
  font-size: .88rem;
  font-family: inherit;
  line-height: 1.35;
  outline: none;
  transition: border-color .15s;
}
#bs-support-chat-input:focus { border-color: rgba(244,212,140,.4); }
#bs-support-chat-input:disabled {
  color: rgba(247,242,232,.42);
  background: rgba(255,255,255,.045);
  border-color: rgba(255,255,255,.10);
}
.bs-support-file-btn,
#bs-support-mic-btn,
#bs-support-send-btn {
  width: 40px; height: 40px;
  border: 0; border-radius: 50%;
  background: linear-gradient(135deg, #e8b840, #d4612a);
  color: #04070b;
  font-size: 14px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: transform .12s;
}
.bs-support-file-btn,
#bs-support-mic-btn {
  border: 1px solid rgba(244,212,140,.18);
  background: rgba(255,255,255,.065);
  color: #f4d48c;
}
#bs-support-mic-btn.is-recording {
  color: #ff8a80;
  background: rgba(239,68,68,.16);
}
.bs-support-file-btn:hover,
#bs-support-mic-btn:hover,
#bs-support-send-btn:hover { transform: scale(1.08); }
.bs-support-file-btn:disabled,
#bs-support-mic-btn:disabled,
#bs-support-send-btn:disabled {
  opacity: .42;
  cursor: not-allowed;
  transform: none;
}
.bs-support-voice-rec-bar {
  display: none;
  margin: 10px 14px;
}
.bs-support-voice-rec-bar.is-active {
  display: flex;
}
#bs-support-chat-feedback {
  min-height: 16px;
  margin: 6px 4px 0;
  font-size: .76rem;
}
#bs-support-chat-view.is-locked .bs-support-chat-input {
  background: rgba(8,14,22,.99);
}

@media (max-width: 520px) {
  .bs-support-card { border-radius: 0; min-height: 100dvh; max-height: 100dvh; width: 100vw; }
  #bs-support-modal.modal-shell { padding: 0; align-items: flex-end; }
}

/* ====================================================
   BLACK SIX v3 â€” FIXES: wider chat, reactions below bubble
   ==================================================== */

/* â”€â”€ WIDER CHAT THREAD â”€â”€ */
/* Remove the 900px cap â€” use full width with just side padding */
#chat-modal .chat-thread {
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 20px 32px 24px !important;
  box-sizing: border-box !important;
}
@media (max-width: 760px) {
  #chat-modal .chat-thread { padding: 12px 12px 16px !important; }
}

/* â”€â”€ WIDER BUBBLES on full-width thread â”€â”€ */
#chat-modal .chat-bubble:not(.is-system):not(.bs-vip-lock-panel) {
  max-width: min(72%, 700px) !important;
}
#chat-modal .chat-bubble.has-media,
#chat-modal .chat-bubble:has(.chat-img-shell) {
  max-width: min(60%, 580px) !important;
}
#chat-modal .chat-img-shell { max-width: 380px !important; max-height: 320px !important; }
#chat-modal .chat-image-attachment { max-width: 380px !important; max-height: 320px !important; }

/* â”€â”€ REACTIONS BELOW BUBBLE (bubble-col wrapper) â”€â”€ */
.bs-bubble-col {
  display: flex;
  flex-direction: column;
  align-items: flex-start; /* others: left-align */
  gap: 3px;
  min-width: 0;
  max-width: min(72%, 700px);
}
.bs-bubble-col.mine {
  align-items: flex-end; /* my bubbles: right-align */
}
.bs-bubble-col > .chat-bubble {
  max-width: 100% !important;
}
.bs-bubble-col .bs-reactions-bar {
  padding: 0 4px;
  margin-top: 0;
}
.bs-bubble-col.mine .bs-reactions-bar {
  justify-content: flex-end;
}

/* â”€â”€ KEEP ROW ALIGNMENT â”€â”€ */
#chat-modal .bs-chat-message-row {
  align-items: flex-end !important;
}
#chat-modal .bs-chat-message-row.is-mine .bs-bubble-col,
#chat-modal .bs-chat-message-row.is-vip-row.is-mine .bs-bubble-col {
  align-items: flex-end !important;
}
#chat-modal .bs-chat-message-row.is-admin-row .bs-bubble-col,
#chat-modal .bs-chat-message-row.is-vip-row:not(.is-mine) .bs-bubble-col {
  align-items: flex-start !important;
}

/* â”€â”€ VIP LOCK panel also benefits from wider thread â”€â”€ */
#chat-modal .bs-vip-lock-panel {
  max-width: 520px !important;
  margin: 60px auto !important;
}

/* â”€â”€ INPUT BAR full width, no max-width restriction â”€â”€ */
#chat-modal .chat-input-area {
  max-width: none !important;
  margin: 0 !important;
  padding: 10px 24px max(10px, env(safe-area-inset-bottom)) !important;
}

/* â”€â”€ NAV: username chip hover â”€â”€ */
#nav-user-name:hover {
  opacity: .85;
  filter: brightness(1.1);
}

/* â”€â”€ HIDE arrow btn-account-card â”€â”€ */
#btn-account-card {
  display: none !important;
}

/* ====================================================
   BLACK SIX v3.1 â€” SUPPORT MODAL BUG FIXES
   ==================================================== */

/* Fix 1: hidden attribute must override flex/grid display */
#bs-support-chat-view[hidden],
#bs-support-list-view[hidden],
#bs-support-form-body[hidden],
#bs-support-resolved-list[hidden],
#bs-support-archive-wrap[hidden],
.bs-support-form-body[hidden],
[id^="bs-support-"][hidden] {
  display: none !important;
}

/* Fix 2: form grid â€” must be scoped outside #chat-modal */
#bs-support-modal .bs-ticket-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
  margin-top: 8px !important;
  margin-bottom: 8px !important;
}
#bs-support-modal .bs-ticket-grid label {
  display: flex !important;
  flex-direction: column !important;
  gap: 5px !important;
  font-size: .68rem !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: rgba(244,212,140,.70) !important;
}
#bs-support-modal .bs-ticket-grid select {
  width: 100% !important;
  background: rgba(255,255,255,.07) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  border-radius: 10px !important;
  color: white !important;
  padding: 9px 11px !important;
  font-size: .82rem !important;
  outline: none !important;
  cursor: pointer !important;
  box-sizing: border-box !important;
}
#bs-support-modal .bs-ticket-grid select:focus {
  border-color: rgba(244,212,140,.45) !important;
}
#bs-support-modal .bs-ticket-grid select option {
  background: #080e16 !important;
}

/* Fix 3: scrollable list takes remaining space properly */
#bs-support-modal .bs-support-list-view {
  overflow: hidden !important;
}
#bs-support-modal .bs-support-tickets-list {
  overflow-y: auto !important;
  flex: 1 !important;
  min-height: 80px !important;
  max-height: 340px !important;
}

/* Fix 4: archive section always at bottom */
#bs-support-modal .bs-support-archive {
  border-top: 1px solid rgba(255,255,255,.06) !important;
  padding: 10px 16px 16px !important;
  flex-shrink: 0 !important;
}

/* Fix 5: chat view fully hidden by default */
#bs-support-chat-view {
  display: none;
}
#bs-support-chat-view:not([hidden]) {
  display: flex !important;
}

/* ====================================================
   BLACK SIX v4 â€” CHAT FULL-WIDTH LAYOUT FIX
   ==================================================== */

/* 1. Thread: true full width, no constraints */
#chat-modal .chat-thread {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 20px 28px 24px !important;
  box-sizing: border-box !important;
  align-self: stretch !important;
}

/* 2. Message rows: explicitly 100% width, flex row */
#chat-modal .bs-chat-message-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-end !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  gap: 8px !important;
  margin: 4px 0 18px !important;
  padding: 0 !important;
}

/* 3. Mine (own messages) = right side */
#chat-modal .bs-chat-message-row.is-mine,
#chat-modal .bs-chat-message-row.is-vip-row.is-mine {
  flex-direction: row-reverse !important;
  justify-content: flex-start !important;
}

/* 4. Others (admin/vip) = left side */
#chat-modal .bs-chat-message-row.is-admin-row,
#chat-modal .bs-chat-message-row.is-vip-row:not(.is-mine) {
  flex-direction: row !important;
  justify-content: flex-start !important;
}

/* 5. Bubble column: grows to fill available space up to max */
.bs-bubble-col {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 3px !important;
  min-width: 0 !important;
  max-width: min(70%, 680px) !important;
  flex: 0 1 auto !important;
}
.bs-bubble-col.mine {
  align-items: flex-end !important;
}
.bs-bubble-col > .chat-bubble {
  max-width: 100% !important;
  min-width: 0 !important;
  width: auto !important;
}
.bs-bubble-col .bs-reactions-bar {
  margin: 0 !important;
  padding: 1px 4px !important;
}
.bs-bubble-col.mine .bs-reactions-bar { justify-content: flex-end !important; }

/* 6. Bubbles: remove conflicting max-width, use col to control width */
#chat-modal .chat-bubble:not(.is-system):not(.bs-vip-lock-panel) {
  min-width: 80px !important;
  max-width: 100% !important;
  width: auto !important;
  box-sizing: border-box !important;
}

/* 7. Remove old row padding overrides that misalign */
#chat-modal .bs-chat-message-row.is-mine,
#chat-modal .bs-chat-message-row.is-vip-row {
  padding-right: 0 !important;
}
#chat-modal .bs-chat-message-row.is-vip-row:not(.is-mine),
#chat-modal .bs-chat-message-row.is-admin-row {
  padding-left: 0 !important;
}

/* 8. Input bar: full width */
#chat-modal .chat-input-area {
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  padding: 10px 20px max(10px, env(safe-area-inset-bottom)) !important;
  margin: 0 !important;
}

/* 9. Voice rec bar: full width */
#chat-modal .bs-voice-rec-bar.is-active {
  width: 100% !important;
  box-sizing: border-box !important;
}

@media (max-width: 760px) {
  #chat-modal .chat-thread { padding: 12px 10px 16px !important; }
  .bs-bubble-col { max-width: min(82%, 480px) !important; }
  #chat-modal .chat-input-area { padding: 8px 10px max(8px, env(safe-area-inset-bottom)) !important; }
}

/* ====================================================
   BLACK SIX FINAL â€” DEFINITIVO: chat allineamento +
   scroll archivio ticket
   ==================================================== */

/* â”€â”€ CHAT: reset tutto e riparti pulito â”€â”€ */

/* 1. Thread: 100% width, no max-width di nessun tipo */
#chat-modal .chat-thread {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 16px 20px 24px !important;
  box-sizing: border-box !important;
}

/* 2. Ogni riga Ã¨ un flexbox orizzontale 100% wide */
#chat-modal .bs-chat-message-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-end !important;
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  gap: 8px !important;
  margin: 2px 0 16px !important;
  padding: 0 !important;
}

/* 3. Wrapper bubble: si adatta, max 70% */
#chat-modal .bs-bubble-col {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  min-width: 0 !important;
  max-width: min(70%, 680px) !important;
  flex: 0 1 auto !important;
  /* Default: left-aligned (altri utenti) */
  align-items: flex-start !important;
  margin-right: auto !important;
  margin-left: 0 !important;
}

/* 4. I MIEI messaggi: spingi a destra con margin-left:auto */
#chat-modal .bs-chat-message-row.is-mine .bs-bubble-col,
#chat-modal .bs-chat-message-row.is-vip-row.is-mine .bs-bubble-col {
  align-items: flex-end !important;
  margin-left: auto !important;
  margin-right: 0 !important;
}

/* 5. Reactions allineate alla bolla */
#chat-modal .bs-bubble-col .bs-reactions-bar {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  justify-content: flex-start !important;
  margin: 0 !important;
  padding: 0 2px !important;
}
#chat-modal .bs-chat-message-row.is-mine .bs-reactions-bar,
#chat-modal .bs-chat-message-row.is-vip-row.is-mine .bs-reactions-bar {
  justify-content: flex-end !important;
}

/* 6. Bolla dentro il wrapper: max 100% del col */
#chat-modal .bs-bubble-col > .chat-bubble {
  max-width: 100% !important;
  min-width: 80px !important;
  width: auto !important;
}

/* 7. Avatar allineato in basso a sinistra */
#chat-modal .bs-chat-avatar {
  flex-shrink: 0 !important;
  align-self: flex-end !important;
  margin-bottom: 0 !important;
}

/* â”€â”€ ARCHIVIO TICKET: scroll funzionante â”€â”€ */

/* Il card del support modal: altezza fissa, tutto scorrevole */
.bs-support-card {
  max-height: min(88vh, 720px) !important;
}

/* List view: flex column, overflow nascosto */
#bs-support-modal .bs-support-list-view {
  display: flex !important;
  flex-direction: column !important;
  flex: 1 !important;
  min-height: 0 !important;
  overflow: hidden !important;
}

/* La zona scrollabile: header fisso, tutto il resto scrolla */
#bs-support-modal .bs-support-scrollable {
  flex: 1 !important;
  overflow-y: auto !important;
  min-height: 0 !important;
  padding: 0 0 8px !important;
}

/* Se bs-support-scrollable non esiste ancora nel DOM,
   usa direttamente tickets-list come scroll container */
#bs-support-modal .bs-support-tickets-list {
  overflow-y: visible !important;  /* non serve qui, scroll Ã¨ sul parent */
  max-height: none !important;
  flex: none !important;
}

/* Archivio: scorribile insieme al resto */
#bs-support-modal .bs-support-archive {
  padding: 8px 16px 12px !important;
}
#bs-support-modal #bs-support-resolved-list {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  margin-top: 8px !important;
}
#bs-support-modal #bs-support-resolved-list[hidden] {
  display: none !important;
}

/* Support ticket chat: mobile full screen, same clean premium chat rhythm */
#bs-support-modal .bs-support-chat-area .chat-bubble.is-user .chat-bubble-meta::after,
#bs-support-modal .bs-support-chat-area .chat-bubble.is-vip .chat-bubble-meta::after {
  content: " \2713\2713" !important;
  color: #25f4df !important;
}

#bs-support-modal .bs-support-chat-area .bs-chat-message-row {
  width: 100% !important;
  max-width: 100% !important;
  display: flex !important;
  align-items: flex-end !important;
  gap: 8px !important;
  margin: 8px 0 18px !important;
  box-sizing: border-box !important;
}

#bs-support-modal .bs-support-chat-area .bs-chat-message-row.is-mine {
  justify-content: flex-end !important;
  padding-right: 8px !important;
}

#bs-support-modal .bs-support-chat-area .bs-chat-message-row.is-admin-row {
  justify-content: flex-start !important;
  padding-left: 4px !important;
}

#bs-support-modal .bs-support-chat-area .chat-bubble:not(.is-system) {
  max-width: min(78%, 360px) !important;
  min-width: 128px !important;
  border-radius: 18px !important;
  padding: 11px 14px 24px !important;
  box-sizing: border-box !important;
}

#bs-support-modal .bs-support-chat-area .chat-bubble p {
  margin: 8px 0 0 !important;
  overflow-wrap: anywhere !important;
}

#bs-support-modal .bs-support-chat-area .chat-bubble::after {
  content: none !important;
}

@media (max-width: 520px) {
  #bs-support-modal.modal-shell {
    align-items: stretch !important;
    justify-content: stretch !important;
    padding: 0 !important;
    background: #03070d !important;
  }

  #bs-support-modal .modal-backdrop {
    display: none !important;
  }

  #bs-support-modal .bs-support-card {
    width: 100vw !important;
    height: 100dvh !important;
    min-height: 100dvh !important;
    max-height: none !important;
    border-radius: 0 !important;
    border: 0 !important;
  }

  #bs-support-chat-view:not([hidden]) {
    position: fixed !important;
    inset: 0 !important;
    z-index: 10350 !important;
    width: 100vw !important;
    height: 100dvh !important;
    max-height: none !important;
    background: #050b12 !important;
  }

  #bs-support-chat-view:not([hidden]) .bs-support-chat-head {
    min-height: 64px !important;
    padding: max(12px, env(safe-area-inset-top)) 14px 12px !important;
  }

  #bs-support-chat-view:not([hidden]) .bs-support-chat-area {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    padding: 16px 10px 18px !important;
  }

  #bs-support-chat-view:not([hidden]) .bs-support-chat-input {
    padding: 10px 12px max(12px, env(safe-area-inset-bottom)) !important;
  }

  #bs-support-modal .bs-support-chat-area .chat-bubble:not(.is-system) {
    max-width: 82% !important;
  }
}

/* ====================================================
   BLACK SIX â€” DEFINITIVO INPUT BAR (Black Six chat style)
   Aggiunto per fix mic button mobile + allineamento SD
   ==================================================== */
#chat-modal .chat-input-area {
  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) 42px 42px !important;
  grid-template-rows: auto !important;
  align-items: end !important;
  gap: 7px !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  margin: 0 !important;
  padding: 10px 16px max(10px, env(safe-area-inset-bottom)) !important;
  height: auto !important;
  min-height: 62px !important;
  max-height: none !important;
  background: rgba(8,14,22,.98) !important;
  border: none !important;
  border-top: 1px solid rgba(255,255,255,.07) !important;
  border-radius: 0 !important;
}

/* Tutti i bottoni nella barra: 42px circolari, sfondo sottile */
#chat-modal .chat-input-area .file-btn,
#chat-modal .chat-input-area #chat-mic-btn,
#chat-modal .chat-input-area #chat-submit-btn {
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  min-height: 42px !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;
}

/* Textarea pill */
#chat-modal .chat-input-area textarea {
  grid-column: 2 !important;
  height: 42px !important;
  min-height: 42px !important;
  max-height: 110px !important;
  border-radius: 21px !important;
  padding: 11px 16px !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  overflow-y: auto !important;
  resize: none !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

/* Mic button: explicit position in grid col 3 */
#chat-modal #chat-mic-btn {
  grid-column: 3 !important;
  background: rgba(255,255,255,.07) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  color: rgba(255,255,255,.55) !important;
}
#chat-modal #chat-mic-btn:hover  { color: #f4d48c !important; background: rgba(244,212,140,.12) !important; }
#chat-modal #chat-mic-btn.is-recording { color: #ef4444 !important; background: rgba(239,68,68,.16) !important; }

/* Send button: col 4, teal like Black Six */
#chat-modal #chat-submit-btn {
  grid-column: 4 !important;
  background: linear-gradient(135deg, #00a884, #2fd27d) !important;
  border: none !important;
  color: #04100c !important;
  font-size: 16px !important;
  box-shadow: 0 6px 20px rgba(0,168,132,.28) !important;
}
#chat-modal #chat-submit-btn:disabled {
  background: rgba(255,255,255,.10) !important;
  color: rgba(255,255,255,.30) !important;
  box-shadow: none !important;
}

/* File button: col 1 */
#chat-modal .file-btn {
  grid-column: 1 !important;
  background: rgba(255,255,255,.07) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  color: rgba(255,255,255,.55) !important;
}
#chat-modal .file-btn:hover { color: #f4d48c !important; background: rgba(244,212,140,.12) !important; }

/* Mobile: slightly tighter padding, touch targets 44px */
@media (max-width: 760px) {
  #chat-modal .chat-input-area {
    padding: 8px max(8px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left)) !important;
    gap: 5px !important;
  }
  #chat-modal .chat-input-area .file-btn,
  #chat-modal .chat-input-area #chat-mic-btn,
  #chat-modal .chat-input-area #chat-submit-btn {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
  }
  #chat-modal .chat-input-area {
    grid-template-columns: 44px minmax(0, 1fr) 44px 44px !important;
  }
  #chat-modal .chat-input-area textarea {
    font-size: 16px !important; /* prevents iOS zoom on focus */
    height: 44px !important;
    min-height: 44px !important;
    border-radius: 22px !important;
  }
}

/* Touch pointer: larger targets */
@media (pointer: coarse) {
  #chat-modal .chat-input-area .file-btn,
  #chat-modal .chat-input-area #chat-mic-btn,
  #chat-modal .chat-input-area #chat-submit-btn {
    min-height: 44px !important;
    min-width: 44px !important;
  }
}

/* ================================================================
   BLACK SIX â€” INPUT BAR FLEX (Black Six chat style, definitivo)
   Sostituisce TUTTO il CSS grid precedente con flexbox
   ================================================================ */
#chat-modal .chat-input-area {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-end !important;
  gap: 7px !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
  margin: 0 !important;
  padding: 10px 16px max(10px, env(safe-area-inset-bottom)) !important;
  height: auto !important;
  min-height: 62px !important;
  max-height: none !important;
  background: rgba(8,14,22,.98) !important;
  border: none !important;
  border-top: 1px solid rgba(255,255,255,.07) !important;
  border-radius: 0 !important;
  /* override qualsiasi grid-template-columns precedente */
  grid-template-columns: unset !important;
}

/* Textarea: occupa tutto lo spazio disponibile (flex:1 = stessa cosa di 1fr) */
#chat-modal .chat-input-area textarea {
  flex: 1 1 auto !important;
  min-width: 0 !important;
  height: 42px !important;
  min-height: 42px !important;
  max-height: 110px !important;
  border-radius: 21px !important;
  padding: 11px 16px !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  overflow-y: auto !important;
  resize: none !important;
  box-sizing: border-box !important;
}

/* Bottoni: dimensione fissa, flex:0 per non allargarsi */
#chat-modal .chat-input-area .file-btn,
#chat-modal .chat-input-area #chat-mic-btn,
#chat-modal .chat-input-area #chat-submit-btn {
  flex: 0 0 auto !important;
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  min-height: 42px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;
}

/* File button */
#chat-modal .chat-input-area .file-btn {
  order: 1 !important;
  background: rgba(255,255,255,.07) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  color: rgba(255,255,255,.55) !important;
  font-size: 17px !important;
}
#chat-modal .chat-input-area .file-btn:hover {
  color: #f4d48c !important;
  background: rgba(244,212,140,.12) !important;
}

/* Textarea: ordine 2 */
#chat-modal .chat-input-area textarea { order: 2 !important; }

/* Mic button: ordine 3 â€” SEMPRE VISIBILE */
#chat-modal .chat-input-area #chat-mic-btn {
  order: 3 !important;
  background: rgba(255,255,255,.07) !important;
  border: 1px solid rgba(255,255,255,.10) !important;
  color: rgba(255,255,255,.55) !important;
  font-size: 18px !important;
}
#chat-modal .chat-input-area #chat-mic-btn:hover  { color: #f4d48c !important; background: rgba(244,212,140,.12) !important; }
#chat-modal .chat-input-area #chat-mic-btn.is-recording { color: #ef4444 !important; background: rgba(239,68,68,.16) !important; }

/* Send button: ordine 4, teal Black Six */
#chat-modal .chat-input-area #chat-submit-btn {
  order: 4 !important;
  background: linear-gradient(135deg, #00a884, #2fd27d) !important;
  border: none !important;
  color: #04100c !important;
  font-size: 16px !important;
  box-shadow: 0 6px 20px rgba(0,168,132,.28) !important;
}
#chat-modal .chat-input-area #chat-submit-btn:disabled {
  background: rgba(255,255,255,.10) !important;
  color: rgba(255,255,255,.30) !important;
  box-shadow: none !important;
}

/* Mobile: bottoni 44px, font-size 16px (no zoom iOS) */
@media (max-width: 760px) {
  #chat-modal .chat-input-area {
    padding: 8px max(8px, env(safe-area-inset-right)) max(10px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left)) !important;
    gap: 6px !important;
  }
  #chat-modal .chat-input-area .file-btn,
  #chat-modal .chat-input-area #chat-mic-btn,
  #chat-modal .chat-input-area #chat-submit-btn {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
  }
  #chat-modal .chat-input-area textarea {
    font-size: 16px !important;
    height: 44px !important;
    min-height: 44px !important;
    border-radius: 22px !important;
    padding: 12px 14px !important;
  }
}

@media (pointer: coarse) {
  #chat-modal .chat-input-area .file-btn,
  #chat-modal .chat-input-area #chat-mic-btn,
  #chat-modal .chat-input-area #chat-submit-btn {
    min-height: 44px !important;
    min-width: 44px !important;
  }
}



/* ===== Gift rain celebration (Community VIP omaggio) ===== */
.bs-gift-rain{position:fixed;inset:0;z-index:2147483000;pointer-events:none;overflow:hidden;opacity:1;transition:opacity .6s ease;}
.bs-gift-rain.is-leaving{opacity:0;}
.bs-gift-piece{position:absolute;top:-8vh;line-height:1;filter:drop-shadow(0 3px 6px rgba(0,0,0,.35));animation-name:bsGiftFall;animation-timing-function:cubic-bezier(.3,.65,.55,1);animation-iteration-count:1;animation-fill-mode:both;will-change:transform,opacity;}
@keyframes bsGiftFall{0%{transform:translateY(-10vh) rotate(0deg);opacity:0;}8%{opacity:1;}100%{transform:translateY(112vh) rotate(360deg);opacity:.9;}}
.bs-gift-banner{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none;}
.bs-gift-banner-card{pointer-events:none;text-align:center;padding:26px 30px;border-radius:22px;background:linear-gradient(135deg,rgba(20,22,28,.96),rgba(34,28,12,.96));border:1px solid rgba(244,212,140,.55);box-shadow:0 24px 70px rgba(0,0,0,.55),0 0 40px rgba(244,212,140,.25);max-width:340px;animation:bsGiftPop .7s cubic-bezier(.18,.9,.3,1.2) both;}
.bs-gift-banner-emoji{font-size:54px;line-height:1;animation:bsGiftBounce 1.1s ease-in-out infinite;}
.bs-gift-banner-card h3{margin:10px 0 6px;color:#f4d48c;font-size:1.25rem;letter-spacing:.3px;}
.bs-gift-banner-card p{margin:0;color:#e7e7ea;font-size:.92rem;line-height:1.4;}
.bs-gift-banner-card strong{color:#ffd97a;}
@keyframes bsGiftPop{0%{transform:scale(.6) translateY(20px);opacity:0;}100%{transform:scale(1) translateY(0);opacity:1;}}
@keyframes bsGiftBounce{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
@media (prefers-reduced-motion: reduce){.bs-gift-piece{animation-duration:2s!important;}.bs-gift-banner-emoji{animation:none;}}

/* ============================================================
   FIX BOLLA FOTO (community/chat): la bolla aderisce alla foto,
   niente piu' grande area vuota attorno. Alta specificita' per
   vincere sulle regole .has-media precedenti.
   ============================================================ */
#chat-modal #chat-thread .bs-bubble-col .chat-bubble.has-media,
#chat-modal #chat-thread .bs-bubble-col .chat-bubble:has(.chat-img-shell) {
  width: fit-content !important;
  max-width: min(86%, 300px) !important;
  min-width: 0 !important;
  padding: 8px 9px 18px !important;
}
#chat-modal #chat-thread .bs-bubble-col .chat-img-shell {
  display: block !important;
  width: auto !important;
  max-width: 100% !important;
  max-height: 320px !important;
  margin-top: 6px !important;
}
#chat-modal #chat-thread .bs-bubble-col .chat-image-attachment {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 260px !important;
  max-height: 320px !important;
  object-fit: contain !important;
}
