html {
  margin: 0;
  padding: 0;
  width: 100%;
  box-sizing: border-box;
  overflow: hidden !important;
  /* Принудительно скрываем скроллбары */
  scrollbar-width: none !important;
  -ms-overflow-style: none !important;
}

html::-webkit-scrollbar {
  width: 0px !important;
  height: 0px !important;
  display: none !important;
}

*, *::before, *::after {
  box-sizing: inherit;
}

body {
  margin: 0;
  padding: 0;
  font-family: 'SF Pro Display', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
  background: #f8f9fb;
  color: #111;
  height: 100vh;
  overflow: hidden !important;
  -webkit-font-smoothing: antialiased;
  /* Принудительно скрываем скроллбары */
  scrollbar-width: none !important;
  -ms-overflow-style: none !important;
}

body::-webkit-scrollbar {
  width: 0px !important;
  height: 0px !important;
  display: none !important;
}
.tw-header {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 28px 0 16px 0;
  background: #fff;
  box-shadow: 0 2px 16px 0 rgba(0,0,0,0.04);
  position: sticky;
  top: 0;
  z-index: 10;
}
.tw-logo {
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: -1px;
}
.tw-main-layout {
  display: -webkit-flex;
  display: flex;
  height: 100vh;
  max-width: 100vw;
  min-width: auto;
  width: 100%;
  margin: 0;
  background: #fff;
  border-radius: 0;
  box-shadow: none;
  overflow: hidden;
}

/* Убираем все медиа-запросы для layout - теперь всегда полная ширина */
/* Адаптация под большие экраны MacBook Pro - только для сайдбара */
@media (min-width: 1400px) {
  /* Оставляем только стили для сайдбара */
}

@media (min-width: 1600px) {
  /* Оставляем только стили для сайдбара */
}

@media (min-width: 1700px) {
  /* Оставляем только стили для сайдбара */
}

@media (min-width: 1800px) {
  /* Оставляем только стили для сайдбара */
}
.tw-sidebar {
  width: 320px;
  background: #f4f6fa;
  border-right: 1px solid #e5e7eb;
  padding: 32px 0 0 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  height: 100vh;
  overflow-y: auto;
  overflow-x: hidden;
}

/* Увеличиваем ширину сайдбара на больших экранах */
@media (min-width: 1400px) and (min-height: 800px) {
  .tw-sidebar {
    width: 380px;
  }
}

@media (min-width: 1600px) and (min-height: 900px) {
  .tw-sidebar {
    width: 420px;
  }
}

@media (min-width: 1700px) and (min-height: 1000px) {
  .tw-sidebar {
    width: 440px;
  }
}

@media (min-width: 1800px) and (min-height: 1000px) {
  .tw-sidebar {
    width: 480px;
  }
}

/* Увеличиваем размеры шрифтов и элементов на больших экранах */
@media (min-width: 1400px) and (min-height: 800px) {
  .tw-webinar-item {
    padding: 22px 24px;
    border-radius: 20px;
  }
  
  .tw-webinar-title {
    font-size: 1.15rem;
  }
  
  .tw-webinar-desc {
    font-size: 1.05rem;
  }
  
  .tw-message-bubble {
    padding: 22px 26px;
    font-size: 1.15rem;
    border-radius: 24px 24px 24px 8px;
  }
  
  .tw-chat-header {
    font-size: 1.35rem;
    padding: 20px 40px 0 40px;
  }
  
  .tw-chat-messages {
    padding: 20px 40px 20px 40px;
    gap: 22px;
  }
}

@media (min-width: 1600px) and (min-height: 900px) {
  .tw-webinar-item {
    padding: 24px 28px;
  }
  
  .tw-webinar-title {
    font-size: 1.2rem;
  }
  
  .tw-webinar-desc {
    font-size: 1.08rem;
  }
  
  .tw-message-bubble {
    padding: 24px 28px;
    font-size: 1.2rem;
  }
  
  .tw-chat-header {
    font-size: 1.4rem;
    padding: 24px 48px 0 48px;
  }
  
  .tw-chat-messages {
    padding: 24px 48px 24px 48px;
    gap: 24px;
  }
}

/* Простое и надежное центрирование плейсхолдера */
.tw-chat-messages {
  position: relative;
}

/* Убираем конфликтующие стили */
.tw-chat-messages > div {
  position: relative;
  z-index: auto;
}

/* Стили для плейсхолдера с Safari поддержкой */
.tw-placeholder-wrapper {
  display: -webkit-flex !important;
  display: flex !important;
  -webkit-align-items: center !important;
  align-items: center !important;
  -webkit-justify-content: center !important;
  justify-content: center !important;
  height: 100% !important;
  min-height: 300px !important;
  width: 100% !important;
  position: relative !important;
  padding: 20px !important;
  -webkit-box-sizing: border-box !important;
  box-sizing: border-box !important;
}

.tw-placeholder-box {
  flex-shrink: 0 !important;
  width: auto !important;
  min-width: 280px !important;
  max-width: 500px !important;
}

/* Ограничиваем размер текста в плейсхолдере для средних экранов */
@media (min-width: 769px) and (max-width: 1399px) {
  .tw-placeholder-wrapper {
    min-height: 300px !important;
  }
  .tw-placeholder-box {
    min-width: 280px !important;
    max-width: 400px !important;
  }
  .tw-placeholder-box div {
    font-size: 1rem !important;
    padding: 20px 24px !important;
  }
}

