.jmf-chat-wrapper{max-width:56rem;width:100%;margin:2.5rem auto;padding:0 1rem}.jmf-chat{background:linear-gradient(145deg,#1e2340,#151929);border-radius:1.5rem;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff14;overflow:hidden;display:flex;flex-direction:column;height:650px}.jmf-chat__header{background:linear-gradient(135deg,#3557c126,#3557c10d);padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1rem;border-bottom:1px solid rgba(255,255,255,.08)}.jmf-chat__avatar{width:48px;height:48px;min-width:48px;min-height:48px;background:linear-gradient(135deg,#3557c1,#1a3c8c);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #3557c166}.jmf-chat__avatar svg{width:24px;height:24px;color:#fff}.jmf-chat__header-info h3{font-family:var(--font-headline);font-size:1.1rem;font-weight:500;color:#fff;margin:0}.jmf-chat__status{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:#fff9}.jmf-chat__status-dot{width:8px;height:8px;background:#22c55e;border-radius:50%;display:inline-block;animation:jmf-pulse 2s ease-in-out infinite}@keyframes jmf-pulse{0%,to{opacity:1;box-shadow:0 0 #22c55e66}50%{opacity:.8;box-shadow:0 0 0 8px #22c55e00}}.jmf-chat__messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.jmf-chat__messages::-webkit-scrollbar{width:6px}.jmf-chat__messages::-webkit-scrollbar-track{background:transparent}.jmf-chat__messages::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.jmf-msg{display:flex;gap:.75rem;align-items:flex-end;animation:jmf-slide .35s cubic-bezier(.16,1,.3,1)}@keyframes jmf-slide{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.jmf-msg--user{flex-direction:row-reverse;align-items:flex-end}.jmf-msg__avatar{width:36px;height:36px;min-width:36px;min-height:36px;background:linear-gradient(135deg,#3557c1,#1a3c8c);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.jmf-msg__avatar svg{width:18px;height:18px;color:#fff}.jmf-msg__body{max-width:75%;padding:.875rem 1.125rem;border-radius:1.25rem;font-size:.95rem;line-height:1.6}.jmf-msg--bot .jmf-msg__body{background:linear-gradient(135deg,#ffffff1a,#ffffff0a);border:1px solid rgba(255,255,255,.08);border-bottom-left-radius:.35rem;color:#fff}.jmf-msg--user .jmf-msg__body{background:linear-gradient(135deg,#3557c1,#1a3c8c);border-bottom-right-radius:.35rem;color:#fff;box-shadow:0 4px 15px #3557c159}.jmf-msg__text,.jmf-msg__body p{margin:0;color:#fff}.jmf-msg__time{display:block;font-size:.7rem;color:#ffffff73;margin-top:.4rem}.jmf-msg--user .jmf-msg__time{text-align:right}.jmf-chat__footer{padding:1rem 1.5rem 1.25rem;background:#0003;border-top:1px solid rgba(255,255,255,.08)}.jmf-chat__typing{display:none;align-items:center;gap:.4rem;padding:.6rem .9rem;margin-bottom:.75rem;background:#ffffff0f;border-radius:1rem;width:fit-content}.jmf-chat__typing span{width:7px;height:7px;background:#3557c1;border-radius:50%;animation:jmf-bounce 1.4s ease-in-out infinite}.jmf-chat__typing span:nth-child(2){animation-delay:.2s}.jmf-chat__typing span:nth-child(3){animation-delay:.4s}@keyframes jmf-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}.jmf-chat__input-wrap{display:flex;gap:.75rem;align-items:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:1.25rem;padding:.35rem .35rem .35rem 1.25rem;transition:border-color .3s,box-shadow .3s}.jmf-chat__input-wrap:focus-within{border-color:#3557c1;box-shadow:0 0 0 3px #3557c159}#jmf-input{flex:1;background:transparent;border:none;outline:none;color:#fff;font-size:.95rem;font-family:var(--font-base);min-width:0}#jmf-input::placeholder{color:#ffffff73}#jmf-send{width:44px;height:44px;min-width:44px;background:linear-gradient(135deg,#3557c1,#1a3c8c);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .2s,box-shadow .2s}#jmf-send:hover{transform:scale(1.05);box-shadow:0 4px 20px #3557c166}#jmf-send:active{transform:scale(.95)}#jmf-send svg{width:20px;height:20px;color:#fff;margin-left:2px}@media (max-width: 640px){.jmf-chat{height:calc(100vh - 200px);border-radius:1rem}.jmf-chat__header,.jmf-chat__messages{padding:1rem}.jmf-msg__body{max-width:85%}.jmf-chat__footer{padding:.75rem 1rem 1rem}}
