/*
 * Diabec Human Call — floating "Talk to a specialist" button (human agent over
 * LiveKit), incoming-call banner, and in-call panel.
 * Sibling of diabec-voice-agent.* (the AI agent). Distinct `dhc-` prefix so the
 * two widgets never collide. FAB sits bottom-LEFT so it doesn't overlap the AI
 * FAB (bottom-right).
 * Palette matches diabec-base.css: --deep-green #2c3e1f, --amber-gold #c8a96e.
 */
:root{
  --dhc-green:#2c3e1f;--dhc-green-soft:#3d5430;--dhc-gold:#c8a96e;
  --dhc-cream:#f8f6f1;--dhc-red:#c83737;--dhc-text:#2a2a2a;
  --dhc-shadow:0 8px 24px rgba(44,62,31,0.25);
}

/* FAB */
.dhc-fab{
  position:fixed;bottom:calc(16px + env(safe-area-inset-bottom,0px));left:16px;
  width:56px;height:56px;border-radius:50%;background:var(--dhc-green);color:#fff;
  border:3px solid var(--dhc-gold);box-shadow:0 8px 24px rgba(0,0,0,0.3);cursor:pointer;
  z-index:10001;display:flex;align-items:center;justify-content:center;
  transition:transform .2s,box-shadow .2s,background .2s,bottom .25s;-webkit-tap-highlight-color:transparent;
}
.dhc-fab:hover{background:var(--dhc-green-soft);transform:translateY(-2px)}
.dhc-fab:focus-visible{outline:3px solid var(--dhc-gold);outline-offset:3px}
.dhc-fab svg{width:26px;height:26px;fill:currentColor}
.dhc-fab-badge{position:absolute;top:-4px;left:-4px;background:var(--dhc-gold);color:var(--dhc-green);
  font-size:9px;font-weight:700;padding:2px 6px;border-radius:10px;line-height:1;letter-spacing:.4px}
.dhc-fab-tooltip{position:absolute;left:calc(100% + 12px);top:50%;transform:translateY(-50%) translateX(-8px);
  background:rgba(44,62,31,0.96);color:#FDFCF9;font-size:12px;font-weight:600;padding:6px 12px;border-radius:8px;
  border:1px solid rgba(200,169,110,0.4);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .18s,transform .18s}
.dhc-fab:hover .dhc-fab-tooltip,.dhc-fab:focus-visible .dhc-fab-tooltip{opacity:1;transform:translateY(-50%) translateX(0)}
@media(max-width:480px){.dhc-fab-tooltip{display:none}}
@media(min-width:768px){.dhc-fab{width:64px;height:64px;bottom:24px;left:24px}.dhc-fab svg{width:30px;height:30px}}
@media print{.dhc-fab,.dhc-modal-overlay,.dhc-panel,.dhc-toast,.dhc-incoming{display:none!important}}

/* Modal */
.dhc-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:9999;display:none;
  align-items:flex-end;justify-content:center;padding:16px}
.dhc-modal-overlay.dhc-open{display:flex}
@media(min-width:768px){.dhc-modal-overlay{align-items:center}}
.dhc-modal{background:var(--dhc-cream);color:var(--dhc-text);border-radius:18px 18px 0 0;max-width:480px;width:100%;
  padding:28px 24px 24px;box-shadow:0 -8px 32px rgba(0,0,0,0.25)}
