/* Servia chat widget styles. */
:root {
  --us-primary:#0D9488; --us-primary-dark:#115E59; --us-accent:#F59E0B;
  --us-bubble-user:#0D9488; --us-bubble-bot:#F1F5F9;
  --us-text:#0F172A; --us-muted:#64748B; --us-border:#E2E8F0;
}

/* v1.24.108 (Bug 32) — FAB stack ladder. Founder reported overlapping
   floating buttons on right edge. New stack bottom-to-top:
     .us-launcher  (chat, primary)     bottom:24px  right:18px  64x64
     #servia-wa-fab (WhatsApp)         bottom:104px right:24px  56x56
     .cmdk-fab     (search)            bottom:184px right:30px  48x48
     #servia-about-fab (info)          bottom:252px right:36px  32x32
   Centres ~76px apart with 6px right-inset cascade. Tested on
   320-1920px viewports. Lift-bar offsets add 64px to all. */
.us-launcher{position:fixed;right:18px;bottom:24px;width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg,var(--us-primary),var(--us-primary-dark));color:#fff;
  border:0;box-shadow:0 12px 32px rgba(13,148,136,.45);cursor:pointer;font-size:26px;
  z-index:99998;transition:transform .18s ease, bottom .25s ease;
  display:flex;align-items:center;justify-content:center;padding:0;overflow:visible}
.us-launcher:hover{transform:scale(1.08)}
[dir="rtl"] .us-launcher{right:auto;left:24px}

/* Lift launcher above sticky bottom bars (service.html .sticky-cta, mobile-nav etc.).
   Uses class-based selectors instead of :has() — :has() forces expensive style
   recalc on every DOM mutation (PSI flagged 6s+ Style & Layout work).
   widget.js adds .us-lift-bar class on <body> when sticky-cta or mobile-nav exists. */
body.us-lift-bar .us-launcher { bottom: 88px; right: 18px; }
body.us-lift-bar .us-launcher-tip { bottom: 104px; }
@media (max-width:720px) {
  body.us-lift-bar .us-launcher { bottom: 76px; }
}

/* v1.24.415 — On phones the WhatsApp + chat-bot floating buttons clutter
   the bottom-right. Founder: "on mobiles adjust the whatsapp and chat
   icons also in bottom bar of mobiles so screen is more clear, think
   some more creative and apply." Solution: on phones, HIDE both floating
   buttons (WA fab + chat-bot launcher); the chat-bot's mascot now lives
   in the centre slot of the canonical mobile-nav, and WhatsApp moves to
   the chat-bot's tap-and-hold long-press affordance + the footer link.
   On desktop both stay where they were (bottom-right launcher, bottom-
   left WA pill). */
#servia-wa-fab, .wa-fab {
  position: fixed !important;
  z-index: 998 !important;
}
body.srv-mobile-nav-active #servia-wa-fab,
body.srv-mobile-nav-active .wa-fab,
body.srv-mobile-nav-active .us-launcher,
body.srv-mobile-nav-active .us-launcher-tip {
  display: none !important;
}

/* Pulsing ring around the launcher — attracts attention without nagging */
.us-launcher-pulse{position:absolute;inset:-4px;border-radius:50%;
  border:3px solid var(--us-primary);opacity:0;
  animation:us-launcher-ring 2.4s ease-out infinite;pointer-events:none}
@keyframes us-launcher-ring{
  0%   {opacity:.85; transform:scale(.8)}
  60%  {opacity:0;   transform:scale(1.45)}
  100% {opacity:0;   transform:scale(1.45)}
}
/* Tiny chat-bubble badge in the corner, blinks softly */
.us-launcher-bubble{position:absolute;top:-2px;right:-2px;
  width:22px;height:22px;background:#F59E0B;border:2px solid #fff;
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:11px;animation:us-bubble-blink 2.6s ease-in-out infinite;
  box-shadow:0 2px 6px rgba(245,158,11,.4)}
@keyframes us-bubble-blink{
  0%, 70%, 100% {transform:scale(1)}
  85%           {transform:scale(1.18)}
}

/* Floating "Need a hand?" tooltip beside the launcher */
.us-launcher-tip{position:fixed;right:96px;bottom:36px;z-index:99997;
  background:#fff;color:#0F172A;padding:9px 14px;border-radius:14px;
  border:1px solid var(--us-border);font-size:13px;font-weight:600;
  box-shadow:0 12px 28px rgba(15,23,42,.18);
  opacity:0;transform:translateX(8px) scale(.96);
  transition:opacity .35s ease, transform .35s ease;
  pointer-events:none;max-width:240px;cursor:pointer}