/* Адаптация под большие экраны (только для действительно больших экранов) */
@media (min-width: 1400px) and (min-height: 800px) {
  .tw-placeholder-wrapper {
    min-height: 450px !important;
  }
}

@media (min-width: 1600px) and (min-height: 900px) {
  .tw-placeholder-wrapper {
    min-height: 480px !important;
  }
}

@media (min-width: 1700px) and (min-height: 1000px) {
  .tw-placeholder-wrapper {
    min-height: 500px !important;
  }
}
.tw-sidebar-title {
  font-size: 1.15rem;
  font-weight: 600;
  color: #888;
  padding: 0 32px 18px 32px;
  margin-bottom: 12px;
}
#webinar-list {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 12px; /* Возвращаем оригинальное расстояние */
  padding: 0 16px 32px 16px; /* Возвращаем оригинальные отступы */
  /* Убираем overflow отсюда, так как скролл теперь на уровне sidebar */
}
.tw-webinar-item {
  background: #fff;
  border-radius: 18px; /* Возвращаем оригинальное скругление */
  box-shadow: 0 2px 12px 0 rgba(0,0,0,0.04);
  padding: 18px 20px; /* Возвращаем оригинальные размеры */
  margin-bottom: 0;
  cursor: pointer;
  transition: box-shadow 0.18s, background 0.18s;
  border: 2px solid transparent;
  display: flex;
  flex-direction: column;
  gap: 4px; /* Возвращаем оригинальное расстояние */
  user-select: none;
  -webkit-user-select: none;
}
.tw-webinar-item.selected, .tw-webinar-item:hover {
  border: 2px solid #0071e3;
  box-shadow: 0 4px 24px 0 rgba(0,113,227,0.08);
  background: #f0f6ff;
}
.tw-webinar-title {
  font-size: 1.08rem;
  font-weight: 600;
  color: #222;
}
.tw-webinar-desc {
  color: #555;
  font-size: 0.98rem;
}
.tw-webinar-price {
  font-size: 0.95rem;
  color: #0071e3;
  font-weight: 600;
  margin-top: 4px;
}
.tw-webinar-online {
  font-size: 0.95rem;
  color: #0071e3;
  background: #eaf1fb;
  border-radius: 12px;
  padding: 2px 10px;
  font-weight: 600;
  align-self: flex-start;
  margin-top: 4px;
}
.tw-chat-section {
  flex: 1;
  display: flex;
  flex-direction: column;
  background: #f8f9fb;
  position: relative;
  height: 100vh;
  overflow: hidden;
}
.tw-chat-header {
  padding: 16px 32px 0 32px;
  font-size: 1.25rem;
  font-weight: 700;
  color: #222;
  min-height: 32px;
  flex-shrink: 0;
}
.tw-chat-messages {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 16px 32px 16px 32px;
  overflow-y: auto;
  min-height: 0;
}
.tw-message-bubble {
  background: #fff;
  border-radius: 22px 22px 22px 6px; /* Возвращаем оригинальное скругление */
  padding: 18px 22px; /* Возвращаем оригинальные размеры */
  font-size: 1.08rem; /* Возвращаем оригинальный шрифт */
  color: #222;
  box-shadow: 0 2px 12px 0 rgba(0,0,0,0.04);
  align-self: flex-start;
  max-width: 90%;
  word-break: break-word;
  transition: background 0.2s;
}
.tw-message-paid {
  background: #eaf1fb;
  color: #0071e3;
}
.tw-chat-controls {
  display: none;
}
.tw-btn {
  display: inline-block;
  padding: 12px 28px;
  border-radius: 24px;
  font-size: 1rem;
  font-weight: 600;
  border: none;
  cursor: pointer;
  transition: background 0.2s, color 0.2s, box-shadow 0.2s;
  box-shadow: 0 2px 8px 0 rgba(0,0,0,0.04);
}
.tw-btn-primary {
  background: #0071e3;
  color: #fff;
}
.tw-btn-primary:hover {
  background: #005bb5;
}
.tw-btn-outline {
  background: #fff;
  color: #0071e3;
  border: 2px solid #0071e3;
}
.tw-btn-outline:hover {
  background: #f0f6ff;
}
.tw-next-btn {
  margin-top: 12px;
  margin-bottom: 0;
  padding: 8px 14px;
  width: 112.5px;
  min-width: 0;
  font-size: inherit;
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.tw-account-box {
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 2px 12px 0 rgba(0,0,0,0.04);
  padding: 14px 16px 6px 16px; /* Уменьшаем базовый padding снизу для неавторизованного состояния */
  margin: 0 16px 18px 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
/* Увеличиваем padding снизу ТОЛЬКО для авторизованного состояния в десктопе */
.tw-account-box:has(#account-balance-box) {
  padding-bottom: 16px;
}
/* Спускаем кнопки немного вниз ТОЛЬКО в неавторизованном состоянии десктопа */
.tw-account-box:not(:has(#account-balance-box)) .tw-auth-buttons {
  margin-top: -4px;
}
.tw-account-balance {
  font-size: 1.05rem;
  font-weight: 600;
  color: #0071e3;
  text-align: center;
  line-height: 1.2;
}
.tw-account-buttons {
  display: flex;
  gap: 32px; /* Увеличиваем расстояние между Top Up и Logout в десктопе для лучшего заполнения пространства */
  margin-top: 6px; /* Спускаем кнопки Top Up и Logout ниже в десктопе */
  justify-content: center;
}
/* Уменьшаем высоту кнопок Top Up и Logout в десктопе */
#topup-btn, #logout-btn {
  padding: 8px 16px;
  font-size: 0.95rem;
  border-radius: 18px;
}
.tw-auth-buttons {
  display: flex;
  gap: 16px; /* Еще немного уменьшаем расстояние между Sign In и Sign Up в десктопе */
  margin-top: -8px; /* Еще больше поднимаем кнопки Sign In и Sign Up в десктопе */
  justify-content: center;
}
#signin-btn, #signup-btn {
  min-width: 120px;
  height: 42px;
  font-size: 1.05rem;
  font-weight: 600;
  border-radius: 21px;
  padding: 0 24px;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
}
#signup-btn {
  background: #f2f4f8;
  color: #111;
  border: none;
}
#signup-btn:active, #signup-btn:focus {
  background: #e5e7eb;
}
.tw-auth-modal {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.18);
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: fadeIn 0.15s ease-out;
  backdrop-filter: blur(2px);
  will-change: opacity;
  transform: translateZ(0); /* Принудительное аппаратное ускорение */
}
.tw-auth-modal-content {
  position: relative;
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 8px 40px 0 rgba(0,0,0,0.15);
  padding: 32px 24px 24px 24px;
  min-width: 320px;
  max-width: 90vw;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  margin: 0 auto;
  overflow: visible;
  animation: slideIn 0.2s cubic-bezier(0.34, 1.56, 0.64, 1);
  transform-origin: center;
  will-change: transform, opacity;
  transform: translateZ(0); /* Аппаратное ускорение */
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes slideIn {
  from {
    opacity: 0;
    transform: translateY(-10px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
.tw-auth-modal-content h3 {
  margin: 0 0 18px 0;
  font-size: 1.25rem;
  font-weight: 700;
  text-align: center;
}
.tw-auth-input {
  margin-bottom: 10px;
  padding: 10px 12px;
  border-radius: 8px;
  border: 1.5px solid #e5e7eb;
  font-size: 1.08rem;
  outline: none;
  transition: border 0.18s;
}
.tw-auth-input:focus {
  border: 1.5px solid #0071e3;
}
.tw-auth-modal-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.18);
  z-index: 1999;
  display: none;
}
.tw-auth-modal-close {
  position: absolute;
  top: 12px;
  right: 20px;
  background: none;
  border: none;
  font-size: 2rem;
  color: #888;
  cursor: pointer;
  z-index: 2001;
  padding: 0 4px;
  line-height: 1;
}
@media (max-width: 900px) {
  *[style*="position:sticky"], *[style*="position: sticky"], .tw-chat-header, .tw-category-header, .tw-mobile-header-flex, h3, h2, h1 {
    position: static !important;
    top: auto !important;
    z-index: auto !important;
  }
}

@media (max-width: 768px) {
  .tw-auth-modal-close {
    top: 8px;
    right: 12px;
  }
  .tw-chat-header,
  .tw-category-header,
  .tw-mobile-header-flex {
    position: static !important;
    top: auto !important;
    z-index: auto !important;
  }
}
  
  /* Оптимизация анимаций для мобильных устройств */
  .tw-auth-modal {
    animation-duration: 0.1s;
    backdrop-filter: none; /* Отключаем blur на мобильных */
  }
  
  .tw-auth-modal-content {
    animation-duration: 0.15s;
    animation-timing-function: ease-out; /* Простая анимация на мобильных */
  }
  
  /* Исправляем футер на мобильных устройствах */
  .tw-footer {
    width: 100% !important;
    margin: 0 !important;
    padding: 16px 8px !important;
    background-color: #f4f6fa !important;
    border-top: 1px solid #e5e7eb !important;
  }
  
  .tw-footer-links {
    max-width: none !important;
    padding: 0 8px !important;
  }
}
#deposit-modal {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.18);
  z-index: 2100;
  display: none;
  align-items: center;
  justify-content: center;
}
#deposit-modal .deposit-modal-content {
  position: relative;
  z-index: 2;
  background: #fff;
  border-radius: 22px;
  box-shadow: 0 8px 48px 0 rgba(0,0,0,0.13);
  padding: 22px 32px 28px 32px; /* уменьшили верхний отступ */
  min-width: 340px;
  max-width: 98vw;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  margin: 0 auto;
  animation: fadeIn .18s;
}
#deposit-modal .deposit-modal-title {
  font-size: 1.35em;
  font-weight: 700;
  text-align: center;
  margin-bottom: 18px;
}
#deposit-modal .deposit-modal-close {
  position: absolute;
  top: 8px;
  right: 20px;
  background: none;
  border: none;
  font-size: 2rem;
  color: #888;
  cursor: pointer;
  z-index: 3;
  padding: 0 4px;
  line-height: 1;
}
#deposit-modal .deposit-network-chooser-label {
  font-weight: 600;
  margin-bottom: 10px;
  text-align: center;
}
#deposit-modal .deposit-network-chooser {
  display: flex;
  gap: 16px;
  justify-content: center;
  margin-bottom: 18px;
}
#deposit-modal .deposit-network-btn {
  background: #0071e3;
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 1.08em;
  font-weight: 600;
  padding: 12px 28px; /* Возвращаем стандартные размеры */
  cursor: pointer;
  transition: background 0.18s;
  box-shadow: 0 2px 8px 0 rgba(0,0,0,0.04);
  white-space: nowrap; /* Предотвращаем перенос строк */
}
#deposit-modal .deposit-network-btn:hover {
  background: #005bb5;
}
/* Убираем стили для двухстрочных кнопок - теперь однострочные */
#deposit-modal .deposit-wallet-card {
  background: #f8fafc;
  border-radius: 12px; /* Уменьшили скругление */
  padding: 18px 16px 12px 16px;
  margin-bottom: 14px;
  box-shadow: 0 2px 8px 0 rgba(0,0,0,0.04);
}
#deposit-modal .deposit-wallet-label {
  font-weight: 600;
  margin-bottom: 8px;
  color: #0071e3;
}
#deposit-modal .deposit-wallet-row {
  display: flex;
  align-items: center;
  gap: 6px; /* Еще больше уменьшили расстояние */
  margin-bottom: 8px;
}
#deposit-modal .deposit-wallet-address {
  font-family: monospace;
  font-size: 1.13em;
  background: #fff;
  padding: 4px 8px;
  border-radius: 8px;
  word-break: break-all;
}
#deposit-modal .deposit-copy-btn {
  background: #f2f4f8;
  border: none;
  border-radius: 50%;
  padding: 7px 8px 7px 8px;
  cursor: pointer;
  transition: background 0.18s;
  display: flex;
  align-items: center;
  justify-content: center;
}
#deposit-modal .deposit-copy-btn:hover {
  background: #e0e7ef;
}
#deposit-modal .deposit-wallet-instruction {
  color: #888;
  font-size: 0.98em;
  margin-bottom: 6px;
}
#deposit-modal .deposit-sent-btn {
  background: #0071e3;
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 1.13em;
  font-weight: 700;
  padding: 14px 0;
  margin: 10px 0 0 0;
  width: 100%;
  cursor: pointer;
  transition: background 0.18s;
  box-shadow: 0 2px 8px 0 rgba(0,0,0,0.04);
}
#deposit-modal .deposit-sent-btn:hover {
  background: #005bb5;
}
#deposit-modal .deposit-back-btn {
  background: #f2f4f8;
  color: #0071e3;
  border: none;
  border-radius: 12px;
  font-size: 1.08em;
  font-weight: 600;
  padding: 12px 0;
  margin: 10px 0 0 0;
  width: 100%;
  cursor: pointer;
  transition: background 0.18s;
}
#deposit-modal .deposit-back-btn:hover {
  background: #e0e7ef;
}
#deposit-modal .deposit-status-msg {
  margin-top: 10px;
  color: #357ab8;
  font-size: 1.08em;
  text-align: center;
}
@media (max-width: 768px) {
  #deposit-modal .deposit-modal-content {
    min-width: 96vw;
    max-width: 99vw;
    padding: 18px 6px 14px 6px;
  }
  #deposit-modal .deposit-wallet-card {
    padding: 12px 6px 8px 6px;
  }
  /* Мобильные размеры для однострочных кнопок */
  #deposit-modal .deposit-network-btn {
    font-size: 1em; /* Немного уменьшаем шрифт в мобиле */
    padding: 10px 20px; /* Оптимальные размеры для мобила */
  }
}
.menu-btn-mobile {
  display: none;
  position: static;
  left: auto;
  top: auto;
  z-index: 1200;
  background: #0071e3;
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 1.08rem;
  font-weight: 700;
  padding: 10px 22px;
  box-shadow: 0 4px 12px 0 rgba(0,113,227,0.3);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
  -webkit-user-select: none;
}
.menu-btn-mobile:active, .menu-btn-mobile:focus {
  background: #005bb5;
  transform: scale(0.95);
}
/* AI Agent Styles */
.ai-agent-message {
  background: #f8f9fa;
  border-left: 3px solid #0071e3;
}

