/* AVAM Headless UI */

/* Root + theming */

.avam-convai { position: fixed; right: 24px; bottom: 24px; z-index: 9999; font: inherit; color: #0f172a; }

.avam-convai, .avam-convai * { box-sizing: border-box; }

.avam-convai { --avam-primary: #6b4cff; --avam-secondary: #00c2ff; --avam-bg: #0b1220; --avam-fg: #e5e7eb; --avam-muted:#94a3b8; }



/* Bubble */

.avam-convai-bubble { display:flex; align-items:center; gap:10px; cursor:pointer; }

.avam-convai-bubble .avatar { width:56px; height:56px; border-radius:999px; box-shadow:0 10px 20px rgba(0,0,0,.25); overflow:hidden; border:2px solid rgba(255,255,255,.8); background:#fff; }

.avam-convai-bubble .avatar .avatar-img { width:100%; height:100%; object-fit:cover; display:block; }

.avam-convai-bubble .cta { background: linear-gradient(135deg, var(--avam-primary), var(--avam-secondary));

  color:#fff; padding:10px 14px; border-radius:999px; font-weight:600; font-size:14px; box-shadow:0 8px 18px rgba(0,0,0,.25); white-space:nowrap; }



/* Panel */

.avam-convai-panel { position: fixed; right: 24px; bottom: 96px; width: 380px; max-width: calc(100vw - 28px);

  background: var(--avam-bg); color: var(--avam-fg); border-radius: 16px; box-shadow: 0 30px 60px rgba(0,0,0,.45);

  opacity:0; transform: translateY(12px) scale(.98); pointer-events:none; transition: all .18s ease; }

.avam-convai-panel.open { opacity:1; transform: translateY(0) scale(1); pointer-events:auto; }



.avam-convai-header { display:flex; align-items:center; justify-content:space-between;

  padding:12px 14px; border-bottom:1px solid rgba(255,255,255,.08);

  background: linear-gradient(135deg, rgba(107,76,255,.25), rgba(0,194,255,.15)); border-top-left-radius:16px; border-top-right-radius:16px; }

.avam-convai-header .title { font-weight:700; font-size:14px; letter-spacing:.2px; color:#fff; }

.avam-convai-header .close { background:transparent; color:#fff; border:0; width:28px; height:28px; border-radius:8px; cursor:pointer; }

.avam-convai-header .close:hover { background:rgba(255,255,255,.08); }



.avam-convai-body { display:grid; grid-template-columns: 120px 1fr; gap:14px; padding:14px; }

.avam-convai-body.compact { grid-template-columns: 1fr; }



.avam-convai .left { display:flex; flex-direction:column; align-items:center; gap:10px; }

.avam-convai .avatar-lg { width:96px; height:96px; border-radius:999px; overflow:hidden; border:2px solid rgba(255,255,255,.2); box-shadow:0 8px 24px rgba(0,0,0,.35); background:#fff; }

.avam-convai .avatar-lg .avatar-img { width:100%; height:100%; object-fit:cover; display:block; }



.avam-convai .btn { width:100%; border:0; border-radius:999px; padding:10px 12px; font-weight:700; color:#0b1220; cursor:pointer; box-shadow:0 10px 20px rgba(0,0,0,.25); }

.avam-convai .btn.start { background: linear-gradient(135deg, var(--avam-primary), var(--avam-secondary)); color:#0b1220; }

.avam-convai .btn.start:hover { filter: brightness(1.05); }

.avam-convai .btn.stop { background: linear-gradient(135deg, #ff6b6b, #ff3b3b); color:#fff; }

.avam-convai .btn.stop:disabled { opacity: .6; cursor: not-allowed; }



.avam-convai .avam-status { font-size:12px; color: var(--avam-muted); }



.avam-convai .right { display:flex; flex-direction:column; gap:10px; }

.avam-convai #transcript { background:#0f172a; color:#cbd5e1; border:1px solid rgba(255,255,255,.08); padding:10px; border-radius:12px; height:220px; overflow:auto; }

#transcript .t { padding:6px 8px; border-radius:8px; margin:2px 0; font-size:13px; }

#transcript .t.user { background: rgba(107,76,255,.25); color:#eae7ff; }

#transcript .t.assistant { background: rgba(148,163,184,.15); color:#e5e7eb; }



/* Mobile */

@media (max-width: 640px) {

  .avam-convai { right: 16px; bottom: 16px; }

  .avam-convai-panel { right: 16px; bottom: 86px; width: calc(100vw - 32px); }

  .avam-convai-body { grid-template-columns: 1fr; }

}

/* v1.0.8: Custom widget ownership and D-ID display */
.avam-convai .avatar-initial{
  display:flex;align-items:center;justify-content:center;width:100%;height:100%;
  font-weight:800;color:#0b1220;background:linear-gradient(135deg,var(--avam-primary),var(--avam-secondary));
}
.avam-convai .avam-did-frame{width:100%;height:100%;border:0;display:block;background:#fff;}
.avam-convai[data-avatar-mode="did"] .avatar-lg{border-radius:24px;width:190px;height:220px;background:#050b18;}
.avam-convai[data-avatar-mode="did"] .avam-convai-body{grid-template-columns:220px 1fr;}
.avam-convai-panel{width: min(760px, calc(100vw - 48px));}
.avam-convai-body{grid-template-columns:220px 1fr; min-height:360px;}
.avam-convai .avatar-lg{width:160px;height:160px;}
.avam-convai .btn{font-size:16px;line-height:1.1;}
.avam-convai #transcript{height:320px;}
.avam-convai-bubble .cta{font-size:18px;font-weight:800;padding:14px 24px;}
@media (max-width: 760px){
  .avam-convai-panel{right:16px;bottom:86px;width:calc(100vw - 32px);}
  .avam-convai-body,.avam-convai[data-avatar-mode="did"] .avam-convai-body{grid-template-columns:1fr;}
  .avam-convai .avatar-lg,.avam-convai[data-avatar-mode="did"] .avatar-lg{width:120px;height:120px;border-radius:999px;}
  .avam-convai #transcript{height:240px;}
}

/* v1.0.9: Real-agent presentation layer */
.avam-convai {
  --avam-panel-bg: #08111f;
  --avam-panel-soft: #0e1a2d;
  --avam-border: rgba(255,255,255,.12);
  --avam-text: #f8fafc;
  --avam-soft-text: #a9b4c7;
  font-family: inherit;
}

.avam-convai-bubble {
  gap: 14px;
  filter: drop-shadow(0 18px 28px rgba(4,10,20,.24));
}
.avam-convai-bubble .avatar {
  width: 78px;
  height: 78px;
  border: 4px solid rgba(255,255,255,.92);
  background: radial-gradient(circle at 50% 25%, rgba(255,255,255,.26), rgba(255,255,255,.06)), linear-gradient(135deg, var(--avam-primary), var(--avam-secondary));
}
.avam-convai-bubble .avatar.has-image {
  background: #fff;
}
.avam-convai-bubble .cta {
  min-width: 260px;
  min-height: 74px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  padding: 14px 30px;
  border: 1px solid rgba(255,255,255,.18);
  background: linear-gradient(135deg, var(--avam-primary), var(--avam-secondary));
}
.avam-convai-bubble .cta-main {
  display: block;
  color: #fff;
  font-size: clamp(20px, 2vw, 30px);
  font-weight: 900;
  letter-spacing: -.03em;
  line-height: 1;
  text-shadow: 0 1px 0 rgba(0,0,0,.18);
}
.avam-convai-bubble .cta-sub {
  display: block;
  color: rgba(255,255,255,.78);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  margin-top: 7px;
}

.avam-convai-panel {
  width: min(1040px, calc(100vw - 72px));
  right: 44px;
  bottom: 122px;
  border-radius: 22px;
  overflow: hidden;
  background:
    radial-gradient(circle at 13% 12%, rgba(255,255,255,.05), transparent 30%),
    linear-gradient(180deg, #0a1324 0%, #070d19 100%);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 36px 90px rgba(2,8,23,.52);
}
.avam-convai-header {
  min-height: 70px;
  padding: 18px 28px;
  border-bottom: 1px solid rgba(255,255,255,.11);
  background: linear-gradient(135deg, rgba(107,76,255,.44), rgba(0,194,255,.20));
}
.avam-convai-header .title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: clamp(20px, 2vw, 30px);
  font-weight: 900;
  letter-spacing: -.04em;
}
.avam-convai-header .title-dot {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: #22c55e;
  box-shadow: 0 0 0 5px rgba(34,197,94,.15), 0 0 18px rgba(34,197,94,.65);
}
.avam-convai-header .close {
  font-size: 32px;
  font-weight: 800;
  opacity: .94;
}

.avam-convai-body {
  grid-template-columns: 300px 1fr;
  gap: 28px;
  min-height: 520px;
  padding: 28px;
}
.avam-convai .left {
  justify-content: flex-start;
  gap: 16px;
}
.avam-convai .agent-card {
  width: 100%;
  padding: 20px 18px 18px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
  text-align: center;
}
.avam-convai .avatar-lg {
  width: 210px;
  height: 210px;
  margin: 0 auto 14px;
  border: 5px solid rgba(255,255,255,.96);
  box-shadow: 0 18px 42px rgba(0,0,0,.42), 0 0 0 10px rgba(255,255,255,.035);
  background: radial-gradient(circle at 50% 25%, rgba(255,255,255,.26), rgba(255,255,255,.06)), linear-gradient(135deg, var(--avam-primary), var(--avam-secondary));
}
.avam-convai .avatar-lg.has-image {
  background: #fff;
}
.avam-convai .avatar-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.avam-convai .agent-name {
  color: var(--avam-text);
  font-size: 20px;
  font-weight: 900;
  letter-spacing: -.02em;
}
.avam-convai .agent-role {
  color: var(--avam-soft-text);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-top: 4px;
}
.avam-convai .avatar-person {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
}
.avam-convai .avatar-person::before {
  content: '';
  position: absolute;
  width: 32%;
  height: 32%;
  left: 34%;
  top: 22%;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 10px 20px rgba(0,0,0,.13);
}
.avam-convai .avatar-person::after {
  content: '';
  position: absolute;
  width: 56%;
  height: 28%;
  left: 22%;
  bottom: 19%;
  border-radius: 999px 999px 28px 28px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 12px 22px rgba(0,0,0,.13);
}

.avam-convai .btn {
  width: 100%;
  min-height: 58px;
  border: 2px solid rgba(255,255,255,.85);
  border-radius: 999px;
  font-size: 20px;
  font-weight: 900;
  letter-spacing: -.03em;
}
.avam-convai .btn.start {
  background: linear-gradient(135deg, var(--avam-primary), var(--avam-secondary));
  color: #06111e;
  box-shadow: 0 18px 30px rgba(0,0,0,.24), inset 0 1px 0 rgba(255,255,255,.34);
}
.avam-convai .btn.stop {
  background: linear-gradient(135deg, #b54552, #8f232f);
}
.avam-convai .avam-status {
  color: var(--avam-soft-text);
  font-size: 15px;
  font-weight: 800;
}

.avam-convai .right {
  min-width: 0;
}
.avam-convai .transcript-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  padding: 2px 4px 12px;
}
.avam-convai .transcript-head span {
  color: var(--avam-text);
  font-size: 18px;
  font-weight: 900;
}
.avam-convai .transcript-head small {
  color: var(--avam-soft-text);
  font-size: 12px;
}
.avam-convai #transcript {
  height: 438px;
  padding: 18px;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.035), rgba(255,255,255,.012)),
    #0e1729;
  border: 1px solid rgba(255,255,255,.12);
}
.avam-convai .empty-state {
  height: 100%;
  min-height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(226,232,240,.52);
  font-size: 16px;
  text-align: center;
}
.avam-convai #transcript .t {
  padding: 11px 13px;
  border-radius: 14px;
  margin: 8px 0;
  font-size: 14px;
  line-height: 1.42;
  max-width: 88%;
}
.avam-convai #transcript .t.user {
  margin-left: auto;
  background: linear-gradient(135deg, rgba(107,76,255,.85), rgba(0,194,255,.62));
  color: #fff;
}
.avam-convai #transcript .t.assistant,
.avam-convai #transcript .t.assistant.booking {
  margin-right: auto;
  background: rgba(255,255,255,.09);
  color: #f1f5f9;
  border: 1px solid rgba(255,255,255,.08);
}

@media (max-width: 860px) {
  .avam-convai-panel {
    right: 16px;
    bottom: 102px;
    width: calc(100vw - 32px);
  }
  .avam-convai-body {
    grid-template-columns: 1fr;
    min-height: auto;
  }
  .avam-convai .avatar-lg {
    width: 144px;
    height: 144px;
  }
  .avam-convai-bubble .cta {
    min-width: 0;
    min-height: 60px;
    padding: 12px 20px;
  }
  .avam-convai-bubble .avatar {
    width: 62px;
    height: 62px;
  }
  .avam-convai #transcript {
    height: 280px;
  }
}

/* v1.1.2: text / voice / both interaction modes */
.avam-convai .avam-text-form{
  display:flex;
  gap:10px;
  align-items:center;
  margin-top:10px;
}
.avam-convai .avam-text-input{
  flex:1;
  min-height:46px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:#f8fafc;
  padding:0 16px;
  font-size:15px;
  outline:none;
}
.avam-convai .avam-text-input::placeholder{color:rgba(226,232,240,.58);}
.avam-convai .avam-text-input:focus{border-color:rgba(255,255,255,.35);box-shadow:0 0 0 4px rgba(107,76,255,.18);}
.avam-convai .avam-text-send{
  min-height:46px;
  border:0;
  border-radius:999px;
  padding:0 18px;
  font-weight:800;
  color:#07111f;
  background:linear-gradient(135deg,var(--avam-primary),var(--avam-secondary));
  cursor:pointer;
}
.avam-convai[data-interaction-mode="text"] .left .btn,
.avam-convai[data-interaction-mode="text"] .left .avam-status:empty{display:none;}
.avam-convai[data-interaction-mode="text"] .agent-role::after{content:' • quiet mode';font-weight:700;color:#a9b4c7;}
.avam-convai[data-interaction-mode="text"] #transcript{height:360px;}
@media (max-width: 760px){
  .avam-convai .avam-text-form{flex-direction:column;align-items:stretch;}
  .avam-convai .avam-text-send{width:100%;}
}


/* v1.1.4: force text chat input visibility against aggressive theme styles */
.avam-convai input.avam-text-input,
.avam-convai .avam-text-input,
.avam-convai .avam-text-form input[type="text"]{
  color:#f8fafc !important;
  -webkit-text-fill-color:#f8fafc !important;
  caret-color:#ffffff !important;
  background:rgba(255,255,255,.075) !important;
}
.avam-convai input.avam-text-input::placeholder,
.avam-convai .avam-text-form input[type="text"]::placeholder{
  color:rgba(226,232,240,.68) !important;
  -webkit-text-fill-color:rgba(226,232,240,.68) !important;
}

/* v1.3.0: commercial widget customisation layer */
.avam-convai {
  font-family: var(--avam-font-family, inherit);
  font-size: calc(14px * var(--avam-font-scale, 1));
}
.avam-convai-panel {
  width: min(var(--avam-panel-width, 760px), calc(100vw - 48px)) !important;
  right: 24px !important;
  bottom: 104px !important;
  border-radius: var(--avam-panel-radius, 18px) !important;
  background: var(--avam-panel-custom-bg, #0b1220) !important;
  color: var(--avam-panel-custom-text, #f8fafc) !important;
  overflow: hidden;
}
.avam-convai-header {
  min-height: 54px !important;
  padding: 12px 18px !important;
  border-top-left-radius: var(--avam-panel-radius, 18px) !important;
  border-top-right-radius: var(--avam-panel-radius, 18px) !important;
}
.avam-convai-header .title {
  font-size: clamp(16px, calc(18px * var(--avam-font-scale, 1)), 22px) !important;
}
.avam-convai-body {
  grid-template-columns: minmax(150px, 190px) 1fr !important;
  gap: 18px !important;
  min-height: var(--avam-panel-height, 420px) !important;
  padding: 18px !important;
}
.avam-convai .agent-card {
  border-radius: calc(var(--avam-panel-radius, 18px) + 2px) !important;
  padding: 14px 12px !important;
}
.avam-convai .avatar-lg {
  width: 132px !important;
  height: 132px !important;
  margin-bottom: 10px !important;
}
.avam-convai .agent-name {
  font-size: calc(18px * var(--avam-font-scale, 1)) !important;
}
.avam-convai .agent-role,
.avam-convai .transcript-head small,
.avam-convai .empty-state,
.avam-convai .avam-status {
  color: var(--avam-panel-custom-muted, #a9b4c7) !important;
}
.avam-convai .transcript-head span {
  color: var(--avam-panel-custom-text, #f8fafc) !important;
}
.avam-convai #transcript,
.avam-convai .transcript {
  height: calc(var(--avam-panel-height, 420px) - 96px) !important;
  min-height: 220px;
  background: var(--avam-transcript-custom-bg, #111827) !important;
}
.avam-convai .btn {
  min-height: 44px !important;
  font-size: calc(14px * var(--avam-font-scale, 1)) !important;
  border-radius: 999px !important;
}
.avam-convai-bubble .avatar {
  width: 64px !important;
  height: 64px !important;
}
.avam-convai-bubble .cta {
  min-width: 210px !important;
  min-height: 62px !important;
  padding: 12px 22px !important;
}
.avam-convai-bubble .cta-main {
  font-size: clamp(17px, calc(21px * var(--avam-font-scale, 1)), 24px) !important;
}
.avam-convai-bubble .cta-sub {
  font-size: calc(10px * var(--avam-font-scale, 1)) !important;
  letter-spacing: .08em !important;
}
.avam-convai.avam-open-button .avam-convai-bubble .avatar { display: none !important; }
.avam-convai.avam-open-button .avam-convai-bubble .cta { min-width: 0 !important; }
.avam-convai.avam-open-avatar .avam-convai-bubble .cta { display: none !important; }
.avam-convai[data-status-mode="hidden"] .avam-status { display: none !important; }
.avam-convai[data-status-mode="minimal"] .avam-status {
  min-height: 22px;
  font-size: calc(12px * var(--avam-font-scale, 1)) !important;
  font-weight: 700;
  letter-spacing: .02em;
}
.avam-convai.avam-size-small {
  --avam-panel-width: 540px;
  --avam-panel-height: 340px;
}
.avam-convai.avam-size-small .avam-convai-body {
  grid-template-columns: 1fr !important;
}
.avam-convai.avam-size-small .agent-card {
  display: none !important;
}
.avam-convai.avam-size-small .avam-convai-bubble .avatar {
  width: 52px !important;
  height: 52px !important;
}
.avam-convai.avam-size-small .avam-convai-bubble .cta {
  min-width: 170px !important;
  min-height: 52px !important;
  padding: 10px 18px !important;
}
.avam-convai.avam-size-small .avam-convai-bubble .cta-main {
  font-size: 17px !important;
}
.avam-convai.avam-size-large {
  --avam-panel-width: 920px;
  --avam-panel-height: 500px;
}
.avam-convai.avam-size-large .avam-convai-body {
  grid-template-columns: 240px 1fr !important;
}
.avam-convai.avam-size-large .avatar-lg {
  width: 170px !important;
  height: 170px !important;
}
@media (max-width: 760px){
  .avam-convai { right: 14px !important; bottom: 14px !important; }
  .avam-convai-panel {
    right: 14px !important;
    bottom: 88px !important;
    width: calc(100vw - 28px) !important;
  }
  .avam-convai-body,
  .avam-convai.avam-size-large .avam-convai-body {
    grid-template-columns: 1fr !important;
    min-height: min(var(--avam-panel-height, 420px), calc(100vh - 170px)) !important;
  }
  .avam-convai .agent-card { display: none !important; }
  .avam-convai #transcript,
  .avam-convai .transcript { height: min(320px, calc(100vh - 270px)) !important; }
  .avam-convai-bubble .avatar { width: 56px !important; height: 56px !important; }
  .avam-convai-bubble .cta { min-width: 180px !important; min-height: 56px !important; }
}