@media(min-width:768px){.dhc-modal{border-radius:18px;padding:32px}}
.dhc-modal h2{margin:0 0 12px;font-size:22px;color:var(--dhc-green);font-weight:700}
.dhc-modal p{margin:0 0 10px;font-size:15px;line-height:1.55;color:#444}
.dhc-disclaimer{background:#fff;border-left:3px solid var(--dhc-gold);padding:12px 14px;border-radius:6px;
  font-size:14px;margin:14px 0 20px;color:#555}
.dhc-actions{display:flex;gap:10px;flex-direction:column-reverse;margin-top:8px}
@media(min-width:480px){.dhc-actions{flex-direction:row;justify-content:flex-end}}
.dhc-btn{padding:12px 20px;border-radius:8px;border:none;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s,transform .1s}
.dhc-btn:active{transform:scale(.97)}
.dhc-btn-primary{background:var(--dhc-green);color:#fff}.dhc-btn-primary:hover{background:var(--dhc-green-soft)}
.dhc-btn-secondary{background:transparent;color:var(--dhc-green);border:1px solid var(--dhc-green)}
.dhc-btn-danger{background:var(--dhc-red);color:#fff}.dhc-btn-danger:hover{background:#a82d2d}

/* In-call panel */
.dhc-panel{position:fixed;bottom:calc(16px + env(safe-area-inset-bottom,0px));left:16px;right:16px;
  background:var(--dhc-green);color:#fff;border-radius:16px;padding:16px 18px;z-index:10001;display:none;
  align-items:center;gap:14px;box-shadow:var(--dhc-shadow)}
.dhc-panel.dhc-open{display:flex}
@media(min-width:768px){.dhc-panel{right:auto;width:340px;bottom:24px;left:24px}}
.dhc-status{flex:1;min-width:0}
.dhc-title{font-weight:700;font-size:14px;margin:0 0 2px}
.dhc-timer{font-size:13px;opacity:.85;font-variant-numeric:tabular-nums}
.dhc-mic{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,0.15);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}
.dhc-mic:hover{background:rgba(255,255,255,0.25)}.dhc-mic.dhc-muted{background:var(--dhc-red)}
.dhc-mic svg{width:18px;height:18px;fill:currentColor}
.dhc-end{background:var(--dhc-red);color:#fff;border:none;border-radius:8px;padding:8px 14px;font-weight:600;cursor:pointer;font-size:14px;font-family:inherit}
.dhc-end:hover{background:#a82d2d}
.dhc-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,0.3);border-top-color:#fff;border-radius:50%;animation:dhc-spin .8s linear infinite;display:inline-block;vertical-align:middle;margin-right:8px}
@keyframes dhc-spin{to{transform:rotate(360deg)}}

/* Incoming-call banner (agent-initiated) */
.dhc-incoming{position:fixed;bottom:calc(16px + env(safe-area-inset-bottom,0px));left:16px;right:16px;
  background:#fff;color:var(--dhc-text);border-radius:16px;padding:16px 18px;z-index:10002;display:none;
  align-items:center;gap:12px;box-shadow:var(--dhc-shadow);border-left:4px solid var(--dhc-gold);animation:dhc-up .25s}
.dhc-incoming.dhc-open{display:flex}
@media(min-width:768px){.dhc-incoming{right:auto;width:360px;bottom:24px;left:24px}}
@keyframes dhc-up{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.dhc-inc-text{flex:1}.dhc-inc-text strong{display:block;font-size:15px;color:var(--dhc-green)}
.dhc-inc-text span{font-size:13px;color:#666}
.dhc-inc-accept{background:var(--dhc-green);color:#fff;border:none;border-radius:8px;padding:9px 14px;font-weight:600;cursor:pointer;font-size:14px;font-family:inherit}
.dhc-inc-decline{background:transparent;color:var(--dhc-red);border:1px solid var(--dhc-red);border-radius:8px;padding:9px 14px;font-weight:600;cursor:pointer;font-size:14px;font-family:inherit}

/* Toast */
.dhc-toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%);background:#2a2a2a;color:#fff;
  padding:12px 18px;border-radius:10px;font-size:14px;z-index:10003;max-width:90vw;text-align:center;box-shadow:0 6px 20px rgba(0,0,0,0.3)}

/* First-visit communication consent (bottom-left, above the FAB) */
.dhc-consent{position:fixed;bottom:84px;left:16px;right:16px;background:#fff;color:var(--dhc-text);
  border-radius:14px;padding:16px 18px;z-index:10002;display:none;box-shadow:var(--dhc-shadow);
  border-left:4px solid var(--dhc-green);max-width:380px;animation:dhc-up .25s}
.dhc-consent.dhc-open{display:block}
@media(min-width:768px){.dhc-consent{left:24px;right:auto;bottom:100px}}
.dhc-consent-text strong{display:block;font-size:15px;color:var(--dhc-green);margin-bottom:5px}
.dhc-consent-text span{display:block;font-size:13px;line-height:1.5;color:#444}
.dhc-consent-text small{display:block;font-size:11px;line-height:1.45;color:#888;margin-top:8px}
.dhc-consent-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:14px}
.dhc-consent-yes{background:var(--dhc-green);color:#fff;border:none;border-radius:8px;padding:9px 16px;font-weight:600;cursor:pointer;font-size:13px;font-family:inherit}
.dhc-consent-yes:hover{background:var(--dhc-green-soft)}
.dhc-consent-no{background:transparent;color:#666;border:1px solid #ccc;border-radius:8px;padding:9px 16px;font-weight:600;cursor:pointer;font-size:13px;font-family:inherit}
.dhc-consent-no:hover{background:#f3f3f3}