.us-launcher-tip::after{content:"";position:absolute;right:-7px;top:50%;
  transform:translateY(-50%);border:7px solid transparent;
  border-left-color:#fff;border-right:0}
.us-launcher-tip.show{opacity:1;transform:translateX(0) scale(1);pointer-events:auto}
[dir="rtl"] .us-launcher-tip{right:auto;left:96px}
[dir="rtl"] .us-launcher-tip::after{right:auto;left:-7px;border-right-color:#fff;border-left:0}
@media(max-width:480px){.us-launcher-tip{display:none}}

.us-panel{position:fixed;right:24px;bottom:96px;width:400px;max-width:calc(100vw - 32px);
  height:620px;max-height:calc(100vh - 120px);background:#fff;border-radius:18px;
  box-shadow:0 24px 60px rgba(15,23,42,.22);display:none;flex-direction:column;
  overflow:hidden;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  color:var(--us-text);z-index:99999}
.us-panel.open{display:flex}
[dir="rtl"] .us-panel{right:auto;left:24px}
@media(max-width:480px){
  .us-panel{right:8px;left:8px;bottom:84px;width:auto;height:calc(100vh - 100px)}
  .us-launcher{right:16px;bottom:16px}
}

.us-header{background:linear-gradient(135deg,var(--us-primary),var(--us-primary-dark));
  color:#fff;padding:14px 16px;display:flex;align-items:center;gap:12px}
.us-header h3{margin:0;font-size:15px;font-weight:700}
.us-header p{margin:2px 0 0;font-size:12px;opacity:.85}
.us-header .us-close,
.us-header .us-min,
.us-header .us-resize,
.us-header .us-download,
.us-header .us-newchat{background:transparent !important;border:0 !important;color:#fff !important;
  font-size:18px !important;cursor:pointer !important;line-height:1 !important;padding:6px !important;
  opacity:.85 !important;border-radius:6px !important;width:auto !important;height:auto !important;
  min-width:0 !important;box-shadow:none !important;transition:background .12s, opacity .12s !important;
  margin:0 !important;display:inline-flex !important;align-items:center !important;justify-content:center !important}
.us-header .us-close{font-size:22px !important;margin-inline-start:2px !important}
.us-header .us-min:hover, .us-header .us-resize:hover, .us-header .us-close:hover,
.us-header .us-download:hover, .us-header .us-newchat:hover{background:rgba(255,255,255,.12) !important;opacity:1 !important}
.us-header .us-version{font-size:9.5px;opacity:.55;margin-top:1px;letter-spacing:.05em;color:#fff}

/* v1.24.82 — minimized state hides the panel entirely; user sees only
   the round launcher icon in the corner. Previous design (54px header
   strip across the screen) looked like a "useless horizontal bar"
   hiding content on every page (user complaint). */
.us-panel.us-min-state{display:none !important}
/* maximized state: full viewport */
.us-panel.us-max-state{position:fixed;inset:8px;right:8px;left:8px;top:8px;bottom:8px;
  width:auto;height:auto;max-width:none;max-height:none;border-radius:14px}
@media(max-width:600px){.us-panel.us-max-state{inset:0;border-radius:0}}

.us-actions-bar{display:flex;gap:6px;overflow-x:auto;padding:10px 12px 6px;
  background:linear-gradient(180deg,#FAFBFD,#fff);border-bottom:1px solid var(--us-border);
  scrollbar-width:thin}
.us-actions-bar::-webkit-scrollbar{height:4px}
.us-actions-bar::-webkit-scrollbar-thumb{background:var(--us-border);border-radius:2px}
.us-actions-bar button{flex-shrink:0;padding:7px 12px;border-radius:999px;background:#fff;
  border:1px solid var(--us-border);font-size:12.5px;font-weight:600;color:var(--us-text);
  cursor:pointer;white-space:nowrap;transition:.12s;display:inline-flex;gap:5px;align-items:center}
.us-actions-bar button:hover{background:var(--us-primary);color:#fff;border-color:var(--us-primary)}

.us-body{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px;
  background:#FAFBFD}
.us-msg{max-width:84%;padding:10px 14px;border-radius:14px;font-size:14px;line-height:1.5;
  white-space:pre-wrap;word-wrap:break-word}
.us-msg.user{align-self:flex-end;background:var(--us-bubble-user);color:#fff;
  border-bottom-right-radius:4px}
[dir="rtl"] .us-msg.user{border-bottom-right-radius:14px;border-bottom-left-radius:4px}
.us-msg.bot{align-self:flex-start;background:var(--us-bubble-bot);color:var(--us-text);
  border-bottom-left-radius:4px}
.us-msg strong{font-weight:700}
.us-tool-tag{font-size:11px;color:var(--us-muted);margin-top:4px;font-style:italic}

.us-typing{align-self:flex-start;display:inline-flex;gap:4px;padding:10px 14px}
.us-typing span{width:6px;height:6px;border-radius:50%;background:var(--us-muted);
  animation:us-blink 1.2s infinite ease-in-out}
.us-typing span:nth-child(2){animation-delay:.2s}
.us-typing span:nth-child(3){animation-delay:.4s}
@keyframes us-blink{0%,80%,100%{opacity:.2;transform:translateY(0)}40%{opacity:1;transform:translateY(-2px)}}

.us-actions{display:flex;flex-wrap:wrap;gap:6px;margin:-2px 8px 6px;align-self:flex-start;
  max-width:100%}
.us-actions button{font-size:13px;font-weight:600;padding:8px 14px;border-radius:999px;
  border:1px solid var(--us-primary);background:#fff;color:var(--us-primary);cursor:pointer;
  transition:.15s}
.us-actions button:hover:not(:disabled){background:var(--us-primary);color:#fff}
.us-actions button:disabled{opacity:.55;cursor:default;border-color:var(--us-border);
  color:var(--us-muted)}
.us-actions button.us-action-picked{background:var(--us-primary);color:#fff;opacity:1}

.us-quickreplies{display:flex;flex-wrap:wrap;gap:6px;padding:0 14px 8px}
.us-quickreplies button{font-size:12.5px;padding:6px 11px;border:1px solid var(--us-border);
  border-radius:999px;background:#fff;color:var(--us-text);cursor:pointer}
.us-quickreplies button:hover{background:#F1F5F9}

.us-attach-preview{padding:8px 12px 0}

.us-input{display:flex;gap:6px;padding:10px;border-top:1px solid var(--us-border);
  background:#fff;align-items:center}
.us-input input{flex:1 1 auto;min-width:0;border:1px solid var(--us-border);border-radius:999px;
  padding:10px 14px;font-size:14px;outline:none;min-height:38px;font-family:inherit;
  background:#FAFBFD}
.us-input input:focus{border-color:var(--us-primary);background:#fff}
.us-input button{flex:0 0 auto;background:var(--us-bubble-bot);color:var(--us-text);
  border:0;border-radius:50%;width:38px;height:38px;cursor:pointer;font-size:16px;
  display:inline-flex;align-items:center;justify-content:center;transition:.15s;padding:0}
.us-input button:hover{background:var(--us-primary);color:#fff}
.us-input button.us-send{background:linear-gradient(135deg,var(--us-primary),var(--us-primary-dark));
  color:#fff;font-weight:700}
.us-input button.us-send:hover{transform:scale(1.05)}
.us-input button.us-send:disabled{opacity:.5;cursor:not-allowed;transform:none}

.us-mic.recording{background:#DC2626 !important;color:#fff !important;animation:us-pulse 1.2s infinite}
@keyframes us-pulse{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.5)}50%{box-shadow:0 0 0 6px rgba(220,38,38,0)}}

.us-mode{display:none}

/* v1.24.64 — friendly date/time picker */
.us-picker { padding: 8px 12px 14px; background: #FAFBFD; border-top: 1px solid #E2E8F0; border-bottom: 1px solid #E2E8F0; }
.us-picker-strip { display: flex; gap: 8px; overflow-x: auto; padding: 6px 2px 8px; scrollbar-width: thin; scroll-snap-type: x mandatory; }
.us-picker-strip::-webkit-scrollbar { height: 4px; }
.us-picker-strip::-webkit-scrollbar-thumb { background: #CBD5E1; border-radius: 2px; }
.us-picker-day { flex-shrink: 0; min-width: 80px; padding: 12px 4px; border: 2px solid #E2E8F0; background: #fff; border-radius: 12px; cursor: pointer; transition: all .15s; scroll-snap-align: start; font-family: inherit; }
.us-picker-day:hover { border-color: var(--us-primary); transform: translateY(-1px); box-shadow: 0 4px 10px rgba(13,148,136,0.15); }
.us-picker-day-label { font-weight: 700; font-size: 13.5px; color: var(--us-text); }
.us-picker-day-sub { font-size: 11px; color: var(--us-muted); margin-top: 2px; }
.us-picker-day-weekend .us-picker-day-label { color: #DC2626; }
.us-picker-day-custom { border-style: dashed !important; border-color: var(--us-primary) !important; background: #F0FDFA !important; }
.us-picker-day-custom .us-picker-day-label { color: var(--us-primary-dark); }
.us-picker-day-custom .us-picker-day-sub { color: var(--us-primary); font-style: italic; }
.us-picker-day-custom:hover { background: var(--us-primary) !important; }
.us-picker-day-custom:hover .us-picker-day-label, .us-picker-day-custom:hover .us-picker-day-sub { color: #fff; }
.us-picker-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; padding: 6px 0 0; }
.us-picker-time { padding: 9px 4px; border: 2px solid #E2E8F0; background: #fff; border-radius: 8px; cursor: pointer; font-size: 12.5px; font-weight: 600; color: var(--us-text); font-family: inherit; transition: all .12s; }
.us-picker-time:hover { border-color: var(--us-primary); background: #F0FDFA; color: var(--us-primary-dark); }
.us-picker-picked { background: var(--us-primary) !important; color: #fff !important; border-color: var(--us-primary) !important; }
.us-picker-picked .us-picker-day-label, .us-picker-picked .us-picker-day-sub { color: #fff !important; }
.us-picker-hint { font-size: 11px; color: var(--us-muted); margin-top: 8px; text-align: center; opacity: .7; }

/* v1.24.78 — in-chat quote card. Designed per CLAUDE.md DESIGN-REVIEW
   gate: clean light card, brand teal accents, ≥44px touch targets,
   clear hierarchy. Embedded signature pad replaces the redirect to
   /q/<id>. */
.us-qcard { background: #fff; border: 1px solid #E2E8F0; border-radius: 14px;
  margin: 8px 0; padding: 14px; box-shadow: 0 4px 12px rgba(15,23,42,.06);
  font-size: 13px; }
.us-qcard-loading, .us-qcard-err { color: var(--us-muted); padding: 8px 4px; text-align: center; }
.us-qcard-err a { color: var(--us-primary); text-decoration: underline; }
.us-qcard-head { display: flex; justify-content: space-between; align-items: center;
  padding-bottom: 8px; border-bottom: 1px dashed #E2E8F0; margin-bottom: 10px; }
.us-qcard-title { font-weight: 800; font-size: 14px; color: var(--us-text); letter-spacing: -.01em; }
.us-qcard-badge { font-size: 11px; font-weight: 700; padding: 4px 9px; border-radius: 999px;
  background: #FEF3C7; color: #92400E; }
.us-qcard-badge-ok { background: #D1FAE5; color: #065F46; }
.us-qcard-items { display: flex; flex-direction: column; gap: 4px; padding: 4px 0; }
.us-qcard-line { display: grid; grid-template-columns: 22px 1fr auto; column-gap: 6px;
  align-items: baseline; padding: 6px 0; border-bottom: 1px solid #F1F5F9; }
.us-qcard-num { color: var(--us-muted); font-weight: 700; font-size: 11px; }
.us-qcard-name { font-weight: 600; color: var(--us-text); }
.us-qcard-detail { display: block; grid-column: 2 / 3; font-size: 11px; color: var(--us-muted); }
.us-qcard-price { font-weight: 700; color: var(--us-primary-dark); font-size: 13px; }
.us-qcard-totals { padding: 8px 0; border-top: 1px dashed #E2E8F0; margin-top: 4px; }
.us-qcard-trow { display: flex; justify-content: space-between; padding: 3px 0; font-size: 12px; color: var(--us-muted); }
.us-qcard-trow.us-qcard-total { font-size: 15px; font-weight: 800; color: var(--us-primary-dark);
  padding-top: 6px; border-top: 1px solid #E2E8F0; margin-top: 4px; }
.us-qcard-meta { background: #F8FAFC; border-radius: 8px; padding: 8px 10px; margin: 10px 0;
  font-size: 12px; color: var(--us-text); line-height: 1.6; }
.us-qcard-actions { display: flex; gap: 6px; margin: 10px 0; }
.us-qcard-btn { flex: 1; padding: 9px 6px; min-height: 44px; background: #fff;
  border: 1.5px solid var(--us-primary); color: var(--us-primary-dark);
  border-radius: 9px; font-weight: 700; font-size: 12.5px; text-align: center;
  text-decoration: none; cursor: pointer; font-family: inherit;
  display: inline-flex; align-items: center; justify-content: center; gap: 4px;
  transition: background .12s, transform .08s; }
.us-qcard-btn:hover { background: var(--us-primary); color: #fff; transform: translateY(-1px); }
.us-qcard-sigblock { margin-top: 12px; background: #F0FDFA; border: 1px solid #99F6E4;
  border-radius: 10px; padding: 12px; }
.us-qcard-siglabel { font-weight: 700; font-size: 12.5px; margin-bottom: 8px; color: var(--us-primary-dark); }
.us-qcard-sigpad { background: #fff; border: 1.5px dashed #14B8A6; border-radius: 8px;
  width: 100%; height: 90px; touch-action: none; cursor: crosshair; display: block; }
.us-qcard-sigrow { display: flex; gap: 8px; margin-top: 8px; }
.us-qcard-sigrow .us-qcard-clear { flex: 0 0 auto; min-width: 80px; background: #fff;
  border-color: #94A3B8; color: var(--us-muted); }
.us-qcard-sigrow .us-qcard-approve { flex: 1; background: var(--us-primary); color: #fff;
  border-color: var(--us-primary); }
.us-qcard-msg { font-size: 11.5px; min-height: 14px; margin-top: 6px; text-align: center; color: var(--us-muted); }
.us-qcard-signed { margin-top: 12px; background: #ECFDF5; border: 1px solid #6EE7B7;
  border-radius: 10px; padding: 12px; text-align: center; }
.us-qcard-signed-msg { font-size: 13px; color: #065F46; font-weight: 600; margin-bottom: 8px; }
.us-qcard-pay { display: inline-block; padding: 11px 18px; min-height: 44px;
  background: linear-gradient(135deg, var(--us-primary), var(--us-primary-dark));
  color: #fff; border-radius: 999px; font-weight: 800; font-size: 14px;
  text-decoration: none; }

/* v1.24.75 — combined calendar + time picker for [[picker:datetime]] */
.us-cal-head { display: flex; align-items: center; justify-content: space-between; padding: 4px 0 8px; }
.us-cal-title { font-weight: 700; font-size: 14px; color: var(--us-text); }
.us-cal-nav { width: 32px; height: 32px; border-radius: 8px; border: 1px solid #E2E8F0; background: #fff; cursor: pointer; font-size: 18px; line-height: 1; color: var(--us-primary-dark); font-family: inherit; }
.us-cal-nav:hover { background: #F0FDFA; border-color: var(--us-primary); }
.us-cal-nav:disabled { opacity: 0.3; cursor: not-allowed; }
.us-cal-dow { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; padding-bottom: 4px; }
.us-cal-dow-cell { text-align: center; font-size: 10.5px; font-weight: 700; color: var(--us-muted); padding: 4px 0; letter-spacing: 0.5px; }
.us-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.us-cal-cell { aspect-ratio: 1; min-height: 36px; border: 1px solid #E2E8F0; background: #fff; border-radius: 8px; cursor: pointer; font-size: 13px; font-weight: 600; color: var(--us-text); font-family: inherit; transition: all .12s; padding: 0; }
.us-cal-cell:hover { border-color: var(--us-primary); background: #F0FDFA; transform: translateY(-1px); }
.us-cal-empty { border: 0; background: transparent; cursor: default; }
.us-cal-disabled { opacity: 0.25; cursor: not-allowed; pointer-events: none; }
.us-cal-today { border-color: var(--us-primary); border-width: 2px; }
.us-cal-picked { background: var(--us-primary) !important; color: #fff !important; border-color: var(--us-primary) !important; transform: scale(1.05); }
.us-cal-time { margin-top: 14px; padding-top: 12px; border-top: 1px dashed #E2E8F0; }
.us-cal-time-label { font-size: 13px; font-weight: 700; color: var(--us-primary-dark); margin-bottom: 8px; text-align: center; }
.us-cal-time-grid { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 380px) { .us-cal-cell { min-height: 32px; font-size: 12px; } .us-cal-time-grid { grid-template-columns: repeat(3, 1fr); } }
.us-picker [disabled] { opacity: .5; cursor: not-allowed; }
@media (max-width: 380px) { .us-picker-grid { grid-template-columns: repeat(3, 1fr); } }
