
div#twilio-chat {
    margin-top: -70px;
}
.twilio-container {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  min-height: 100vh !important;
  
  padding: 20px !important;
  box-sizing: border-box !important;
      width: 100%;
}

.mobile-frame
 {
    background: #e9eef3 !important;
    width: 100% !important;
    height: 681px !important;
    border-radius: 25px !important;
    /* box-shadow: 0 0 20px rgba(0, 0, 0, 0.15) !important; */
    display: flex !important
;
    flex-direction: column !important;
    position: relative !important;
    display: grid !important
;
    grid-template-columns: 80% 20%;
}

/* ===== Header ===== */
.mobile-header {
    background: #007bff !important;
    color: #fff !important;
    padding: 15px !important;
    font-size: 18px !important;
    display: flex !important
;
    justify-content: space-between !important;
    align-items: center !important;
    font-weight: bold !important;
    gap: 8px !important;
    border-radius: 10px 0px 0px 0px;
}
.search-field {
    position: relative;
    width: 100%;
    display: flex
;
    align-items: center;
    margin-bottom: 20px;
}
.search-field button {
    background: transparent !important;
    border: 0 !important;
    position: absolute;
    top: -2px;
    display: flex
;
    justify-content: space-between;
    right: -20px;
    align-items: center;
}
.search-field button img {
    width: 24px;
    height: 24px;
    cursor: pointer;
    opacity: 0.7;
}
.mobile-header button#refreshMessages {
  background: rgba(255,255,255,0.12) !important;
  color: #000 !important;
  border: none !important;
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 18px !important;
  cursor: pointer !important;
  transition: transform 0.25s ease, background 0.3s ease !important;
}
.number-wrapper {
    height: 100%;
    background: #fff;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.15) !important;
    padding: 10px;
    border-radius: 0 10px 10px 0;
}
.sms-form button {
    font-size: 22px !important;
   
}

.number-data {
    display: flex
;
    flex-direction: column;
    gap: 10px;
    position: sticky;
    top: 40px;
}
.number-carousel {
  display: flex;
  justify-content: start;
  padding: 10px;
}

.number-item {
   
    color: #000 !important;
    border-radius: 8px !important;
    padding: 6px 14px !important;
    margin: 0 5px !important;
    cursor: pointer !important;
    transition: background 0.3s !important;
    background: transparent !important;
    border-bottom: 1px solid rgba(0, 0, 0, 0.1);
    display:flex;
    align-items: center !important;
    gap:10px;
}
.number-item img
{
    width: 24px;
    height: 24px !important;
    transition:filter 0.3s !important;
    filter:invert(0);
opacity: 0.8 !important;
}
.number-item.active,
.number-item:hover {
  background: #cd1616 !important;
  color: #fff !important;
  border: 1px solid #cd1616 !important;
}
.number-item:hover img{
        filter:invert(1);
}
.number-item label {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    width: 100% !important;
    cursor: pointer !important;
}
.number-item input[type="checkbox"] {
    transform: scale(1.2) !important;
    accent-color: #007bff !important;
}
.number-item span {
    font-size: 14px !important;
    color: #333 !important;
}
.mobile-header button#refreshMessages:hover {
  transform: rotate(20deg) !important;
  background: rgba(255,255,255,0.16) !important;
}

.mobile-header button#refreshMessages.loading {
  animation: icon-spin 1s linear infinite !important;
}

.mobile-header button#refreshMessages[disabled] {
  opacity: 0.6 !important;
  cursor: not-allowed !important;
}

/* ===== Message Area ===== */
.messages-body {
    flex: 1 !important;
    overflow-y: auto !important;
    padding: 15px !important;
    background: #e9eef3 !important;
    display: flex !important
;
    flex-direction: column !important;
    gap: 10px !important;
    font-size: 14px !important;
    height: 500px;
    border-radius: 10px;
}

/* Message bubbles */
.message {
  padding: 10px 14px !important;
  border-radius: 15px !important;
  width: fit-content !important;
  max-width: 80% !important;
  animation-duration: 0.6s !important;
  animation-fill-mode: both !important;
  position: relative !important;
  word-break: break-word !important;
}