.user-message {
  background: #0071e3;
  color: white;
  margin-left: 20%;
  text-align: right;
}

.typing-indicator {
  opacity: 0.7;
  animation: pulse 1.5s infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 0.7; }
  50% { opacity: 1; }
}

#ai-chat-input:focus {
  border-color: #0071e3;
  box-shadow: 0 0 0 3px rgba(0, 113, 227, 0.1);
}

#ai-chat-send:hover {
  background: #005bb5;
}

/* Стили для мобильной версии */
@media (max-width: 768px) {
  /* Кнопка меню показывается только когда нужно */
  .menu-btn-mobile {
    display: none !important; /* По умолчанию скрыта */
    position: static !important;
    left: auto !important;
    top: auto !important;
    z-index: 1200 !important;
    background: #0071e3 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 12px !important;
    font-size: 1.08rem !important;
    font-weight: 700 !important;
    padding: 10px 22px !important;
    box-shadow: 0 4px 12px 0 rgba(0,113,227,0.3) !important;
    cursor: pointer !important;
    align-items: center !important;
    justify-content: center !important;
    transition: all 0.2s ease !important;
    margin-bottom: 0 !important;
  }
  
  /* Показываем кнопку только в активном чате */
  .tw-chat-section.active .menu-btn-mobile {
    display: flex !important;
  }
  
  .menu-btn-mobile:active, .menu-btn-mobile:focus {
    background: #005bb5 !important;
    transform: scale(0.95) !important;
  }
  .tw-auth-modal-content {
    min-width: 90vw;
    max-width: 98vw;
    padding: 24px 8px 18px 8px;
    margin-top: 32px;
  }

  body, .tw-chat-header, .tw-message-bubble, .tw-auth-input, .tw-btn, .tw-webinar-title, .tw-webinar-desc {
    font-size: 1.22rem !important;
    line-height: 1.7 !important;
  }
  .tw-message-bubble {
    padding: 22px 18px;
  }
  .tw-chat-header {
    padding-top: 80px;
    text-align: center;
    padding-left: 0;
  }
  .tw-main-layout {
    flex-direction: column;
    max-width: 100vw;
    border-radius: 0;
    box-shadow: none;
    min-height: 100vh;
  }
  .tw-footer {
    display: none !important; /* Скрыт и на мобиле */
  }
  .tw-sidebar {
    width: 100vw;
    border-right: none;
    border-bottom: 1px solid #e5e7eb;
    padding: 0;
    background: #fff;
    min-height: unset;
    box-shadow: none;
  }
  .tw-account-box {
    margin: 0;
    border-radius: 0;
    box-shadow: none;
    padding: 4px 10px 0px 10px; /* Критически уменьшаем высоту контейнера в мобиле */
    background: #fff;
    border-bottom: none; /* Убираем разделительную полоску в мобиле */
  }
  /* Убираем sticky поведение для неавторизованного состояния в мобиле */
  .tw-account-box.unauthenticated {
    position: static;
  }
  .tw-auth-buttons {
    margin-bottom: 10px;
    margin-top: 6px; /* Спускаем кнопки немного вниз на мобиле */
    gap: 28px; /* Уменьшаем расстояние между Sign In и Sign Up на мобиле - было слишком большое */
  }
  /* Увеличиваем размеры блока баланса в мобиле авторизованном состоянии */
  .tw-account-box:has(#account-balance-box) #account-balance-box {
    margin-top: 18px !important;
  }
  /* Увеличиваем размер текста Balance: в мобиле */
  .tw-account-box:has(#account-balance-box) .tw-account-balance {
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    margin-bottom: 8px !important;
  }
  /* Увеличиваем отступ снизу для авторизованного состояния */
  .tw-account-box:has(#account-balance-box) {
    padding-bottom: 12px !important;
  }
  .tw-account-buttons {
    gap: 50px; /* Увеличиваем расстояние между Top Up и Logout на мобиле */
    margin-top: 12px; /* Увеличиваем отступ сверху */
  }
  .tw-account-buttons .tw-btn {
    padding: 10px 18px; /* Увеличиваем padding */
    font-size: 1.1rem; /* Увеличиваем размер шрифта */
  }
  /* Приплюскиваем кнопки Top Up и Logout на мобиле, сохраняя размер шрифта */
  #topup-btn, #logout-btn {
    padding: 8px 18px !important; /* Уменьшаем вертикальный padding */
    font-size: 1.1rem !important; /* Оставляем размер шрифта */
    border-radius: 18px !important; /* Немного уменьшаем скругление */
    height: auto !important;
    min-height: 36px !important; /* Уменьшаем минимальную высоту */
    font-weight: 600 !important;
    line-height: 1.2 !important; /* Добавляем контроль межстрочного интервала */
  }
  /* Уменьшаем высоту кнопок Sign In и Sign Up на мобиле, сохраняя размер текста */
  #signin-btn, #signup-btn {
    height: 36px !important;
    padding: 0 20px !important;
    border-radius: 18px !important;
    min-width: 110px !important;
  }
  #webinar-list {
    padding: 8px 8px 16px 8px;
    gap: 10px;
  }
  .tw-webinar-item {
    border-radius: 14px;
    padding: 14px 12px;
    font-size: 1.08rem;
  }
  .tw-chat-section {
    display: none;
    background: #f8f9fb;
    min-height: 0;
    flex: none;
  }
  .tw-chat-section.active {
    display: flex !important;
    flex-direction: column;
    height: 100vh;
    height: calc(100vh - env(safe-area-inset-bottom, 0px)) !important;
    background: #f8f9fb;
    position: static !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    bottom: auto !important;
    z-index: 1001;
    animation: fadeIn 0.2s;
    overflow: hidden;
    padding-bottom: env(safe-area-inset-bottom, 0px) !important;
    box-sizing: border-box !important;
  }
  .tw-chat-messages {
    flex: 1 1 auto;
    overflow-y: auto;
    padding-bottom: 20px !important;
    margin-bottom: 0 !important;
    /* Убираем отступ справа на мобиле */
    padding-right: 16px !important;
  }
  .tw-next-btn {
    margin: 12px auto 0 auto !important;
    display: block;
  }
  .tw-chat-controls {
    display: none !important;
  }
  .tw-mobile-menu-btn {
    display: block;
    position: absolute;
    left: 16px;
    top: 18px;
    z-index: 1100;
    background: none;
    border: none;
    font-size: 2rem;
    color: #0071e3;
    cursor: pointer;
  }
  @keyframes fadeIn {
    from { opacity: 0; }
    to { opacity: 1; }
  }
}
.tw-mobile-header-flex {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: 100%;
  gap: 8px;
}
.tw-mobile-header-center {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.tw-mobile-webinar-title {
  font-weight: 700;
  font-size: 1.08em;
  margin-bottom: 2px;
}
/* Специальные стили для iPhone 14 Pro Max и больших iPhone */
@media (max-width: 768px) and (min-width: 390px) and (min-height: 844px) {
  /* Исправляем невидимые блоки для больших iPhone */
  .tw-chat-section.active {
    /* Учитываем Dynamic Island и safe-area */
    padding-top: env(safe-area-inset-top, 0px) !important;
    padding-bottom: env(safe-area-inset-bottom, 0px) !important;
    height: 100vh !important;
    height: calc(100vh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px)) !important;
    margin: 0 !important;
    box-sizing: border-box !important;
  }
  
  /* Исправляем заголовок чата */
  .tw-chat-header {
    padding-top: calc(60px + env(safe-area-inset-top, 0px)) !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
    text-align: center !important;
    background: #f8f9fb !important;
    position: relative !important;
    z-index: 1100 !important;
  }
  
  /* Исправляем область сообщений */
  .tw-chat-messages {
    padding-top: 16px !important;
    padding-bottom: calc(20px + env(safe-area-inset-bottom, 0px)) !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
    max-height: calc(100vh - 140px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px)) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    margin: 0 !important;
  }
  
  /* Кнопка меню с учетом safe-area */
  .menu-btn-mobile, #mobile-menu-btn {
    top: calc(16px + env(safe-area-inset-top, 0px)) !important;
    left: 16px !important;
    z-index: 1300 !important;
  }
  
  /* Убираем невидимые прямоугольники */
  .tw-chat-section.active::before,
  .tw-chat-section.active::after {
    display: none !important;
  }
  
  /* Предотвращаем перекрытие элементов */
  .tw-message-bubble {
    position: relative !important;
    z-index: auto !important;
    margin: 0 !important;
    clear: both !important;
  }
}

