/* ==========================================================================
   STANZA — Costanza Realtors client concierge chat widget
   Self-mounting, CSP-strict (no inline JS; events wired in stanza.js).
   Reuses the storefront brand tokens — navy var(--ink) · amber var(--gold) ·
   Cormorant/Hanken/PlexMono. Everything is namespaced under .sz-* so it never
   collides with page styles. Zero CDN, zero new fonts (the tokens + @font-face
   already ship in app.css / listings.css; tokens carry hard fallbacks here so
   the widget still renders branded if a page omits them).
   Distinctive on purpose: a navy seal-pill launcher with an amber Cormorant
   "S" monogram + glow — NOT a generic round bubble.
   ========================================================================== */

.sz-root{
  --sz-ink:var(--ink,#0a2562);
  --sz-ink-2:var(--ink-2,#0d2a66);
  --sz-gold:var(--gold,#f5a200);
  --sz-gold-bright:var(--gold-bright,#ffc23d);
  --sz-gold-pale:var(--gold-pale,#ffe1a6);
  --sz-gold-line:var(--gold-line,rgba(245,162,0,.38));
  --sz-gold-soft:var(--gold-soft,rgba(245,162,0,.12));
  --sz-card:var(--card,#ffffff);
  --sz-line:var(--line,#e2e7f0);
  --sz-line-2:var(--line-2,#d3dae9);
  --sz-ivory:#faf8f3;                 /* warm market-paper for the message field */
  --sz-t-ink:var(--t-ink,#15213b);
  --sz-t-mid:var(--t-mid,#48526a);
  --sz-t-faint:var(--t-faint,#8b94a8);
  --sz-t-onink:var(--t-onink,#e9eefb);
  --sz-t-onink-2:var(--t-onink-2,#aeb9d6);
  --sz-live:var(--live,#2e9d6e);
  --sz-foil:var(--foil,linear-gradient(135deg,#ffc63f 0%,#f5a200 46%,#d98a00 70%,#ffcc55 100%));
  --sz-serif:var(--serif,"Cormorant",Georgia,"Times New Roman",serif);
  --sz-ui:var(--ui,"Hanken","Helvetica Neue","Segoe UI",-apple-system,sans-serif);
  --sz-mono:var(--mono,"PlexMono",ui-monospace,Menlo,monospace);
  --sz-shadow:0 1px 2px rgba(10,37,98,.05),0 18px 44px -26px rgba(10,37,98,.42);
  --sz-shadow-ink:var(--shadow-ink,0 30px 70px -30px rgba(8,24,72,.48));
  font-family:var(--sz-ui);
}
.sz-root, .sz-root *{box-sizing:border-box}
.sz-mono{font-family:var(--sz-serif);font-weight:600;line-height:1;color:var(--sz-gold);
  -webkit-font-smoothing:antialiased}

/* ====================== Launcher (the seal) ====================== */
.sz-launch{
  position:fixed; right:clamp(16px,4vw,30px); bottom:clamp(16px,4vw,30px);
  z-index:2147483000; display:inline-flex; align-items:center; gap:12px;
  padding:9px 20px 9px 9px; border:1px solid var(--sz-gold-line);
  background:radial-gradient(120% 160% at 88% -30%,rgba(245,162,0,.22),transparent 60%),var(--sz-ink);
  color:var(--sz-t-onink); border-radius:999px; box-shadow:var(--sz-shadow-ink);
  cursor:pointer; user-select:none; -webkit-tap-highlight-color:transparent;
  /* NO gap/padding transition — the launcher must never animate its size (that
     read as "compressing weirdly", esp. on mobile orientation/viewport changes).
     Size is fixed per breakpoint; only motion/shadow/opacity transition. */
  transition:transform .26s cubic-bezier(.2,.8,.2,1),box-shadow .26s,opacity .24s,
    visibility 0s linear 0s;
  animation:sz-pop .55s cubic-bezier(.2,.9,.3,1.15) both;
}
.sz-launch:hover{transform:translateY(-3px);box-shadow:0 36px 80px -30px rgba(8,24,72,.6)}
.sz-launch:active{transform:translateY(-1px)}

.sz-launch-medallion{flex:none;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;
  background:radial-gradient(130% 130% at 30% 18%,rgba(245,162,0,.22),transparent 62%),var(--sz-ink-2);
  border:1.5px solid var(--sz-gold);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 0 0 0 rgba(245,162,0,.5);
  animation:sz-glow 2.9s ease-out infinite}
.sz-launch-medallion .sz-mono{font-size:25px;color:var(--sz-gold);
  text-shadow:0 1px 10px rgba(245,162,0,.35)}

.sz-launch-label{display:flex;flex-direction:column;line-height:1.04;white-space:nowrap;
  max-width:170px;overflow:hidden;
  transition:max-width .35s cubic-bezier(.2,.8,.2,1),opacity .22s,margin .35s cubic-bezier(.2,.8,.2,1)}
.sz-launch-k{font-family:var(--sz-mono);font-size:9px;font-weight:500;letter-spacing:.24em;
  text-transform:uppercase;color:var(--sz-gold-bright)}
.sz-launch-n{font-family:var(--sz-serif);font-size:20px;font-weight:600;color:#fff;margin-top:2px}

.sz-launch-dot{position:absolute;top:5px;right:7px;width:11px;height:11px;border-radius:50%;
  background:var(--sz-gold);border:2px solid var(--sz-ink);opacity:0;transform:scale(.3);
  transition:opacity .3s,transform .3s}
.sz-launch.sz-unread .sz-launch-dot{opacity:1;transform:none;animation:sz-blip 1.9s ease-in-out infinite}

/* collapsed → just the seal. Explicit square box (not max-width:0 + negative
   margin) so it's always a true circle, never a lopsided ellipse. */
.sz-launch.sz-min{width:60px;height:60px;gap:0;padding:0;
  justify-content:center;align-items:center;border-radius:50%}
.sz-launch.sz-min .sz-launch-label{display:none}
.sz-launch.sz-min .sz-launch-dot{top:5px;right:5px}

@keyframes sz-pop{from{opacity:0;transform:translateY(16px) scale(.82)}to{opacity:1;transform:none}}
@keyframes sz-glow{0%{box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 0 0 0 rgba(245,162,0,.5)}
  70%,100%{box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 0 0 13px rgba(245,162,0,0)}}
@keyframes sz-blip{0%,100%{box-shadow:0 0 0 0 rgba(245,162,0,.55)}50%{box-shadow:0 0 0 6px rgba(245,162,0,0)}}

/* ====================== Panel ====================== */
.sz-panel{
  position:fixed; right:clamp(16px,4vw,30px); bottom:clamp(16px,4vw,30px); z-index:2147483001;
  width:380px; max-width:calc(100vw - 32px);
  height:min(622px,calc(100vh - 48px)); height:min(622px,calc(100dvh - 48px));
  display:flex; flex-direction:column; background:var(--sz-card);
  border:1px solid var(--sz-line-2); border-radius:16px; overflow:hidden;
  box-shadow:var(--sz-shadow-ink);
  transform-origin:bottom right; opacity:0; transform:translateY(14px) scale(.97);
  visibility:hidden; pointer-events:none;
  transition:opacity .26s cubic-bezier(.2,.8,.2,1),transform .26s cubic-bezier(.2,.8,.2,1),
    visibility 0s linear .26s;
}
.sz-root.sz-open .sz-panel{opacity:1;transform:none;visibility:visible;pointer-events:auto;
  transition:opacity .26s cubic-bezier(.2,.8,.2,1),transform .26s cubic-bezier(.2,.8,.2,1),visibility 0s}
.sz-root.sz-open .sz-launch{opacity:0;visibility:hidden;transform:scale(.8) translateY(10px);
  pointer-events:none;transition:transform .2s,opacity .18s,visibility 0s linear .2s}

/* ---- header ---- */
.sz-head{flex:none;position:relative;display:flex;align-items:center;gap:12px;padding:15px 13px 15px 16px;
  color:#fff;
  background:radial-gradient(130% 150% at 86% -25%,rgba(245,162,0,.2),transparent 58%),
    linear-gradient(165deg,var(--sz-ink-2),var(--sz-ink) 72%)}
.sz-head::after{content:"";position:absolute;left:0;right:0;top:0;height:2px;background:var(--sz-foil)}
.sz-avatar{flex:none;width:40px;height:40px;border-radius:50%;display:grid;place-items:center;
  background:var(--sz-foil);box-shadow:0 7px 18px -7px rgba(245,162,0,.75),inset 0 1px 0 rgba(255,255,255,.4)}
.sz-avatar .sz-mono{color:var(--sz-ink);font-size:23px}
.sz-head-id{flex:1;min-width:0}
.sz-head-name{font-family:var(--sz-serif);font-size:22px;font-weight:600;line-height:1;color:#fff;
  display:flex;align-items:center;gap:9px}
.sz-live{flex:none;width:7px;height:7px;border-radius:50%;background:var(--sz-live);
  box-shadow:0 0 8px 1px rgba(46,157,110,.8);animation:sz-ping 2.4s ease-out infinite}
.sz-head-sub{font-family:var(--sz-mono);font-size:9.5px;font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;color:var(--sz-t-onink-2);margin-top:6px}
.sz-close{flex:none;width:34px;height:34px;border-radius:8px;border:1px solid rgba(245,162,0,.26);
  background:rgba(255,255,255,.06);color:var(--sz-gold-pale);display:grid;place-items:center;
  transition:background .2s,border-color .2s,color .2s}
.sz-close:hover{background:rgba(245,162,0,.16);border-color:var(--sz-gold-line);color:#fff}
.sz-close svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round}
@keyframes sz-ping{0%{box-shadow:0 0 0 0 rgba(46,157,110,.5)}70%,100%{box-shadow:0 0 0 7px rgba(46,157,110,0)}}

/* ---- message stream ---- */
.sz-msgs{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding:18px 16px 10px;
  background:
    radial-gradient(120% 60% at 100% 0%,rgba(245,162,0,.05),transparent 60%),
    var(--sz-ivory);
  display:flex;flex-direction:column;gap:10px;scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch}
.sz-msgs::-webkit-scrollbar{width:10px}
.sz-msgs::-webkit-scrollbar-thumb{background:var(--sz-line-2);border-radius:10px;
  border:3px solid var(--sz-ivory)}
.sz-msgs::-webkit-scrollbar-track{background:transparent}

.sz-msg{display:flex;max-width:100%}
.sz-msg.sz-user{justify-content:flex-end}
.sz-msg.sz-stanza{justify-content:flex-start}
.sz-bubble{max-width:84%;padding:11px 14px;font-size:14.5px;line-height:1.5;border-radius:13px;
  word-wrap:break-word;overflow-wrap:anywhere;animation:sz-rise .32s cubic-bezier(.2,.8,.2,1) both}
.sz-msg.sz-stanza .sz-bubble{background:var(--sz-card);color:var(--sz-t-ink);
  border:1px solid var(--sz-line);border-left:3px solid var(--sz-gold);
  border-radius:4px 13px 13px 4px;box-shadow:0 1px 2px rgba(10,37,98,.05)}
.sz-msg.sz-user .sz-bubble{background:var(--sz-ink);color:var(--sz-t-onink);
  border-radius:13px 4px 13px 13px}
.sz-bubble strong{font-weight:700}
.sz-msg.sz-stanza .sz-bubble strong{color:var(--sz-ink)}
.sz-msg.sz-user .sz-bubble strong{color:#fff}
.sz-bubble.sz-noanim,.sz-cards.sz-noanim{animation:none}
@keyframes sz-rise{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* typing indicator */
.sz-bubble.sz-typing{display:inline-flex;gap:6px;align-items:center;padding:14px 16px}
.sz-bubble.sz-typing i{width:7px;height:7px;border-radius:50%;background:var(--sz-gold);opacity:.4;
  animation:sz-blink 1.25s infinite ease-in-out}
.sz-bubble.sz-typing i:nth-child(2){animation-delay:.16s}
.sz-bubble.sz-typing i:nth-child(3){animation-delay:.32s}
@keyframes sz-blink{0%,80%,100%{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}

/* ---- inline listing cards (premium mini-listings) ---- */
.sz-cards{align-self:flex-start;display:flex;flex-direction:column;gap:9px;max-width:90%;
  animation:sz-rise .34s cubic-bezier(.2,.8,.2,1) both}
.sz-card{display:flex;background:var(--sz-card);border:1px solid var(--sz-line);border-radius:10px;
  overflow:hidden;text-decoration:none;color:inherit;
  transition:transform .2s,box-shadow .2s,border-color .2s}
.sz-card:hover{transform:translateY(-2px);box-shadow:var(--sz-shadow);border-color:var(--sz-gold-line)}
.sz-card-ph{flex:none;width:108px;align-self:stretch;min-height:98px;position:relative;overflow:hidden;
  background:linear-gradient(135deg,#dfe5f0,#d3dae9)}
.sz-card-ph img{width:100%;height:100%;object-fit:cover;display:block}
.sz-card-ph.sz-empty{background:
  radial-gradient(130% 130% at 28% 8%,rgba(245,162,0,.32),transparent 60%),
  linear-gradient(160deg,var(--sz-ink-2),var(--sz-ink))}
.sz-card-ph .sz-ph-price{position:absolute;inset:0;display:grid;place-items:center;padding:8px;
  text-align:center;font-family:var(--sz-serif);font-weight:600;font-size:19px;color:#fff;
  text-shadow:0 1px 10px rgba(0,0,0,.35)}
.sz-card-b{flex:1;min-width:0;padding:11px 13px;display:flex;flex-direction:column;
  justify-content:center;gap:4px}
.sz-card-p{font-family:var(--sz-mono);font-weight:600;font-size:15px;color:var(--sz-ink);
  letter-spacing:.01em;font-variant-numeric:tabular-nums}
.sz-card-a{font-size:13.5px;font-weight:600;color:var(--sz-t-ink);line-height:1.25;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.sz-card-m{font-family:var(--sz-mono);font-size:10px;font-weight:500;letter-spacing:.04em;
  line-height:1.5;text-transform:uppercase;color:var(--sz-t-faint)}

/* ---- on-the-spot CMA report card ---- */
.sz-bubble.sz-report{max-width:94%;padding:0;overflow:hidden;background:var(--sz-card);
  border:1px solid var(--sz-line)}
.szr-hero{background:var(--sz-ink);color:#eaf0ff;padding:15px 16px}
.szr-ey{font-family:var(--sz-mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--sz-gold);font-weight:700}
.szr-range{font-family:var(--serif,Georgia,serif);font-size:30px;font-weight:600;line-height:1.05;margin-top:4px}
.szr-mid{font-family:var(--sz-mono);font-size:11px;color:var(--sz-gold-bright);margin-top:5px}
.szr-addr{font-size:12.5px;color:#b9c4e2;margin-top:6px}
.szr-basis{font-family:var(--sz-mono);font-size:9.5px;color:var(--sz-gold);margin-top:7px;letter-spacing:.03em}
.szr-an{padding:13px 16px 2px;font-size:13.5px;line-height:1.55;color:var(--sz-t-ink)}
.szr-prow{padding:9px 16px 0;font-size:12.5px;color:var(--sz-t-ink);line-height:1.5}
.szr-prow span{display:block;font-family:var(--sz-mono);font-size:9px;letter-spacing:.1em;
  text-transform:uppercase;color:var(--sz-t-faint);margin-bottom:1px}
.szr-hl{margin:11px 16px 2px;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:6px}
.szr-hl li{font-family:var(--sz-mono);font-size:10px;color:var(--sz-t-ink);background:var(--sz-gold-soft);
  border:1px solid var(--sz-gold-line);border-radius:14px;padding:3px 9px}
.szr-comps{padding:12px 16px 4px}
.szr-ct{font-family:var(--sz-mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--sz-t-faint);margin-bottom:4px}
.szc-row{display:flex;align-items:baseline;justify-content:space-between;gap:10px;padding:7px 0;
  border-top:1px solid var(--sz-line)}
.szc-row:first-of-type{border-top:0}
.szc-a{font-size:12.5px;font-weight:600;color:var(--sz-t-ink)}
.szc-b{font-size:8px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:1px 5px;
  border-radius:4px;margin-left:6px;vertical-align:middle}
.szc-b.closed{background:rgba(31,138,76,.14);color:#1f8a4c}
.szc-b.active{background:var(--sz-gold-soft);color:var(--sz-gold-strong,#d98a00)}
.szc-m{font-family:var(--sz-mono);font-size:9.5px;color:var(--sz-t-faint);margin-top:2px}
.szc-p{font-family:var(--serif,Georgia,serif);font-size:16px;font-weight:600;white-space:nowrap;color:var(--sz-ink)}
.szr-pdf{display:block;margin:13px 16px 16px;text-align:center;background:var(--sz-ink);
  color:var(--sz-gold-pale);font-family:var(--sz-ui);font-weight:700;font-size:13px;letter-spacing:.03em;
  padding:12px;border-radius:8px;text-decoration:none;transition:background .18s,color .18s}
.szr-pdf:hover{background:var(--sz-gold);color:var(--sz-ink)}
.szr-pdf .ar{margin-left:4px}

/* ---- quick-reply chips ---- */
.sz-chiprow{display:flex;flex-wrap:wrap;gap:7px;align-self:flex-start;max-width:100%;
  padding:1px 0 4px;animation:sz-rise .3s ease both}
.sz-chip{font-family:var(--sz-ui);font-size:13px;font-weight:600;color:var(--sz-ink);
  background:var(--sz-card);border:1px solid var(--sz-gold-line);border-radius:8px;
  padding:8px 13px;cursor:pointer;line-height:1.1;
  transition:background .18s,border-color .18s,color .18s,transform .12s,box-shadow .18s}
.sz-chip:hover{background:var(--sz-gold-soft);border-color:var(--sz-gold);
  box-shadow:0 6px 16px -10px rgba(245,162,0,.7)}
.sz-chip:active{transform:translateY(1px)}

/* ---- composer ---- */
.sz-form{flex:none;display:flex;align-items:center;gap:9px;padding:12px;
  border-top:1px solid var(--sz-line);background:var(--sz-card)}
.sz-form.sz-hidden{display:none}
.sz-field{flex:1;min-width:0;font-family:var(--sz-ui);font-size:14.5px;color:var(--sz-t-ink);
  padding:12px 14px;border:1px solid var(--sz-line-2);border-radius:10px;background:#fff;
  transition:border-color .18s,box-shadow .18s}
.sz-field::placeholder{color:var(--sz-t-faint)}
.sz-field:focus{outline:none;border-color:var(--sz-gold);box-shadow:0 0 0 3px var(--sz-gold-soft)}
.sz-send{flex:none;width:44px;height:44px;border-radius:10px;border:0;cursor:pointer;
  position:relative;overflow:hidden;display:grid;place-items:center;
  background:var(--sz-ink);color:var(--sz-gold-pale);transition:color .2s,transform .12s,box-shadow .2s}
.sz-send::before{content:"";position:absolute;inset:0;background:var(--sz-foil);opacity:0;
  transition:opacity .25s}
.sz-send:hover{color:var(--sz-ink);box-shadow:0 10px 22px -12px rgba(245,162,0,.8)}
.sz-send:hover::before{opacity:1}
.sz-send svg{position:relative;z-index:1;width:18px;height:18px;fill:none;stroke:currentColor;
  stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.sz-send:active{transform:translateY(1px)}
.sz-send:disabled,.sz-field:disabled{opacity:.5;cursor:default}
.sz-send:disabled::before{opacity:0}
.sz-send:disabled:hover{color:var(--sz-gold-pale);box-shadow:none}

/* honeypot — off-screen, never focusable */
.sz-hp{position:absolute!important;left:-9999px!important;top:auto!important;width:1px!important;
  height:1px!important;opacity:0!important;pointer-events:none}

/* ====================== Mobile sheet (<560px) ====================== */
@media (max-width:560px){
  .sz-panel{right:0;left:0;bottom:0;top:auto;width:100%;max-width:100%;
    height:88vh;height:88dvh;border-radius:18px 18px 0 0;
    transform:translateY(20px)}
  .sz-root.sz-open .sz-panel{transform:none}
  /* collapsed seal on mobile = a clean, FIXED circle. An explicit square box is
     required so border-radius:50% can't render an ellipse; the label is removed
     outright (display:none) rather than collapsed with max-width:0 + a negative
     margin, which left the box non-square → the lopsided navy "blob". */
  .sz-launch{width:60px;height:60px;padding:0;gap:0;
    justify-content:center;align-items:center;
    border-radius:50%;right:16px;bottom:16px}
  .sz-launch .sz-launch-label{display:none}
  .sz-launch .sz-launch-dot{top:5px;right:5px}
  .sz-bubble{max-width:88%}
  .sz-cards{max-width:96%}
}

/* ====================== Reduced motion ====================== */
@media (prefers-reduced-motion:reduce){
  .sz-launch,.sz-launch-medallion,.sz-launch-dot,.sz-live,.sz-panel,.sz-bubble,.sz-cards,
  .sz-chiprow,.sz-bubble.sz-typing i,.sz-launch-label{animation:none!important}
  .sz-panel,.sz-launch,.sz-launch-label{transition:opacity .18s,visibility 0s!important}
  .sz-msgs{scroll-behavior:auto}
}
