/* ===== Ovinis WhatsApp Pro (single widget) ===== */
:root{ --ovp-brand:#25D366; }
.ovp-wa-pro{ position: fixed; z-index: 99999; bottom: var(--ovp-oy, 18px); }
.ovp-wa-right{ right: var(--ovp-ox, 18px); }
.ovp-wa-left{ left: var(--ovp-ox, 18px); }

/* FAB button */
.ovp-wa-fab{
  width: 60px; height: 60px; border-radius: 50%;
  display:flex; align-items:center; justify-content:center;
  border: 0; cursor: pointer; position: relative;
  background: radial-gradient(60% 60% at 30% 20%, rgba(255,255,255,.25), rgba(255,255,255,0)) , var(--ovp-brand);
  color: #fff; box-shadow: 0 18px 46px rgba(4,120,87,.30);
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}
.ovp-wa-size-sm .ovp-wa-fab{ width: 52px; height: 52px; }
.ovp-wa-size-lg .ovp-wa-fab{ width: 68px; height: 68px; }
.ovp-wa-fab:hover{ transform: translateY(-1px); box-shadow: 0 22px 56px rgba(4,120,87,.33); }
.ovp-wa-fab:active{ transform: translateY(0); filter: brightness(.98); }
.ovp-wa-ico{ width: 26px; height: 26px; }
.ovp-wa-dot{
  position:absolute; top:8px; right:10px; width:10px; height:10px; border-radius:50%;
  background:#22c55e; box-shadow: 0 0 0 0 rgba(34,197,94,.6); animation: ovp-ping 2s infinite;
}
@keyframes ovp-ping { 0%{ box-shadow: 0 0 0 0 rgba(34,197,94,.6); } 100%{ box-shadow: 0 0 0 16px rgba(34,197,94,0); } }

/* Panel */
.ovp-wa-panel{
  position: absolute; bottom: 74px;
  right: 0;
  width: min(92vw, 360px);
  background: #0f172a; color: #e5e7eb; border:1px solid rgba(148,163,184,.25);
  border-radius: 16px; overflow: hidden;
  box-shadow: 0 24px 64px rgba(2,6,23,.45);
}
.ovp-wa-left .ovp-wa-panel{ left: 0; right: auto; }
.ovp-wa-head{ display:flex; align-items:center; justify-content:space-between; padding:12px 14px; background: rgba(255,255,255,.04); }
.ovp-wa-close{ background:none; border:0; color:#e5e7eb; font-size:20px; cursor:pointer; }
.ovp-wa-body{ padding:12px 14px; }
.ovp-wa-greet{ margin:0 0 10px; opacity:.9; }
.ovp-wa-quick{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px; }
.ovp-wa-chip{ background: rgba(255,255,255,.06); color:#fff; border:1px solid rgba(255,255,255,.12); padding:6px 10px; border-radius:999px; cursor:pointer; }
.ovp-wa-chip:hover{ background: rgba(255,255,255,.1); }
.ovp-wa-form{ display:flex; gap:8px; align-items:center; }
.ovp-wa-input{
  flex:1; background:#0b1220; color:#fff; border:1px solid rgba(255,255,255,.14);
  border-radius: 10px; padding:10px 12px; outline:none;
}
.ovp-wa-send{
  background: var(--ovp-brand); color:#0b1220; border:0; border-radius:10px; padding:10px 14px; font-weight:800; cursor:pointer;
}

/* Presets */
.ovp-wa-glass .ovp-wa-panel{ background: rgba(15,23,42,.55); backdrop-filter: blur(10px); }
.ovp-wa-solid .ovp-wa-panel{ background: #0f172a; }
.ovp-wa-outline .ovp-wa-panel{ background: transparent; border:2px solid var(--ovp-brand); }

/* RTL improvements */
[dir="rtl"] .ovp-wa-panel{ direction: rtl; }
[dir="rtl"] .ovp-wa-head{ flex-direction: row-reverse; }
[dir="rtl"] .ovp-wa-dot{ right: auto; left: 10px; }