/* Специальные стили для iPhone SE и маленьких экранов */
@media (max-width: 375px) {
  /* Исправляем позиционирование кнопки меню для маленьких экранов */
  .menu-btn-mobile {
    left: 12px !important;
    top: 12px !important;
    padding: 8px 16px !important;
    font-size: 1rem !important;
  }
  
  /* Убираем невидимые блоки и исправляем высоту */
  .tw-chat-section.active {
    height: 100vh !important;
    height: calc(100vh - env(safe-area-inset-bottom, 0px)) !important;
    padding-bottom: env(safe-area-inset-bottom, 0px) !important;
    margin-bottom: 0 !important;
  }
  
  /* Исправляем чат для маленьких экранов */
  .tw-chat-messages {
    padding-bottom: calc(20px + env(safe-area-inset-bottom, 0px)) !important;
    margin-bottom: 0 !important;
    max-height: calc(100vh - 80px - env(safe-area-inset-bottom, 0px)) !important;
  }
  
  .tw-chat-header {
    padding-top: 50px !important; /* Место для кнопки меню */
    padding-left: 12px !important;
    padding-right: 12px !important;
    text-align: center !important;
    font-size: 1.1rem !important;
  }
  
  /* Убираем лишние отступы в сайдбаре */
  .tw-sidebar {
    padding-bottom: env(safe-area-inset-bottom, 0px) !important;
  }
  
  #webinar-list {
    padding-bottom: calc(16px + env(safe-area-inset-bottom, 0px)) !important;
  }
  
  /* Исправляем кнопки для маленьких экранов */
  .tw-next-btn {
    margin-bottom: calc(20px + env(safe-area-inset-bottom, 0px)) !important;
  }
}
@media (max-width: 768px) {
  .tw-mobile-header-flex {
    padding: 0 4px;
  }
  .tw-mobile-header-center {
    margin-left: auto;
    margin-right: auto;
  }
}

