.frontdesk-chat{max-width:345px;border:1px solid #d7d7d7;border-radius:14px;background:#fff;box-shadow:0 8px 24px rgba(0,0,0,.08);overflow:hidden;font-family:inherit}.frontdesk-chat-header{display:flex;justify-content:space-between;gap:10px;padding:11px 13px;background:#1f2937;color:#fff}.frontdesk-chat-header span{font-size:12px;opacity:.8}.frontdesk-chat-intro{padding:9px 13px;color:#4b5563;border-bottom:1px solid #eee}.frontdesk-chat-messages{height:240px;overflow-y:auto;background:#f9fafb;padding:11px}.frontdesk-chat-msg{display:flex;margin:0 0 10px}.frontdesk-chat-msg.customer{justify-content:flex-end}.frontdesk-chat-msg.staff{justify-content:flex-start}.frontdesk-chat-bubble{max-width:78%;border:1px solid #e5e7eb;background:#fff;border-radius:14px;padding:9px 11px}.frontdesk-chat-msg.customer .frontdesk-chat-bubble{background:#e8f1ff;border-color:#c9ddff}.frontdesk-chat-bubble p{margin:0 0 4px;line-height:1.35}.frontdesk-chat-bubble small{display:block;font-size:11px;color:#6b7280}.frontdesk-chat-form{padding:9px;background:#fff;border-top:1px solid #eee}.frontdesk-chat-form input,.frontdesk-chat-form textarea{width:100%;box-sizing:border-box;border:1px solid #d1d5db;border-radius:10px;padding:8px;margin:0 0 7px;font:inherit}.frontdesk-chat-sendrow{display:flex;gap:8px;align-items:stretch}.frontdesk-chat-sendrow textarea{margin:0;resize:vertical}.frontdesk-chat-sendrow button{border:0;border-radius:10px;padding:0 16px;background:#1f2937;color:#fff;cursor:pointer}.frontdesk-chat-status{font-size:12px;color:#6b7280;margin-top:6px}@media(max-width:520px){.frontdesk-chat{max-width:100%}.frontdesk-chat-sendrow{flex-direction:column}.frontdesk-chat-sendrow button{padding:10px}}
.frontdesk-staff{border:1px solid #d7d7d7;border-radius:14px;background:#fff;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.08);font-family:inherit}.frontdesk-staff-header{display:flex;justify-content:space-between;gap:10px;padding:11px 13px;background:#111827;color:#fff}.frontdesk-staff-header span{font-size:12px;opacity:.85}.frontdesk-staff-layout{display:grid;grid-template-columns:280px 1fr;min-height:520px}.frontdesk-staff-list{border-right:1px solid #e5e7eb;background:#f9fafb;overflow-y:auto;max-height:620px}.frontdesk-staff-item{display:block;width:100%;border:0;border-bottom:1px solid #e5e7eb;background:#fff;text-align:left;padding:12px;cursor:pointer}.frontdesk-staff-item.active{background:#e8f1ff}.frontdesk-staff-item strong{display:flex;justify-content:space-between;gap:8px}.frontdesk-staff-item span{background:#111827;color:#fff;border-radius:999px;padding:1px 7px;font-size:12px}.frontdesk-staff-item small{display:block;color:#6b7280;margin-top:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.frontdesk-staff-thread{display:flex;flex-direction:column;min-width:0}.frontdesk-staff-thread-title{padding:12px 14px;border-bottom:1px solid #e5e7eb;font-weight:700}.frontdesk-staff-messages{height:390px;overflow-y:auto;background:#f9fafb;padding:14px}.frontdesk-staff-form{display:flex;gap:8px;padding:12px;border-top:1px solid #e5e7eb;background:#fff}.frontdesk-staff-form textarea{flex:1;border:1px solid #d1d5db;border-radius:10px;padding:9px;font:inherit;resize:vertical}.frontdesk-staff-form button{border:0;border-radius:10px;background:#111827;color:#fff;padding:0 16px;cursor:pointer}.frontdesk-staff-empty,.frontdesk-staff-notice{padding:14px;color:#4b5563}@media(max-width:760px){.frontdesk-staff-layout{grid-template-columns:1fr}.frontdesk-staff-list{max-height:220px;border-right:0;border-bottom:1px solid #e5e7eb}.frontdesk-staff-form{flex-direction:column}.frontdesk-staff-form button{padding:10px}.frontdesk-staff-messages{height:330px}}
.frontdesk-chat-header>div{display:flex;flex-direction:column}.frontdesk-chat-minimize{border:0;background:transparent;color:#fff;font-size:22px;line-height:1;cursor:pointer}.frontdesk-typing{font-size:12px;color:#6b7280;padding:6px 14px;background:#f9fafb}.frontdesk-floating{position:fixed;right:18px;bottom:18px;z-index:99999;font-family:inherit}.frontdesk-floating-button{border:0;border-radius:999px;background:#111827;color:#fff;padding:13px 18px;box-shadow:0 8px 26px rgba(0,0,0,.25);cursor:pointer;font-weight:700}.frontdesk-floating-button span:not(:empty){display:inline-block;margin-left:6px;background:#ef4444;color:#fff;border-radius:999px;min-width:20px;padding:1px 6px}.frontdesk-floating-panel{display:none;position:absolute;right:0;bottom:56px;width:285px;max-width:calc(100vw - 28px)}.frontdesk-floating.open .frontdesk-floating-panel{display:block}.frontdesk-floating .frontdesk-chat{max-width:100%}.frontdesk-staff-tools{display:flex;gap:12px;align-items:center;padding:10px 12px;border-bottom:1px solid #e5e7eb;background:#fff}.frontdesk-staff-tools input[type=search]{flex:1;border:1px solid #d1d5db;border-radius:10px;padding:9px}.frontdesk-staff-thread-top{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e5e7eb}.frontdesk-staff-thread-top .frontdesk-staff-thread-title{border-bottom:0}.frontdesk-archive-btn{margin-right:10px;border:1px solid #d1d5db;background:#fff;border-radius:8px;padding:7px 11px;cursor:pointer}.frontdesk-staff-item.archived{opacity:.72}.frontdesk-staff-item.archived strong:after{content:'Archived';font-size:11px;color:#6b7280;font-weight:400}.frontdesk-staff-messages .frontdesk-chat-msg.customer{justify-content:flex-start}.frontdesk-staff-messages .frontdesk-chat-msg.staff{justify-content:flex-end}.frontdesk-staff-messages .frontdesk-chat-msg.staff .frontdesk-chat-bubble{background:#e8f1ff;border-color:#c9ddff}@media(max-width:520px){.frontdesk-floating{right:10px;bottom:10px}.frontdesk-floating-panel{width:calc(100vw - 20px);right:0}.frontdesk-floating-button{padding:12px 15px}.frontdesk-staff-tools{flex-direction:column;align-items:stretch}}

.frontdesk-status-pill{display:inline-block;margin-left:8px;padding:2px 7px;border-radius:999px;background:#f3f4f6;color:#374151;font-size:12px;font-weight:600}.frontdesk-chat-closed-note{margin:0 0 10px;padding:8px 10px;border-radius:10px;background:#fff7ed;border:1px solid #fed7aa;color:#7c2d12;font-size:13px}.frontdesk-staff-item.closed,.frontdesk-staff-item.archived{opacity:.72}.frontdesk-staff-item em{font-style:normal;font-size:11px;color:#6b7280;font-weight:400;margin-left:6px}.frontdesk-staff-form-closed:before{content:'This conversation is closed. Sending a reply will reopen it.';display:block;margin:0 0 8px;color:#6b7280;font-size:12px}.frontdesk-archive-btn{font-weight:600}

/* Front Desk v1.4 professional polish */
.frontdesk-chat-form input[type="email"]{width:100%;box-sizing:border-box;margin:0 0 8px 0;padding:10px;border:1px solid #d1d5db;border-radius:10px;}
.frontdesk-staff-thread-title small{display:block;font-size:12px;font-weight:400;opacity:.75;margin-top:2px;}
.frontdesk-export-btn{border:1px solid #d1d5db;background:#fff;border-radius:8px;padding:8px 10px;cursor:pointer;}
.frontdesk-export-btn:disabled{opacity:.5;cursor:not-allowed;}
.frontdesk-staff-form select[data-frontdesk-canned]{width:100%;box-sizing:border-box;margin-bottom:8px;padding:9px;border:1px solid #d1d5db;border-radius:10px;background:#fff;}
@media(max-width:700px){.frontdesk-staff-thread-top{gap:6px;flex-wrap:wrap}.frontdesk-export-btn,.frontdesk-archive-btn{font-size:12px;padding:7px 8px}.frontdesk-staff-form select[data-frontdesk-canned]{font-size:16px}}

/* Front Desk v1.4.4 required field indicators */
.frontdesk-field-label{display:block;margin:0 0 4px;font-size:13px;font-weight:700;color:#374151;}
.frontdesk-required{color:#dc2626;font-weight:800;}

/* v1.4.5 mobile-safe required indicators */
.frontdesk-field-label.frontdesk-required-label::after{content:" *" !important;color:#dc2626 !important;font-weight:900 !important;display:inline !important;visibility:visible !important;}
.frontdesk-required{color:#dc2626 !important;font-weight:900 !important;display:inline !important;visibility:visible !important;}


/* Front Desk v1.4.6 business name + color customization */
.frontdesk-chat-header{background:var(--frontdesk-header-bg,#1f2937) !important;color:var(--frontdesk-header-text,#fff) !important;}
.frontdesk-chat-sendrow button{background:var(--frontdesk-button-bg,#1f2937) !important;color:var(--frontdesk-button-text,#fff) !important;}
.frontdesk-chat-messages,.frontdesk-typing{background:var(--frontdesk-chat-bg,#f9fafb) !important;}
.frontdesk-chat-msg.customer .frontdesk-chat-bubble{background:var(--frontdesk-customer-bubble,#e8f1ff) !important;}
.frontdesk-floating-button{background:var(--frontdesk-button-bg,#111827);color:var(--frontdesk-button-text,#fff);}


/* v1.4.7 floating bubble placement controls */
.frontdesk-floating{position:fixed;z-index:99999;font-family:inherit;right:auto;left:auto;top:auto;bottom:auto;}
.frontdesk-floating-bottom-right{right:var(--frontdesk-floating-x,18px);bottom:var(--frontdesk-floating-y,18px);}
.frontdesk-floating-bottom-left{left:var(--frontdesk-floating-x,18px);bottom:var(--frontdesk-floating-y,18px);}
.frontdesk-floating-top-right{right:var(--frontdesk-floating-x,18px);top:var(--frontdesk-floating-y,18px);}
.frontdesk-floating-top-left{left:var(--frontdesk-floating-x,18px);top:var(--frontdesk-floating-y,18px);}
.frontdesk-floating-panel{right:auto;left:auto;bottom:auto;top:auto;}
.frontdesk-floating-bottom-right .frontdesk-floating-panel{right:0;bottom:56px;}
.frontdesk-floating-bottom-left .frontdesk-floating-panel{left:0;bottom:56px;}
.frontdesk-floating-top-right .frontdesk-floating-panel{right:0;top:56px;}
.frontdesk-floating-top-left .frontdesk-floating-panel{left:0;top:56px;}
@media(max-width:520px){
  .frontdesk-floating-bottom-right,.frontdesk-floating-top-right{right:10px;}
  .frontdesk-floating-bottom-left,.frontdesk-floating-top-left{left:10px;}
  .frontdesk-floating-bottom-right,.frontdesk-floating-bottom-left{bottom:10px;}
  .frontdesk-floating-top-right,.frontdesk-floating-top-left{top:10px;}
}


/* v1.4.8 screen-safe floating chat window height */
.frontdesk-floating-panel{
  max-height:calc(100vh - 96px);
  max-height:calc(100dvh - 96px);
  overflow:hidden;
}
.frontdesk-floating-panel .frontdesk-chat{
  display:flex;
  flex-direction:column;
  max-height:min(520px, calc(100vh - 96px));
  max-height:min(520px, calc(100dvh - 96px));
}
.frontdesk-floating-panel .frontdesk-chat-messages{
  height:auto !important;
  min-height:140px;
  flex:1 1 auto;
}
.frontdesk-floating-panel .frontdesk-chat-form{
  flex:0 0 auto;
}
.frontdesk-floating-top-right .frontdesk-floating-panel,
.frontdesk-floating-top-left .frontdesk-floating-panel{
  max-height:calc(100vh - 86px);
  max-height:calc(100dvh - 86px);
}
.frontdesk-floating-top-right .frontdesk-chat,
.frontdesk-floating-top-left .frontdesk-chat{
  max-height:min(520px, calc(100vh - 86px));
  max-height:min(520px, calc(100dvh - 86px));
}
@media(max-width:520px){
  .frontdesk-floating-panel{
    width:calc(100vw - 20px) !important;
    max-height:calc(100vh - 90px);
    max-height:calc(100dvh - 90px);
  }
  .frontdesk-floating-panel .frontdesk-chat{
    max-height:calc(100vh - 90px);
    max-height:calc(100dvh - 90px);
  }
  .frontdesk-floating-panel .frontdesk-chat-messages{
    min-height:120px;
  }
  .frontdesk-floating-top-right .frontdesk-floating-panel,
  .frontdesk-floating-top-left .frontdesk-floating-panel{
    max-height:calc(100vh - 76px);
    max-height:calc(100dvh - 76px);
  }
  .frontdesk-floating-top-right .frontdesk-chat,
  .frontdesk-floating-top-left .frontdesk-chat{
    max-height:calc(100vh - 76px);
    max-height:calc(100dvh - 76px);
  }
}


/* v1.4.9 floating chat footer visibility, scroll, move support */
.frontdesk-floating-panel{
  overflow:visible !important;
}
.frontdesk-floating-panel .frontdesk-chat{
  height:min(500px, calc(100vh - 96px));
  height:min(500px, calc(100dvh - 96px));
  overflow:hidden !important;
}
.frontdesk-floating-panel .frontdesk-chat-header{
  cursor:move;
  user-select:none;
  touch-action:none;
  flex:0 0 auto;
}
.frontdesk-floating-panel .frontdesk-chat-intro{
  flex:0 0 auto;
}
.frontdesk-floating-panel .frontdesk-typing{
  flex:0 0 auto;
}
.frontdesk-floating-panel .frontdesk-chat-messages{
  flex:1 1 auto;
  min-height:80px !important;
  overflow-y:auto !important;
  overscroll-behavior:contain;
}
.frontdesk-floating-panel .frontdesk-chat-form{
  flex:0 0 auto;
  max-height:46vh;
  overflow-y:auto;
  overscroll-behavior:contain;
  position:relative;
  z-index:2;
}
.frontdesk-floating-panel .frontdesk-chat-sendrow button{
  font-size:13px;
  line-height:1.1;
  padding:0 12px;
  min-width:58px;
}
.frontdesk-floating-panel .frontdesk-chat-sendrow textarea{
  min-height:46px;
  max-height:90px;
}
.frontdesk-floating-panel.frontdesk-dragging,
.frontdesk-floating.frontdesk-dragging{
  transition:none !important;
}
@media(max-width:520px){
  .frontdesk-floating-panel .frontdesk-chat{
    height:calc(100vh - 90px);
    height:calc(100dvh - 90px);
  }
  .frontdesk-floating-panel .frontdesk-chat-form{
    max-height:50vh;
  }
  .frontdesk-floating-panel .frontdesk-chat-sendrow{
    flex-direction:row !important;
  }
  .frontdesk-floating-panel .frontdesk-chat-sendrow button{
    font-size:12px;
    padding:0 10px;
  }
}


/* v1.5.0 popup fit polish: taller window, smaller fonts, tighter spacing */
.frontdesk-floating-panel .frontdesk-chat{
  height:min(560px, calc(100vh - 72px)) !important;
  height:min(560px, calc(100dvh - 72px)) !important;
}
.frontdesk-floating-panel .frontdesk-chat-header{
  padding:9px 11px !important;
}
.frontdesk-floating-panel .frontdesk-chat-header strong{
  font-size:14px !important;
}
.frontdesk-floating-panel .frontdesk-chat-header span,
.frontdesk-floating-panel .frontdesk-chat-intro,
.frontdesk-floating-panel .frontdesk-chat-status,
.frontdesk-floating-panel .frontdesk-typing{
  font-size:12px !important;
}
.frontdesk-floating-panel .frontdesk-chat-intro{
  padding:7px 11px !important;
}
.frontdesk-floating-panel .frontdesk-chat-messages{
  padding:8px !important;
}
.frontdesk-floating-panel .frontdesk-chat-msg{
  margin-bottom:7px !important;
}
.frontdesk-floating-panel .frontdesk-chat-bubble{
  padding:7px 9px !important;
  border-radius:12px !important;
  font-size:13px !important;
}
.frontdesk-floating-panel .frontdesk-chat-bubble p{
  line-height:1.28 !important;
}
.frontdesk-floating-panel .frontdesk-chat-bubble small{
  font-size:10px !important;
}
.frontdesk-floating-panel .frontdesk-chat-form{
  padding:7px !important;
  max-height:42vh !important;
}
.frontdesk-floating-panel .frontdesk-chat-form label{
  font-size:12px !important;
  line-height:1.2 !important;
}
.frontdesk-floating-panel .frontdesk-chat-form input,
.frontdesk-floating-panel .frontdesk-chat-form textarea{
  font-size:13px !important;
  padding:6px 7px !important;
  margin-bottom:5px !important;
  border-radius:8px !important;
}
.frontdesk-floating-panel .frontdesk-chat-sendrow{
  gap:6px !important;
}
.frontdesk-floating-panel .frontdesk-chat-sendrow textarea{
  min-height:40px !important;
  max-height:74px !important;
}
.frontdesk-floating-panel .frontdesk-chat-sendrow button{
  font-size:11px !important;
  padding:0 9px !important;
  min-width:50px !important;
}
@media(max-width:520px){
  .frontdesk-floating-panel .frontdesk-chat{
    height:calc(100vh - 58px) !important;
    height:calc(100dvh - 58px) !important;
  }
  .frontdesk-floating-panel .frontdesk-chat-form{
    max-height:44vh !important;
  }
  .frontdesk-floating-panel .frontdesk-chat-bubble,
  .frontdesk-floating-panel .frontdesk-chat-form input,
  .frontdesk-floating-panel .frontdesk-chat-form textarea{
    font-size:12px !important;
  }
  .frontdesk-floating-panel .frontdesk-chat-sendrow button{
    font-size:10px !important;
    min-width:46px !important;
    padding:0 7px !important;
  }
}

.frontdesk-delete-btn{margin-right:10px;border:1px solid #dc2626;background:#fff;color:#b91c1c;border-radius:8px;padding:7px 11px;cursor:pointer;font-weight:600}.frontdesk-delete-btn:disabled{opacity:.5;cursor:not-allowed}
@media(max-width:700px){.frontdesk-delete-btn{font-size:12px;padding:7px 8px}}

/* v1.5.4 grouped staff inbox rows */
.frontdesk-staff-name-row{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%}
.frontdesk-staff-name-row strong{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.frontdesk-staff-count{display:inline-flex!important;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:999px;background:#ef4444!important;color:#fff!important;font-size:12px!important;font-weight:800;line-height:1;box-shadow:0 1px 4px rgba(0,0,0,.18);flex:0 0 auto}
.frontdesk-staff-item .frontdesk-staff-name-row + small{margin-top:6px}


/* v1.5.8 staff reply layout polish: stack quick replies and keep message box visible */
.frontdesk-staff-form{
  display:flex !important;
  flex-direction:column !important;
  gap:8px !important;
  align-items:stretch !important;
}
.frontdesk-staff-form select[data-frontdesk-canned]{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  margin:0 !important;
  font-size:13px !important;
  padding:7px 9px !important;
  min-height:34px !important;
}
.frontdesk-staff-form textarea[data-frontdesk-staff-message],
.frontdesk-staff-form textarea{
  width:100% !important;
  max-width:100% !important;
  box-sizing:border-box !important;
  min-height:74px !important;
  font-size:13px !important;
  line-height:1.35 !important;
}
.frontdesk-staff-form button[type="submit"]{
  align-self:flex-end !important;
  font-size:12px !important;
  line-height:1.1 !important;
  padding:7px 12px !important;
  min-height:30px !important;
}
.frontdesk-staff-thread-top{
  gap:6px !important;
  flex-wrap:wrap !important;
}
.frontdesk-staff-thread-top .frontdesk-staff-thread-title{
  flex:1 1 220px !important;
  min-width:0 !important;
}
.frontdesk-export-btn,
.frontdesk-archive-btn,
.frontdesk-delete-btn,
button[data-frontdesk-export],
button[data-frontdesk-archive],
button[data-frontdesk-delete]{
  font-size:11px !important;
  line-height:1.1 !important;
  padding:6px 8px !important;
  min-height:28px !important;
  border-radius:7px !important;
  white-space:nowrap !important;
}
@media(max-width:760px){
  .frontdesk-staff-form{padding:9px !important;}
  .frontdesk-staff-form textarea[data-frontdesk-staff-message],
  .frontdesk-staff-form textarea{min-height:82px !important;font-size:13px !important;}
  .frontdesk-staff-thread-top{align-items:flex-start !important;}
}


/* v1.5.9 mobile no-zoom fix: phones zoom inputs below 16px */
@media (max-width: 768px){
  .frontdesk-chat input,
  .frontdesk-chat textarea,
  .frontdesk-floating-panel .frontdesk-chat-form input,
  .frontdesk-floating-panel .frontdesk-chat-form textarea,
  .frontdesk-staff-form textarea,
  .frontdesk-staff-form input,
  .frontdesk-staff-form select{
    font-size:16px !important;
  }
  .frontdesk-chat-sendrow button,
  .frontdesk-floating-panel .frontdesk-chat-sendrow button{
    font-size:12px !important;
  }
}
