/* =============================================================
   WA Contact Divi — Frontend Styles
   ============================================================= */

/* ── CSS Variables ── */
:root {
  --wacd-green:       #25D366;
  --wacd-green-dark:  #128C7E;
  --wacd-white:       #ffffff;
  --wacd-shadow:      0 4px 20px rgba(37, 211, 102, .45);
  --wacd-radius:      50px;
  --wacd-transition:  .25s cubic-bezier(.4,0,.2,1);
  --wacd-z:           9999;
}

/* ── Floating Button Wrapper ── */
#wacd-floating-wrapper {
  position: fixed;
  z-index: var(--wacd-z);
  pointer-events: none;
}

.wacd-floating-btn {
  position: fixed;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  cursor: pointer;
  pointer-events: all;
  border: none;
  outline: none;
  box-shadow: var(--wacd-shadow);
  transition: transform var(--wacd-transition), box-shadow var(--wacd-transition);
  z-index: var(--wacd-z);
  text-decoration: none;
  line-height: 0;
}

.wacd-floating-btn > svg {
  display: block;
  flex-shrink: 0;
}

.wacd-floating-btn:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 28px rgba(37,211,102,.6);
}

/* Positions */
.wacd-pos-bottom-right { bottom: 24px; right: 24px; }
.wacd-pos-bottom-left  { bottom: 24px; left:  24px; }
.wacd-pos-top-right    { top:    24px; right: 24px; }
.wacd-pos-top-left     { top:    24px; left:  24px; }

/* ── Pulse animation ── */
@keyframes wacd-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(37,211,102,.6); }
  70%  { box-shadow: 0 0 0 18px rgba(37,211,102,0); }
  100% { box-shadow: 0 0 0 0 rgba(37,211,102,0); }
}
.wacd-pulse { animation: wacd-pulse 2s ease-out infinite; }

/* ── Tooltip ── */
.wacd-tooltip {
  position: absolute;
  white-space: nowrap;
  background: #1a1a1a;
  color: #fff;
  font-size: 13px;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  padding: 6px 14px;
  border-radius: 6px;
  pointer-events: none;
  opacity: 0;
  transform: scale(.9);
  transition: opacity .2s, transform .2s;
}
.wacd-tooltip::after {
  content: '';
  position: absolute;
  top: 50%;
  border: 6px solid transparent;
  transform: translateY(-50%);
}
.wacd-pos-bottom-right .wacd-tooltip,
.wacd-pos-top-right .wacd-tooltip    { right: calc(100% + 12px); }
.wacd-pos-bottom-left .wacd-tooltip,
.wacd-pos-top-left .wacd-tooltip     { left: calc(100% + 12px); }
.wacd-pos-bottom-right .wacd-tooltip::after,
.wacd-pos-top-right .wacd-tooltip::after { right: -12px; border-left-color: #1a1a1a; }
.wacd-pos-bottom-left .wacd-tooltip::after,
.wacd-pos-top-left .wacd-tooltip::after  { left: -12px; border-right-color: #1a1a1a; }

.wacd-floating-btn:hover .wacd-tooltip { opacity: 1; transform: scale(1); }

/* ── Agents Popup ── */
.wacd-agents-popup {
  position: fixed;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 8px 40px rgba(0,0,0,.18);
  width: 300px;
  overflow: hidden;
  z-index: calc(var(--wacd-z) + 1);
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  transform-origin: bottom right;
  animation: wacd-popup-in .25s ease-out;
}
.wacd-pos-bottom-left  .wacd-agents-popup,
.wacd-pos-top-left     .wacd-agents-popup { transform-origin: bottom left; }

@keyframes wacd-popup-in {
  from { opacity:0; transform: scale(.9) translateY(8px); }
  to   { opacity:1; transform: scale(1) translateY(0); }
}

.wacd-popup-header {
  background: linear-gradient(135deg, #25D366, #128C7E);
  color: #fff !important;
  padding: 20px 20px 28px;
}
.wacd-popup-header h4 {
  margin: 0 0 4px;
  font-size: 16px;
  font-weight: 700;
  color: #fff !important;
}
.wacd-popup-header p {
  margin: 0;
  font-size: 13px;
  opacity: .85;
  color: #fff !important;
}

.wacd-popup-agents { padding: 8px 0; }
.wacd-agent-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 20px;
  text-decoration: none;
  color: inherit;
  transition: background .15s;
  cursor: pointer;
}
.wacd-agent-item:hover { background: #f7f7f7; }

.wacd-agent-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  background: #eee;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px;
  color: #555;
}
.wacd-agent-avatar img { width:100%; height:100%; border-radius:50%; object-fit:cover; }

.wacd-agent-info { flex: 1; }
.wacd-agent-name { font-size: 14px; font-weight: 600; color: #1a1a1a; margin: 0 0 2px; }
.wacd-agent-role { font-size: 12px; color: #777; margin: 0; }

.wacd-status-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.wacd-status-dot.online  { background: #25D366; }
.wacd-status-dot.busy    { background: #f59e0b; }
.wacd-status-dot.offline { background: #9ca3af; }

/* Outside hours message */
.wacd-outside-msg {
  padding: 16px 20px;
  font-size: 13px;
  color: #555;
  border-top: 1px solid #f0f0f0;
  text-align: center;
}

/* ── Hidden states ── */
.wacd-hidden  { display: none !important; }
.wacd-invisible { opacity:0; pointer-events:none; }

/* ── Responsive ── */
@media (max-width: 767px) {
  .wacd-hide-mobile  { display: none !important; }
  .wacd-agents-popup { width: 280px; }
}
@media (min-width: 768px) {
  .wacd-hide-desktop { display: none !important; }
}

/* ── Shortcode Buttons ── */
.wacd-sc-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  font-weight: 600;
  cursor: pointer;
  transition: filter var(--wacd-transition), transform var(--wacd-transition);
  line-height: 1;
}
.wacd-sc-btn:hover { filter: brightness(1.1); transform: translateY(-1px); }

.wacd-sc-btn--pill   { padding: 12px 22px; border-radius: 50px; }
.wacd-sc-btn--button { padding: 12px 22px; border-radius: 8px; }
.wacd-sc-btn--icon   { padding: 10px; border-radius: 50%; }

.wacd-sc-icon { flex-shrink: 0; width: 20px; height: 20px; }
.wacd-sc-btn--icon .wacd-sc-icon { width: 24px; height: 24px; }

.wacd-inline-link { color: var(--wacd-green); text-decoration: underline; }
.wacd-qr-wrap { display: inline-block; line-height: 0; }

/* ── Divi Module ── */
.wacd-divi-wrap { display: flex; }
.wacd-divi-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  font-weight: 600;
  cursor: pointer;
  transition: filter .2s, transform .2s;
  line-height: 1;
}
.wacd-divi-btn:hover { filter: brightness(1.08); transform: translateY(-2px); }
.wacd-divi-icon { flex-shrink: 0; }
.wacd-style--link {
  background: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  text-decoration: underline;
  box-shadow: none !important;
}