/* Если чего-то нет — добавьте */
.tw-fullscreen-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.7); /* полупрозрачный чёрный */
  z-index: 9999; /* Высокий z-index */
}

.tw-fullscreen-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: white;
  z-index: 10000; /* Выше overlay */
  overflow-y: auto;
  padding: 20px;
}

.tw-modal-close-btn {
  position: absolute;
  top: 10px;
  right: 10px;
  background: none;
  border: none;
  font-size: 24px;
  color: #333;
  cursor: pointer;
}

.tw-modal-content h2 {
  margin-bottom: 20px;
}

.tw-modal-text {
  max-width: 800px;
  margin: 0 auto;
}

.tw-footer {
  padding: 16px;
  text-align: center;
  background-color: #f4f6fa;
  border-top: 1px solid #e5e7eb;
  width: 100% !important;
  margin: 0 !important;
  box-sizing: border-box;
  clear: both;
  position: relative;
  left: 0 !important;
  right: 0 !important;
  display: none !important; /* Скрыт по умолчанию, можно включить изменив на block */
}

.tw-footer-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 16px;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

.tw-footer-link-btn {
  background: none;
  border: none;
  color: #0071e3;
  cursor: pointer;
  text-decoration: underline;
}

/* Для крестика в модалках Privacy/Terms — если вернешься к модалкам */
.tw-modal-close-btn {
  position: absolute !important;
  top: 10px !important;
  right: 10px !important;
  background: red !important;
  color: white !important;
  border: none !important;
  font-size: 24px !important;
  cursor: pointer !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  text-align: center !important;
  line-height: 38px !important;
  z-index: 10001 !important; /* Быстрее overlay */
  display: block !important;
}