/* Alignment and colors */
.message.sent {
  align-self: flex-start !important;
  background: #0c61bc !important;
  color: #fff !important;
  animation: send-left-anim 0.45s forwards !important;
}

.message.received {
  align-self: flex-end !important;
  background: #fff !important;
  color: #333 !important;
  border: 1px solid #ddd !important;
  animation: receive-right-anim 0.45s forwards !important;
}

/* Temporary and error states */
.message.sending {
  opacity: 0 !important;
  transform: translateX(-30px) !important;
  animation: send-left-anim 0.45s forwards !important;
}

.message.failed {
  border: 1px solid #ff4d4f !important;
  background: #fff1f0 !important;
  color: #6b0000 !important;
}

/* Meta info */
.message .meta {
  font-size: 11px !important;
  margin-top: 4px !important;
  text-align: right !important;
}

.message.sent .meta { color: #f0f0f0 !important; }
.message.received .meta { color: #666 !important; }

/* ===== Load Button ===== */
.divider {
  text-align: center !important;
  padding: 10px !important;
  border-top: 1px solid #ccc !important;
}

.divider button {
  background: #007bff !important;
  color: #fff !important;
  border: none !important;
  padding: 8px 16px !important;
  border-radius: 5px !important;
  cursor: pointer !important;
  transition: background 0.3s ease !important;
}

.divider button:hover { background: #0056b3 !important; }

/* ===== Form ===== */
.sms-form {
    display: flex !important
;
    flex-direction: column !important;
    padding: 10px !important;
    background: #e9eef3 !important;
    border-top: 1px solid #ccc !important;
    border-radius: 0px 0px 0px 10px;
    margin-top: 10px;
}

.sms-form input,
.sms-form textarea {
  margin-bottom: 10px !important;
  padding: 8px !important;
  border: 1px solid #ccc !important;
  border-radius: 5px !important;
  font-size: 14px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.sms-form textarea {
  height: 60px !important;
  resize: none !important;
}

.sms-form button {
  background: #007bff !important;
  color: #fff !important;
  border: none !important;
  padding: 10px !important;
  border-radius: 5px !important;
  cursor: pointer !important;
  transition: background 0.3s ease !important;
}

.sms-form button:hover { background: #0056b3 !important; }

/* ===== Animations ===== */
@keyframes send-left-anim {
  from { opacity: 0 !important; transform: translateX(-30px) !important; }
  to { opacity: 1 !important; transform: translateX(0) !important; }
}

@keyframes receive-right-anim {
  from { opacity: 0 !important; transform: translateX(40px) !important; }
  to { opacity: 1 !important; transform: translateX(0) !important; }
}

@keyframes icon-spin {
  from { transform: rotate(0deg) !important; }
  to { transform: rotate(360deg) !important; }
}

@keyframes small-spin {
  from { transform: rotate(0deg) !important; }
  to { transform: rotate(360deg) !important; }
}

/* Small spinner for sending bubble */
.message.sending .meta::before {
  content: "" !important;
  display: inline-block !important;
  width: 14px !important;
  height: 14px !important;
  margin-right: 8px !important;
  border: 2px solid rgba(0,0,0,0.15) !important;
  border-top-color: rgba(0,0,0,0.6) !important;
  border-radius: 50% !important;
  animation: small-spin 0.8s linear infinite !important;
  vertical-align: middle !important;
}

/* ===== Scrollbar ===== */
.messages-body::-webkit-scrollbar {
  width: 6px !important;
}

.messages-body::-webkit-scrollbar-thumb {
  background: #bbb !important;
  border-radius: 10px !important;
}

/* ===== Responsive ===== */
@media (max-width: 480px) {
  .mobile-frame { width: 100% !important; height: 90vh !important; border-radius: 20px !important; }
  .mobile-header { font-size: 16px !important; padding: 10px !important; }
  .messages-body { padding: 10px !important; gap: 6px !important; }
  .message { font-size: 13px !important; padding: 8px 12px !important; }
  .sms-form input, .sms-form textarea { font-size: 13px !important; padding: 6px !important; }
  .sms-form button, .divider button { font-size: 14px !important; padding: 8px !important; }
}

@media (max-width: 360px) {
  .mobile-frame { height: 85vh !important; }
  .message { max-width: 90% !important; }
  .mobile-header span { font-size: 14px !important; }
}
