
/* ===== Container externo do mockup ===== */
.device-preview-container[data-v-e4b5213a] {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  box-sizing: border-box;
}

/* ===== iPhone frame ===== */
.phone-mockup[data-v-e4b5213a] {
  display: flex;
  align-items: center;
  justify-content: center;
}
.phone-frame[data-v-e4b5213a] {
  position: relative;
  width: 320px;
  height: 650px;
  border-radius: 56px;
  background: linear-gradient(to bottom, #020617, #000000);
  overflow: hidden;
  border: 14px solid #020617; /* slate-900 aproximado */
  box-sizing: border-box;
}

/* Notch / speaker */
.phone-notch[data-v-e4b5213a] {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 144px;
  height: 28px;
  background-color: #020617;
  border-bottom-left-radius: 24px;
  border-bottom-right-radius: 24px;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.phone-notch-bar[data-v-e4b5213a] {
  width: 56px;
  height: 4px;
  border-radius: 999px;
  background-color: #1e293b;
}
.phone-notch-dot[data-v-e4b5213a] {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background-color: #1e293b;
}

/* Inner screen */
.phone-inner[data-v-e4b5213a] {
  position: absolute;
  inset: 3px;
  background-color: #111b21;
  border-radius: 48px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

/* ===== Status bar ===== */
.phone-status-bar[data-v-e4b5213a] {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 24px;
  font-size: 11px;
  font-weight: 500;
  background-color: #111b21;
  color: #8696a0;
  box-sizing: border-box;
}
.phone-status-time[data-v-e4b5213a] {
  font-weight: 600;
}
.phone-status-icons[data-v-e4b5213a] {
  display: flex;
  align-items: center;
  gap: 6px;
  color: #ffffff;
}

/* Status icons via sprite (Icon.vue) */
.phone-status-signal-icon[data-v-e4b5213a],
.phone-status-wifi-icon[data-v-e4b5213a],
.phone-status-battery-icon[data-v-e4b5213a] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

/* ===== WhatsApp header ===== */
.phone-header[data-v-e4b5213a] {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background-color: #202c33;
  box-sizing: border-box;
}
.phone-header-avatar[data-v-e4b5213a] {
  flex-shrink: 0;
}
.phone-header-avatar-circle[data-v-e4b5213a] {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background-color: #25d366;
  display: flex;
  align-items: center;
  justify-content: center;
}
.phone-header-avatar-initials[data-v-e4b5213a] {
  color: #ffffff;
  font-size: 14px;
  font-weight: 600;
}
.phone-header-text[data-v-e4b5213a] {
  flex: 1;
  min-width: 0;
}
.phone-header-title[data-v-e4b5213a] {
  font-size: 15px;
  font-weight: 600;
  color: #ffffff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.phone-header-subtitle[data-v-e4b5213a] {
  font-size: 13px;
  color: #8696a0;
}
.phone-header-badge[data-v-e4b5213a] {
  width: 20px;
  height: 20px;
  border-radius: 999px;
  background-color: #25d366;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.phone-header-badge-check[data-v-e4b5213a] {
  color: #ffffff;
  font-size: 11px;
  font-weight: 700;
}

/* ===== WhatsApp chat container ===== */
.phone-chat[data-v-e4b5213a] {
  flex: 1;
  background-color: #111b21;
  overflow: hidden;
  position: relative;
}

/* Background pattern aproximada */
.phone-chat-bg[data-v-e4b5213a] {
  width: 100%;
  height: 100%;
  background-image:
    radial-gradient(circle at 0 0, rgba(17, 27, 33, 0.4) 0, transparent 20px),
    radial-gradient(circle at 100% 0, rgba(17, 27, 33, 0.4) 0, transparent 20px),
    radial-gradient(circle at 0 100%, rgba(17, 27, 33, 0.4) 0, transparent 20px),
    radial-gradient(circle at 100% 100%, rgba(17, 27, 33, 0.4) 0, transparent 20px);
  background-color: #111b21;
  overflow-y: auto;
}
.phone-chat-content[data-v-e4b5213a] {
  display: flex;
  flex-direction: column;
}

/* Message row */
.phone-message-row[data-v-e4b5213a] {
  padding: 8px 12px;
  box-sizing: border-box;
}
.phone-message-bubble[data-v-e4b5213a] {
  background-color: #202c33;
  border-radius: 18px;
  padding: 12px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.45);
  text-align: left;
}

/* Bubble header */
.phone-message-header[data-v-e4b5213a] {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.phone-message-header-avatar[data-v-e4b5213a] {
  flex-shrink: 0;
}
.phone-message-header-avatar-circle[data-v-e4b5213a] {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background-color: #25d366;
  display: flex;
  align-items: center;
  justify-content: center;
}
.phone-message-header-avatar-initials[data-v-e4b5213a] {
  font-size: 12px;
  font-weight: 600;
  color: #ffffff;
}
.phone-message-header-text[data-v-e4b5213a] {
  flex: 1;
  min-width: 0;
}
.phone-message-header-title[data-v-e4b5213a] {
  font-size: 14px;
  font-weight: 500;
  color: #25d366;
}
.phone-message-header-subtitle[data-v-e4b5213a] {
  font-size: 12px;
  color: #8696a0;
}

/* Media preview area (placeholder) */
.phone-media-preview[data-v-e4b5213a] {
  margin-bottom: 8px;
  border-radius: 12px;
  overflow: hidden;
  background-color: #182229;
}
.phone-media-preview-inner[data-v-e4b5213a] {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px;
}
.phone-media-icon[data-v-e4b5213a] {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background-color: #25d366;
  flex-shrink: 0;
}
.phone-media-text[data-v-e4b5213a] {
  flex: 1;
  min-width: 0;
}
.phone-media-title[data-v-e4b5213a] {
  font-size: 14px;
  font-weight: 500;
  color: #e9edef;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.phone-media-subtitle[data-v-e4b5213a] {
  font-size: 13px;
  color: #8696a0;
  margin-top: 2px;
}

/* Message text */
.phone-message-text[data-v-e4b5213a] {
  font-size: 15px;
  line-height: 1.4;
  color: #e9edef;
  word-break: break-word;
  text-align: left;
}

/* Message meta (time) */
.phone-message-meta[data-v-e4b5213a] {
  display: flex;
  justify-content: flex-end;
  margin-top: 6px;
}
.phone-message-time[data-v-e4b5213a] {
  font-size: 11px;
  color: #8696a0;
}
.phone-message-header-text-line[data-v-e4b5213a] {
  font-size: 14px;
  font-weight: 600;
  color: #e9edef;
  margin-bottom: 6px;
  line-height: 1.35;
  text-align: left;
}
.phone-message-footer[data-v-e4b5213a] {
  font-size: 12px;
  color: #8696a0;
  margin-top: 6px;
  line-height: 1.35;
  text-align: left;
}
.phone-message-buttons[data-v-e4b5213a] {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  margin-top: 8px;
  justify-content: flex-start;
}
.phone-message-button[data-v-e4b5213a] {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 500;
  color: #25d366;
  background-color: #182229;
  border: 1px solid #2a3942;
  min-width: 0;
  white-space: nowrap;
  flex-shrink: 0;
}
.phone-message-button-full[data-v-e4b5213a] {
  flex-shrink: 0;
}
.phone-media-preview-img[data-v-e4b5213a] {
  width: 100%;
  height: 160px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.phone-media-preview-video[data-v-e4b5213a] {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  height: 120px;
  background-color: #182229;
  color: #8696a0;
  font-size: 12px;
}
.phone-media-icon--image[data-v-e4b5213a],
.phone-media-icon--video[data-v-e4b5213a],
.phone-media-icon--document[data-v-e4b5213a] {
  background-color: #2a3942;
}

/* Extra empty state */
.phone-chat-empty[data-v-e4b5213a] {
  text-align: center;
  padding: 40px 24px 24px;
  color: #e9edef;
}
.phone-chat-empty-icon[data-v-e4b5213a] {
  width: 64px;
  height: 64px;
  border-radius: 999px;
  background-color: #202c33;
  margin: 0 auto 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #8696a0;
}
.phone-chat-empty-title[data-v-e4b5213a] {
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 4px;
}
.phone-chat-empty-subtitle[data-v-e4b5213a] {
  font-size: 12px;
  color: #8696a0;
}

/* ===== WhatsApp footer / info bar ===== */
.phone-footer[data-v-e4b5213a] {
  padding: 10px 12px 12px;
  border-top: 1px solid #111b21;
  background-color: #202c33;
  box-sizing: border-box;
}
.phone-footer-text[data-v-e4b5213a] {
  text-align: center;
  font-size: 12px;
  line-height: 1.4;
  color: #8696a0;
  margin: 0;
}
.phone-footer-highlight[data-v-e4b5213a] {
  color: #25d366;
  font-weight: 500;
}

/* ===== RCS header ===== */
.rcs-header[data-v-e4b5213a] {
  display: flex;
  align-items: center;
  padding: 10px 14px;
  background-color: #ffffff;
  border-bottom: 1px solid #e5e7eb;
  box-sizing: border-box;
}
.rcs-header-left[data-v-e4b5213a] {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 8px;
  flex-shrink: 0;
}
.rcs-icon-back[data-v-e4b5213a] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #6b7280;
}
.rcs-header-center[data-v-e4b5213a] {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
}
.rcs-header-avatar[data-v-e4b5213a] {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  background: linear-gradient(135deg, #059669 0%, #10b981 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #ffffff;
  font-size: 14px;
  font-weight: 600;
}
.rcs-header-info[data-v-e4b5213a] {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
}
.rcs-header-name[data-v-e4b5213a] {
  font-size: 14px;
  font-weight: 600;
  color: #111827;
  line-height: 1.2;
}
.rcs-header-verified[data-v-e4b5213a] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  font-size: 11px;
  color: #059669;
  line-height: 1;
  margin-top: 2px;
}
.rcs-verified-icon[data-v-e4b5213a] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #059669;
}
.rcs-header-verified-text[data-v-e4b5213a] {
  white-space: nowrap;
}
.rcs-header-right[data-v-e4b5213a] {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.rcs-icon-menu[data-v-e4b5213a] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #6b7280;
}

/* ===== RCS messages ===== */
.rcs-messages-area[data-v-e4b5213a] {
  flex: 1;
  padding: 16px 12px;
  background-color: #f9fafb;
  overflow-y: auto;
  box-sizing: border-box;
}
.rcs-empty-state[data-v-e4b5213a] {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  color: #9ca3af;
  text-align: center;
  font-size: 12px;
}
.rcs-empty-icon[data-v-e4b5213a] {
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background-color: #e5e7eb;
  display: flex;
  align-items: center;
  justify-content: center;
}
.rcs-empty-text[data-v-e4b5213a] {
  max-width: 220px;
}
.rcs-bubble-wrapper[data-v-e4b5213a] {
  max-width: 260px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.rcs-bubble[data-v-e4b5213a] {
  background-color: #ffffff;
  border-radius: 4px 18px 18px 18px;
  padding: 10px 14px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
  border: 1px solid #e5e7eb;
  text-align: left;
}
.rcs-bubble-text[data-v-e4b5213a] {
  font-size: 14px;
  color: #1f2937;
  line-height: 1.45;
  word-break: break-word;
  text-align: left;
}
.rcs-bubble-meta[data-v-e4b5213a] {
  display: flex;
  justify-content: flex-end;
  margin-top: 4px;
  font-size: 11px;
  color: #9ca3af;
}
.rcs-suggestions[data-v-e4b5213a] {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.rcs-suggestion-chip[data-v-e4b5213a] {
  padding: 6px 14px;
  border: 1.5px solid #10b981;
  border-radius: 18px;
  font-size: 12px;
  font-weight: 500;
  color: #059669;
  background-color: #ffffff;
  white-space: nowrap;
}
.rcs-bubble--template[data-v-e4b5213a] {
  background-color: #ecfdf5;
  border-color: #a7f3d0;
}
.rcs-template-badge-preview[data-v-e4b5213a] {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 600;
  color: #059669;
  background-color: #d1fae5;
  padding: 2px 8px;
  border-radius: 4px;
  margin-bottom: 6px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  text-align: left;
}

/* RCS Rich Card */
.rcs-rich-card-preview[data-v-e4b5213a] {
  width: 250px;
  border-radius: 12px;
  overflow: hidden;
  background-color: #ffffff;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
  border: 1px solid #e5e7eb;
}
.rcs-card-media[data-v-e4b5213a] {
  width: 100%;
  overflow: hidden;
  position: relative;
}
.rcs-card-media--short[data-v-e4b5213a] { height: 100px;
}
.rcs-card-media--medium[data-v-e4b5213a] { height: 140px;
}
.rcs-card-media--tall[data-v-e4b5213a] { height: 200px;
}
.rcs-card-media-img[data-v-e4b5213a] {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
}
.rcs-card-media-placeholder[data-v-e4b5213a] {
  width: 100%;
  height: 100%;
  min-height: 100px;
  background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #10b981;
}
.rcs-card-media-placeholder--sm[data-v-e4b5213a] {
  min-height: 80px;
}
.rcs-card-body[data-v-e4b5213a] {
  padding: 12px;
}
.rcs-card-title[data-v-e4b5213a] {
  font-size: 14px;
  font-weight: 600;
  color: #111827;
  margin-bottom: 4px;
  line-height: 1.3;
}
.rcs-card-desc[data-v-e4b5213a] {
  font-size: 12px;
  color: #6b7280;
  line-height: 1.4;
}
.rcs-card-desc--sm[data-v-e4b5213a] {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.rcs-card-actions[data-v-e4b5213a] {
  border-top: 1px solid #f3f4f6;
}
.rcs-card-action-btn[data-v-e4b5213a] {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px;
  font-size: 13px;
  font-weight: 500;
  color: #059669;
  border-top: 1px solid #f3f4f6;
}
.rcs-card-action-btn[data-v-e4b5213a]:first-child {
  border-top: none;
}
.rcs-card-action-btn--sm[data-v-e4b5213a] {
  padding: 8px;
  font-size: 11px;
}

/* RCS Carousel */
.rcs-carousel-preview[data-v-e4b5213a] {
  width: 100%;
  overflow: hidden;
}
.rcs-carousel-track[data-v-e4b5213a] {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
  scroll-snap-type: x mandatory;
}
.rcs-carousel-track[data-v-e4b5213a]::-webkit-scrollbar {
  height: 3px;
}
.rcs-carousel-track[data-v-e4b5213a]::-webkit-scrollbar-thumb {
  background: #d1d5db;
  border-radius: 4px;
}
.rcs-carousel-card[data-v-e4b5213a] {
  flex-shrink: 0;
  border-radius: 12px;
  overflow: hidden;
  background-color: #ffffff;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
  border: 1px solid #e5e7eb;
  scroll-snap-align: start;
}
.rcs-carousel-card--small[data-v-e4b5213a] { width: 140px;
}
.rcs-carousel-card--medium[data-v-e4b5213a] { width: 200px;
}
.rcs-carousel-card-media[data-v-e4b5213a] {
  height: 100px;
  overflow: hidden;
}
.rcs-carousel-card-body[data-v-e4b5213a] {
  padding: 10px;
}

/* ===== RCS input ===== */
.rcs-input-area[data-v-e4b5213a] {
  padding: 10px 12px;
  background-color: #ffffff;
  border-top: 1px solid #e5e7eb;
  box-sizing: border-box;
}
.rcs-input-bar[data-v-e4b5213a] {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  background-color: #f3f4f6;
  border-radius: 24px;
  color: #9ca3af;
  font-size: 14px;
  min-height: 44px;
  box-sizing: border-box;
}
.rcs-input-icon[data-v-e4b5213a] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.rcs-input-plus[data-v-e4b5213a] {
  color: #6b7280;
}
.rcs-input-send[data-v-e4b5213a] {
  width: 32px;
  height: 32px;
  min-width: 32px;
  min-height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
  color: #ffffff;
}
.rcs-input-placeholder[data-v-e4b5213a] {
  flex: 1;
  font-size: 14px;
  line-height: 1.4;
}