/* Для гарантии видимости и скролла — если вернешься */
.tw-modal-content {
  overflow-y: auto !important;
  max-height: 70vh !important;
  padding: 20px !important;
  margin-top: 50px !important; /* Чтобы не перекрывался крестиком */
}
/* Фикс мелькания: скрываем дефолтные элементы до загрузки */
#account-balance-box, #signin-btn, #signup-btn, #topup-btn, #logout-btn {
  display: none;
}
/* Убираем Loading... у баланса */
#account-balance::before {
  display: none;
}
#account-balance:not(.empty)::before {
  display: none;
}
/* Скрываем весь контент до полной загрузки */
body.loading .tw-main-layout,
body.loading .tw-footer {
  opacity: 0;
  transition: opacity 0.3s ease-in-out;
}
body:not(.loading) .tw-main-layout,
body:not(.loading) .tw-footer {
  opacity: 1;
}
/* Убираем индикатор загрузки */
body.loading::before {
  display: none;
}
/* Скроллбары полностью скрыты - см. раздел ниже */

/* --- Оптимизированный мобильный скролл для лучшей производительности --- */
@media (max-width: 768px) {
  .tw-sidebar,
  .tw-chat-section.active {
    overscroll-behavior: contain;
    /* Убираем -webkit-overflow-scrolling: touch для лучшей производительности */
    -webkit-overflow-scrolling: auto; /* Отключаем momentum scrolling для предотвращения багов */
  }
  #webinar-list {
    /* Явно скроллим внутри вебинар-списка на мобиле */
    overflow-y: auto;
    overscroll-behavior: contain;
    /* Убираем плавность скролла для предотвращения автоматического выделения */
    scroll-behavior: auto;
    -webkit-overflow-scrolling: auto;
    /* Добавляем стабилизацию скролла */
    scroll-snap-type: none;
    touch-action: pan-y;
  }
  /* Убираем ограничение высоты для неавторизованного состояния */
  .tw-sidebar.unauthenticated #webinar-list {
    max-height: none;
  }
  .tw-chat-messages {
    max-height: calc(100vh - 120px);
    overflow-y: auto;
    overscroll-behavior: contain;
    /* Убираем плавность скролла для предотвращения автоматического выделения */
    scroll-behavior: auto;
    -webkit-overflow-scrolling: auto;
    touch-action: pan-y;
  }
}

@media (max-width: 768px) {
  /* Убираем избыточные отступы внизу чата */
  .tw-chat-messages {
    padding-bottom: 20px !important;
    /* Убираем лишние safe-area-inset отступы */
  }
  .tw-chat-section.active {
    /* Минимальные отступы для корректного отображения */
    padding-bottom: env(safe-area-inset-bottom, 0px);
    box-sizing: border-box;
  }
  .tw-next-btn, .tw-btn.tw-btn-primary.tw-next-btn {
    margin-bottom: 20px !important;
    /* Убираем избыточные отступы у кнопки */
  }
}

@media (max-width: 768px) {
  .tw-sidebar {
    padding-top: 0 !important;
    margin-top: 0 !important;
    /* Оптимизация для лучшего скролла */
    will-change: scroll-position;
    transform: translateZ(0);
    /* Предотвращаем случайное выделение при скролле */
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-touch-callout: none;
    -webkit-tap-highlight-color: transparent;
  }
  #webinar-list {
    margin-top: 0 !important;
    padding-top: 0px !important;
    /* убираем нежелательные верхние отступы для предотвращения бага полоски */
    /* Оптимизация для лучшего скролла */
    will-change: scroll-position;
    transform: translateZ(0);
    /* Предотвращаем случайное выделение при скролле */
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-touch-callout: none;
    -webkit-tap-highlight-color: transparent;
  }
  .tw-chat-messages {
    /* Оптимизация для лучшего скролла */
    will-change: scroll-position;
    transform: translateZ(0);
  }

  /* Не даём "залипать" шапке над списком */
  .tw-main-layout,
  .tw-sidebar,
  #webinar-list {
    box-shadow: none !important;
  }
  
  /* Убираем границы у заголовков категорий в мобильной версии */
  .tw-category-header h3 {
    border: none !important;
    border-bottom: none !important;
  }
  
  /* Предотвращаем случайное выделение кнопок при скролле */
  .tw-category-item,
  .tw-webinar-item {
    -webkit-user-select: none !important;
    -moz-user-select: none !important;
    -ms-user-select: none !important;
    user-select: none !important;
    -webkit-touch-callout: none !important;
    -webkit-tap-highlight-color: transparent !important;
    /* Предотвращаем случайное выделение при скролле */
    pointer-events: auto;
  }
  
  /* Отключаем все эффекты hover на мобильных устройствах */
  .tw-category-item:hover,
  .tw-webinar-item:hover {
    transform: none !important;
  }
}

/* Анимация для индикатора загрузки */
@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.tw-loading-indicator {
  background: #fff;
  border-radius: 18px;
  box-shadow: 0 2px 12px 0 rgba(0,0,0,0.04);
  margin-bottom: 12px;
}

/* === ИСПРАВЛЕНИЕ НЕВИДИМЫХ БЛОКОВ ДЛЯ iPhone === */

/* Убираем лишние отступы и невидимые блоки */
@media (max-width: 768px) {
  /* Основные контейнеры */
  html, body {
    margin: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    height: 100% !important;
    overflow-x: hidden !important;
    position: relative !important;
  }
  
  /* Убираем лишние отступы снизу */
  .tw-main-layout {
    margin: 0 !important;
    padding: 0 !important;
    min-height: 100vh !important;
    position: relative !important;
  }
  
  /* Исправляем сайдбар */
  .tw-sidebar {
    margin: 0 !important;
    padding: 0 !important;
    padding-top: 0 !important;
    width: 100vw !important;
    min-height: calc(100vh - env(safe-area-inset-bottom, 0px)) !important;
    padding-bottom: env(safe-area-inset-bottom, 0px) !important;
  }
  
  /* Убираем невидимые блоки в чате */
  .tw-chat-section.active {
    margin: 0 !important;
    padding: 0 !important;
    padding-bottom: env(safe-area-inset-bottom, 0px) !important;
    width: 100vw !important;
    height: 100vh !important;
    max-height: 100vh !important;
    overflow: hidden !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
  }
  
  /* Убираем любые псевдоэлементы которые могут создавать невидимые блоки */
  .tw-chat-section::before,
  .tw-chat-section::after,
  .tw-chat-section.active::before,
  .tw-chat-section.active::after,
  .tw-chat-messages::before,
  .tw-chat-messages::after,
  .tw-main-layout::before,
  .tw-main-layout::after {
    display: none !important;
    content: none !important;
  }
  
  /* Исправляем область сообщений */
  .tw-chat-messages {
    margin: 0 !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
    padding-top: 16px !important;
    padding-bottom: calc(20px + env(safe-area-inset-bottom, 0px)) !important;
    max-height: calc(100vh - 120px - env(safe-area-inset-bottom, 0px)) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }
}

/* === ПОЛНОСТЬЮ СКРЫТЫЕ СКРОЛЛБАРЫ === */

/* Полностью скрываем все скроллбары */
*, *::before, *::after {
  scrollbar-width: none !important;
  -ms-overflow-style: none !important;
}

*::-webkit-scrollbar,
*::before::-webkit-scrollbar,
*::after::-webkit-scrollbar {
  width: 0px !important;
  height: 0px !important;
  display: none !important;
}

*::-webkit-scrollbar-track,
*::before::-webkit-scrollbar-track,
*::after::-webkit-scrollbar-track {
  display: none !important;
}

*::-webkit-scrollbar-thumb,
*::before::-webkit-scrollbar-thumb,
*::after::-webkit-scrollbar-thumb {
  display: none !important;
}

/* Скрываем скроллбар сайдбара */
.tw-sidebar::-webkit-scrollbar {
  width: 0px !important;
  display: none !important;
}

.tw-sidebar::-webkit-scrollbar-track {
  display: none !important;
}

.tw-sidebar::-webkit-scrollbar-thumb {
  display: none !important;
}

/* Скрываем скроллбар чата */
.tw-chat-messages::-webkit-scrollbar {
  width: 0px !important;
  display: none !important;
}

.tw-chat-messages::-webkit-scrollbar-track {
  display: none !important;
}

.tw-chat-messages::-webkit-scrollbar-thumb {
  display: none !important;
}

/* Скрываем скроллбары на мобильных устройствах */
@media (max-width: 768px) {
  .tw-sidebar::-webkit-scrollbar,
  .tw-chat-messages::-webkit-scrollbar {
    display: none;
  }
  
  .tw-sidebar,
  .tw-chat-messages {
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
}

/* Для Firefox - полностью скрываем скроллбары */
.tw-sidebar,
.tw-chat-messages {
  scrollbar-width: none !important;
  -ms-overflow-style: none !important;
}

@media (max-width: 768px) {
  .tw-sidebar,
  .tw-chat-messages {
    scrollbar-width: none !important;
  }
}

/* Скроллбары полностью скрыты через CSS выше */
.tw-sidebar {
  scroll-behavior: smooth;
}

.tw-chat-messages {
  scroll-behavior: smooth;
}

/* === ФИНАЛЬНЫЕ ИСПРАВЛЕНИЯ ДЛЯ iPhone SE === */
@media (max-width: 768px) {
  /* Предотвращаем горизонтальную прокрутку */
  * {
    max-width: 100vw !important;
    box-sizing: border-box !important;
  }
  
  /* Убираем лишние отступы у корневых элементов */
  body {
    position: relative !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
  }
  
  /* Кнопка меню показывается только когда нужно */
  #mobile-menu-btn {
    display: none !important; /* По умолчанию скрыта */
    position: fixed !important;
    left: 16px !important;
    top: 16px !important;
    z-index: 1200 !important;
    background: #0071e3 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 12px !important;
    font-size: 1.08rem !important;
    font-weight: 700 !important;
    padding: 10px 22px !important;
    box-shadow: 0 4px 12px 0 rgba(0,113,227,0.3) !important;
    cursor: pointer !important;
    transition: all 0.2s ease !important;
    -webkit-tap-highlight-color: transparent !important;
    user-select: none !important;
    -webkit-user-select: none !important;
  }
  
  /* Показываем кнопку только в активном чате */
  .tw-chat-section.active #mobile-menu-btn {
    display: block !important;
  }
  
  #mobile-menu-btn:active, #mobile-menu-btn:focus {
    background: #005bb5 !important;
    transform: scale(0.95) !important;
  }
  
  /* Убираем проблемы с высотой на iPhone */
  .tw-chat-section.active {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    height: calc(var(--vh, 1vh) * 100) !important;
    margin: 0 !important;
    padding: 0 !important;
    padding-bottom: env(safe-area-inset-bottom, 0px) !important;
    overflow: hidden !important;
  }
}