/* WhatsApp Inbox - RT MAROC Manager v2 — Full Refonte */
:root{
  --wa-bg:#0b141a;
  --wa-panel:#111b21;
  --wa-header:#202c33;
  --wa-border:#2a3942;
  --wa-input-bg:#2a3942;
  --wa-text:#e9edef;
  --wa-text2:#8696a0;
  --wa-bubble-in:#202c33;
  --wa-bubble-out:#005c4b;
  --wa-green:#00a884;
  --wa-blue:#53bdeb;
  --wa-hover:rgba(134,150,160,.08);
  --wa-active:rgba(0,168,132,.12);
  --wa-danger:#ef4444;
}
.wa-inbox-root{width:100%;height:100%;overflow:hidden;position:absolute;inset:0}
.wa-inbox{display:flex;width:100%;height:100%;background:var(--wa-bg);color:var(--wa-text);font-family:'Segoe UI',Helvetica,Arial,sans-serif;position:relative;overflow:hidden}

/* === SIDEBAR === */
.wa-sidebar{width:380px;min-width:380px;border-right:1px solid var(--wa-border);display:flex;flex-direction:column;background:var(--wa-panel)}
.wa-sidebar-header{padding:10px 16px;height:59px;display:flex;align-items:center;gap:12px;background:var(--wa-header)}
.wa-sidebar-header h2{font-size:.95rem;font-weight:500;flex:1;margin:0;color:var(--wa-text)}
.wa-sidebar-header .wa-status{font-size:.7rem;color:var(--wa-text2);display:flex;align-items:center;gap:4px;transition:color .3s}
.wa-sidebar-header .wa-status.connected{color:var(--wa-green)}
.wa-ws-dot{width:8px;height:8px;border-radius:50%;background:var(--wa-text2);transition:background .3s;flex-shrink:0}
.wa-ws-dot.connected{background:var(--wa-green);animation:wa-dot-glow 2s ease-in-out infinite}
@keyframes wa-dot-glow{0%,100%{box-shadow:0 0 0 0 rgba(0,168,132,.4)}50%{box-shadow:0 0 0 4px rgba(0,168,132,0)}}
.wa-ws-dot.reconnecting{background:#f59e0b;animation:wa-pulse 1s infinite}
.wa-ws-dot.offline{background:var(--wa-danger)}
.wa-search-box{padding:7px 12px;background:var(--wa-panel)}
.wa-search{width:100%;padding:7px 32px 7px 12px;border-radius:8px;border:none;background:var(--wa-input-bg);color:var(--wa-text);font-size:.85rem;outline:none}
.wa-search::placeholder{color:var(--wa-text2)}
.wa-conv-list{flex:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(134,150,160,.3) transparent}
.wa-conv-list::-webkit-scrollbar{width:6px}
.wa-conv-list::-webkit-scrollbar-thumb{background:rgba(134,150,160,.3);border-radius:3px}

/* Conversation items */
.wa-conv-item{display:flex;align-items:center;gap:13px;padding:10px 15px;cursor:pointer;border-bottom:none;transition:background .1s;position:relative}
.wa-conv-item::after{content:'';position:absolute;bottom:0;right:15px;left:72px;height:1px;background:var(--wa-border)}
.wa-conv-item:hover{background:var(--wa-hover)}
.wa-conv-item.active{background:var(--wa-active)}
.wa-conv-avatar{width:49px;height:49px;border-radius:50%;background:#6b7b8d;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:500;color:#fff;flex-shrink:0;text-transform:uppercase}
.wa-conv-info{flex:1;min-width:0}
.wa-conv-name{font-size:.95rem;font-weight:400;color:var(--wa-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wa-conv-item.has-unread .wa-conv-name{font-weight:600}
.wa-conv-last{font-size:.82rem;color:var(--wa-text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px;display:flex;align-items:center;gap:3px}
.wa-conv-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0;align-self:flex-start;padding-top:2px}
.wa-conv-time{font-size:.75rem;color:var(--wa-text2)}
.wa-conv-time.has-unread{color:var(--wa-green)}
.wa-conv-badge{background:var(--wa-green);color:#111b21;font-size:.75rem;min-width:20px;height:20px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:600;padding:0 5px}

/* 24h window badge */
.wa-window-badge{font-size:.6rem;padding:1px 5px;border-radius:4px;font-weight:600;line-height:1.3;letter-spacing:.02em}
.wa-window-badge.open{background:rgba(0,168,132,.2);color:var(--wa-green);animation:wa-badge-pulse 3s ease-in-out infinite}
@keyframes wa-badge-pulse{0%,100%{opacity:1}50%{opacity:.65}}
.wa-window-badge.closed{background:rgba(239,68,68,.12);color:#f87171;font-size:.6rem}

/* === CHAT AREA === */
.wa-chat{flex:1;display:flex;flex-direction:column;min-width:0;position:relative}
.wa-chat-header{padding:10px 16px;height:auto;min-height:59px;display:flex;align-items:center;gap:12px;background:var(--wa-header);border-bottom:1px solid var(--wa-border);z-index:2;flex-wrap:wrap}
.wa-chat-header .wa-back-btn{display:none;background:none;border:none;color:var(--wa-text2);cursor:pointer;padding:4px;font-size:1.3rem;margin-right:4px;line-height:1}
.wa-chat-header .wa-back-btn:hover{color:var(--wa-text)}
.wa-chat-avatar-sm{width:40px;height:40px;border-radius:50%;background:#6b7b8d;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:500;color:#fff;flex-shrink:0;text-transform:uppercase}
.wa-chat-info{flex:1;cursor:pointer;min-width:0}
.wa-chat-name{font-size:1rem;font-weight:400;color:var(--wa-text)}
.wa-chat-phone{font-size:.8rem;color:var(--wa-text2)}

/* 24h window indicator in chat header */
.wa-window-info{font-size:.7rem;padding:3px 10px;border-radius:12px;white-space:nowrap;flex-shrink:0;transition:all .3s}
.wa-window-info.open{background:rgba(0,168,132,.15);color:var(--wa-green)}
.wa-window-info.closed{background:rgba(239,68,68,.12);color:#f87171}

/* Header actions */
.wa-header-actions{display:flex;align-items:center;gap:4px;margin-left:auto;flex-shrink:0}
.wa-header-btn{background:none;border:none;color:var(--wa-text2);cursor:pointer;padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .15s;width:40px;height:40px;flex-shrink:0}
.wa-header-btn:hover{color:var(--wa-green);background:var(--wa-hover)}
.wa-header-btn svg{width:22px;height:22px}

/* Chat wallpaper */
.wa-messages-wrap{flex:1;position:relative;overflow:hidden}
.wa-messages-wrap::before{content:'';position:absolute;inset:0;background:var(--wa-bg);opacity:.06;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='1'%3E%3Ccircle cx='5' cy='5' r='1'/%3E%3Ccircle cx='25' cy='15' r='1'/%3E%3Ccircle cx='45' cy='5' r='1'/%3E%3Ccircle cx='15' cy='35' r='1'/%3E%3Ccircle cx='35' cy='25' r='1'/%3E%3Ccircle cx='55' cy='35' r='1'/%3E%3Ccircle cx='5' cy='45' r='1'/%3E%3Ccircle cx='25' cy='55' r='1'/%3E%3Ccircle cx='45' cy='45' r='1'/%3E%3C/g%3E%3C/svg%3E");z-index:0}
.wa-messages{position:absolute;inset:0;overflow-y:auto;padding:20px 45px 12px 63px;display:flex;flex-direction:column;gap:2px;scrollbar-width:thin;scrollbar-color:rgba(134,150,160,.3) transparent;z-index:1}
.wa-messages::-webkit-scrollbar{width:6px}
.wa-messages::-webkit-scrollbar-thumb{background:rgba(134,150,160,.3);border-radius:3px}

/* Load more indicator */
.wa-load-more{text-align:center;padding:12px;color:var(--wa-text2);font-size:.8rem;display:flex;align-items:center;justify-content:center;gap:6px}

/* Date separator */
.wa-date-sep{text-align:center;padding:8px 0;margin:4px 0}
.wa-date-sep span{background:#182229;color:rgba(233,237,239,.75);padding:5px 12px;border-radius:8px;font-size:.75rem;box-shadow:0 1px 0.5px rgba(11,20,26,.13)}

/* === MESSAGE BUBBLES === */
.wa-msg{display:flex;max-width:65%;position:relative;margin-bottom:1px}
.wa-msg.incoming{align-self:flex-start}
.wa-msg.outgoing{align-self:flex-end}
.wa-msg.tail{margin-top:4px}

.wa-msg-bubble{padding:6px 7px 8px 9px;border-radius:8px;font-size:.875rem;line-height:1.35;position:relative;word-break:break-word;direction:auto;box-shadow:0 1px 0.5px rgba(11,20,26,.13)}
.wa-msg.incoming .wa-msg-bubble{background:var(--wa-bubble-in);border-top-left-radius:0}
.wa-msg.outgoing .wa-msg-bubble{background:var(--wa-bubble-out);border-top-right-radius:0}
.wa-msg.incoming.tail .wa-msg-bubble::before{content:'';position:absolute;top:0;left:-8px;width:0;height:0;border-top:0 solid transparent;border-bottom:13px solid transparent;border-right:8px solid var(--wa-bubble-in)}
.wa-msg.outgoing.tail .wa-msg-bubble::after{content:'';position:absolute;top:0;right:-8px;width:0;height:0;border-top:0 solid transparent;border-bottom:13px solid transparent;border-left:8px solid var(--wa-bubble-out)}

/* Reply-to quote bar */
.wa-msg-reply{background:rgba(0,0,0,.2);border-left:3px solid var(--wa-green);border-radius:4px;padding:5px 8px;margin:-2px -2px 4px -2px;cursor:pointer;font-size:.8rem;line-height:1.3;max-height:52px;overflow:hidden}
.wa-msg-reply-name{color:var(--wa-green);font-size:.75rem;font-weight:600;margin-bottom:1px}
.wa-msg-reply-text{color:var(--wa-text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* Message text */
.wa-msg-text{white-space:pre-wrap;unicode-bidi:plaintext;padding-right:60px;min-width:100px}
.wa-msg-text a{color:var(--wa-blue);text-decoration:none}
.wa-msg-text a:hover{text-decoration:underline}
.wa-msg-text strong{font-weight:600}
.wa-msg-text em{font-style:italic}
.wa-msg-text del{text-decoration:line-through}
.wa-msg-text code{background:rgba(0,0,0,.2);padding:1px 4px;border-radius:3px;font-family:monospace;font-size:.8rem}

/* Message meta (time + ticks) */
.wa-msg-meta{float:right;margin:-10px 0 -5px 12px;position:relative;padding-top:4px;display:flex;align-items:center;gap:3px;white-space:nowrap}
.wa-msg-time{font-size:.6875rem;color:rgba(233,237,239,.6)}
.wa-msg-status{display:inline-flex;align-items:center}

/* Status ticks */
.wa-tick{width:16px;height:11px;fill:rgba(233,237,239,.5);transition:fill .3s}
.wa-tick.read{fill:var(--wa-blue)}
.wa-tick.failed{width:14px;height:14px;color:var(--wa-danger);fill:none}

/* Sending spinner */
.wa-tick-sending{width:12px;height:12px;border:1.5px solid rgba(233,237,239,.3);border-top-color:rgba(233,237,239,.7);border-radius:50%;animation:wa-spin .6s linear infinite;display:inline-block}

/* Media messages */
.wa-msg-media{border-radius:6px;overflow:hidden;margin:-3px -3px 3px -3px}
.wa-msg-media img{display:block;max-width:330px;min-width:150px;cursor:pointer;border-radius:6px;transition:filter .15s}
.wa-msg-media img:hover{filter:brightness(.9)}
.wa-msg-media video{display:block;max-width:330px;border-radius:6px}
.wa-msg-caption{margin-top:4px;padding-right:60px;white-space:pre-wrap;direction:auto}

/* Audio — WhatsApp style waveform */
.wa-msg-audio{display:flex;align-items:center;gap:8px;padding:6px 8px;min-width:260px}
.wa-msg-audio-play{width:32px;height:32px;border-radius:50%;background:var(--wa-text2);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s;color:#fff}
.wa-msg-audio-play:hover{background:var(--wa-green)}
.wa-msg-audio-play svg{width:16px;height:16px;fill:currentColor}
.wa-msg-audio-wave{flex:1;display:flex;align-items:center;gap:1.5px;height:28px;cursor:pointer}
.wa-msg-audio-bar{width:3px;border-radius:1.5px;transition:height .1s,background .2s}
.wa-msg.incoming .wa-msg-audio-bar{background:var(--wa-text2)}
.wa-msg.outgoing .wa-msg-audio-bar{background:rgba(255,255,255,.5)}
.wa-msg-audio-bar.played{background:var(--wa-green)!important}
.wa-msg-audio-time{font-size:.7rem;color:var(--wa-text2);min-width:32px;text-align:right;flex-shrink:0}

/* Video with play overlay */
.wa-msg-video-wrap{position:relative;cursor:pointer}
.wa-msg-video-wrap video{display:block;max-width:330px;border-radius:6px}
.wa-msg-video-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(0,0,0,.3);border-radius:6px;transition:background .15s}
.wa-msg-video-play:hover{background:rgba(0,0,0,.5)}
.wa-msg-video-play svg{width:48px;height:48px;fill:#fff;opacity:.9}

/* Document card */
.wa-msg-doc{display:flex;align-items:center;gap:10px;padding:10px 12px;background:rgba(0,0,0,.15);border-radius:8px;cursor:pointer;margin:-3px -3px 3px -3px;min-width:220px;transition:background .15s}
.wa-msg-doc:hover{background:rgba(0,0,0,.25)}
.wa-msg-doc-icon{width:36px;height:44px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;font-weight:700;color:#fff}
.wa-msg-doc-icon.pdf{background:#ef4444}
.wa-msg-doc-icon.doc,.wa-msg-doc-icon.docx{background:#2563eb}
.wa-msg-doc-icon.xls,.wa-msg-doc-icon.xlsx{background:#16a34a}
.wa-msg-doc-icon.zip,.wa-msg-doc-icon.rar{background:#a855f7}
.wa-msg-doc-icon.default{background:rgba(255,255,255,.1)}
.wa-msg-doc-info{flex:1;min-width:0}
.wa-msg-doc-name{font-size:.83rem;color:var(--wa-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wa-msg-doc-size{font-size:.7rem;color:var(--wa-text2);margin-top:1px}
.wa-msg-doc-dl{color:var(--wa-text2);font-size:1.1rem;flex-shrink:0;opacity:.7;transition:opacity .15s}
.wa-msg-doc:hover .wa-msg-doc-dl{opacity:1}

/* Template badge */
.wa-msg-tpl-badge{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;color:var(--wa-text2);margin-bottom:3px;padding:2px 6px;background:rgba(0,0,0,.15);border-radius:4px}

/* Button reply */
.wa-msg-btn{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:8px;font-size:.84rem;font-weight:500}
.wa-msg-btn-icon{font-size:.9rem}
.wa-msg-btn.btn-confirm{background:rgba(0,168,132,.15);color:var(--wa-green);border:1px solid rgba(0,168,132,.25)}
.wa-msg-btn.btn-cancel{background:rgba(239,68,68,.12);color:#f87171;border:1px solid rgba(239,68,68,.2)}
.wa-msg-btn.btn-modify{background:rgba(245,158,11,.12);color:#fbbf24;border:1px solid rgba(245,158,11,.2)}
.wa-msg-btn.btn-neutral{background:rgba(134,150,160,.1);color:var(--wa-text2);border:1px solid rgba(134,150,160,.15)}

/* Reaction (attached to message) */
.wa-msg-reaction{position:absolute;bottom:-8px;left:6px;background:#182229;border-radius:12px;padding:2px 6px;font-size:1rem;box-shadow:0 1px 3px rgba(0,0,0,.3);z-index:1}
.wa-msg.outgoing .wa-msg-reaction{right:6px;left:auto}

/* Sticker */
.wa-msg-sticker img{width:128px;height:128px;object-fit:contain}

/* System message */
.wa-msg-system{align-self:center;max-width:80%}
.wa-msg-system .wa-msg-bubble{background:#182229;color:rgba(233,237,239,.75);font-size:.775rem;text-align:center;border-radius:8px;padding:5px 12px}

/* Failed message */
.wa-msg.failed .wa-msg-bubble{opacity:.7}
.wa-msg-retry{display:inline-flex;align-items:center;gap:4px;color:var(--wa-danger);font-size:.75rem;cursor:pointer;margin-top:3px;padding:2px 6px;border-radius:4px;background:rgba(239,68,68,.08);transition:background .15s}
.wa-msg-retry:hover{background:rgba(239,68,68,.15)}

/* === INPUT BAR === */
.wa-input-bar{padding:5px 10px;display:flex;align-items:flex-end;gap:5px;background:var(--wa-header)}
.wa-input-actions{display:flex;align-items:center;gap:2px}
.wa-input-bar button{background:none;border:none;color:var(--wa-text2);cursor:pointer;padding:8px;border-radius:50%;font-size:1.15rem;transition:all .15s;display:flex;align-items:center;justify-content:center;line-height:1;width:40px;height:40px}
.wa-input-bar button:hover{color:var(--wa-text);background:var(--wa-hover)}
.wa-input-bar button.recording{color:var(--wa-danger);animation:wa-pulse 1s infinite}
@keyframes wa-pulse{0%,100%{opacity:1}50%{opacity:.4}}
.wa-input-text{flex:1;padding:9px 12px;border-radius:8px;border:none;background:var(--wa-input-bg);color:var(--wa-text);font-size:.94rem;outline:none;resize:none;max-height:150px;line-height:1.35;font-family:inherit}
.wa-input-text::placeholder{color:var(--wa-text2)}
.wa-send-btn{background:none!important;color:var(--wa-text2)!important;width:40px;height:40px}
.wa-send-btn:hover{color:var(--wa-green)!important;background:var(--wa-hover)!important}
.wa-send-btn svg{width:24px;height:24px}

/* Template button in input bar */
.wa-tpl-btn{color:var(--wa-text2)!important;position:relative}
.wa-tpl-btn:hover{color:var(--wa-green)!important}

/* Window closed bar */


.wa-window-closed-actions{display:flex;justify-content:center}





/* === TEMPLATE PICKER MODAL === */
.wa-tpl-modal{position:absolute;inset:0;z-index:100;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;animation:wa-fade-in .2s ease-out;backdrop-filter:blur(2px)}
.wa-tpl-modal.closing{animation:wa-fade-out .15s ease-in forwards}
@keyframes wa-fade-in{from{opacity:0}to{opacity:1}}
@keyframes wa-fade-out{from{opacity:1}to{opacity:0}}

.wa-tpl-dialog{background:var(--wa-panel);border-radius:12px;width:90%;max-width:520px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px rgba(0,0,0,.5);overflow:hidden}
.wa-tpl-dialog-header{padding:16px 20px;background:var(--wa-header);display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--wa-border)}
.wa-tpl-dialog-header h3{font-size:1rem;font-weight:500;margin:0;flex:1;color:var(--wa-text)}
.wa-tpl-dialog-close{background:none;border:none;color:var(--wa-text2);cursor:pointer;font-size:1.4rem;padding:4px 8px;border-radius:4px;transition:all .15s}
.wa-tpl-dialog-close:hover{color:var(--wa-text);background:var(--wa-hover)}
.wa-tpl-search{padding:12px 16px;background:var(--wa-panel)}
.wa-tpl-search input{width:100%;padding:8px 12px;border-radius:8px;border:none;background:var(--wa-input-bg);color:var(--wa-text);font-size:.85rem;outline:none}
.wa-tpl-search input::placeholder{color:var(--wa-text2)}
.wa-tpl-list{flex:1;overflow-y:auto;padding:8px 0;scrollbar-width:thin;scrollbar-color:rgba(134,150,160,.3) transparent}
.wa-tpl-list::-webkit-scrollbar{width:6px}
.wa-tpl-list::-webkit-scrollbar-thumb{background:rgba(134,150,160,.3);border-radius:3px}

/* Template category group */
.wa-tpl-group{margin-bottom:8px}
.wa-tpl-group-header{padding:6px 16px;font-size:.7rem;color:var(--wa-text2);text-transform:uppercase;letter-spacing:.05em;font-weight:600}

/* Template item */
.wa-tpl-item{padding:10px 16px;cursor:pointer;transition:background .1s;display:flex;flex-direction:column;gap:3px}
.wa-tpl-item:hover{background:var(--wa-hover)}
.wa-tpl-item-name{font-size:.85rem;color:var(--wa-text);font-weight:500}
.wa-tpl-item-lang{font-size:.7rem;color:var(--wa-text2);margin-left:8px;font-weight:400}
.wa-tpl-item-preview{font-size:.78rem;color:var(--wa-text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;direction:auto}

/* Template params form */
.wa-tpl-params{padding:16px 20px}
.wa-tpl-params-title{font-size:.9rem;color:var(--wa-text);margin-bottom:4px;font-weight:500}
.wa-tpl-params-preview{font-size:.82rem;color:var(--wa-text2);margin-bottom:12px;padding:8px 12px;background:rgba(0,0,0,.15);border-radius:6px;white-space:pre-wrap;direction:auto;border-left:3px solid var(--wa-green);line-height:1.4}
.wa-tpl-param-row{margin-bottom:8px}
.wa-tpl-param-label{font-size:.78rem;color:var(--wa-text2);margin-bottom:3px}
.wa-tpl-param-input{width:100%;padding:7px 10px;border-radius:6px;border:1px solid var(--wa-border);background:var(--wa-input-bg);color:var(--wa-text);font-size:.85rem;outline:none}
.wa-tpl-param-input:focus{border-color:var(--wa-green)}
.wa-tpl-send-btn{width:100%;padding:10px;border:none;border-radius:8px;background:var(--wa-green);color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;margin-top:12px;transition:all .15s}
.wa-tpl-send-btn:hover{background:#009975}
.wa-tpl-send-btn:disabled{opacity:.5;cursor:not-allowed}

/* Empty state */
.wa-empty{flex:1;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px;background:var(--wa-panel);border-bottom:6px solid var(--wa-green)}
.wa-empty-title{font-size:1.8rem;font-weight:300;color:var(--wa-text)}
.wa-empty-text{font-size:.87rem;color:var(--wa-text2);text-align:center;max-width:500px;line-height:1.5}
.wa-loading{display:flex;align-items:center;justify-content:center;padding:20px;color:var(--wa-text2);font-size:.85rem;gap:8px}
.wa-spinner{width:18px;height:18px;border:2px solid var(--wa-border);border-top-color:var(--wa-green);border-radius:50%;animation:wa-spin .8s linear infinite}
@keyframes wa-spin{to{transform:rotate(360deg)}}

/* Lightbox */
.wa-lightbox{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.92);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:12px;opacity:0;pointer-events:none;transition:opacity .2s}
.wa-lightbox.active{opacity:1;pointer-events:auto}
.wa-lightbox img{max-width:92vw;max-height:85vh;border-radius:4px;object-fit:contain}
.wa-lightbox-actions{display:flex;gap:12px}
.wa-lightbox-btn{background:rgba(255,255,255,.1);border:none;color:#fff;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.85rem;display:flex;align-items:center;gap:6px;transition:background .15s}
.wa-lightbox-btn:hover{background:rgba(255,255,255,.2)}
.wa-lightbox-close{position:absolute;top:12px;right:16px;background:none;border:none;color:#fff;font-size:2rem;cursor:pointer;z-index:1;opacity:.7;transition:opacity .15s}
.wa-lightbox-close:hover{opacity:1}

/* Recording overlay — WhatsApp style */
.wa-recording-overlay{
  display:flex;align-items:center;gap:8px;padding:5px 10px;
  background:var(--wa-header);border-top:1px solid var(--wa-border);
  animation:wa-rec-slideIn .25s ease-out;
}
.wa-recording-overlay.wa-rec-exit{animation:wa-rec-slideOut .2s ease-in forwards}
@keyframes wa-rec-slideIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes wa-rec-slideOut{from{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(10px)}}

.wa-rec-delete{
  background:none!important;border:none;color:var(--wa-danger)!important;cursor:pointer;
  width:40px!important;height:40px!important;padding:0!important;
  display:flex;align-items:center;justify-content:center;
  border-radius:50%;transition:background .15s,transform .15s;flex-shrink:0;
}
.wa-rec-delete:hover{background:rgba(239,68,68,.12)!important;transform:scale(1.1)}
.wa-rec-delete svg{width:22px;height:22px}
.wa-rec-center{
  flex:1;display:flex;align-items:center;gap:10px;
  background:var(--wa-input-bg);border-radius:8px;padding:8px 14px;
  min-width:0;overflow:hidden;
}
.wa-rec-dot-pulse{
  width:10px;height:10px;border-radius:50%;background:var(--wa-danger);flex-shrink:0;
  animation:wa-dot-blink 1.2s ease-in-out infinite;
}
@keyframes wa-dot-blink{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.75)}}
.wa-rec-wave{flex:1;display:flex;align-items:center;gap:2px;height:28px;min-width:0}
.wa-rec-bar{flex:1;min-width:2px;max-width:5px;height:3px;background:var(--wa-green);border-radius:2px;transition:height .08s ease-out}
.wa-recording-time{font-size:.85rem;color:var(--wa-text);font-variant-numeric:tabular-nums;min-width:36px;text-align:right;flex-shrink:0}
.wa-rec-send{
  background:var(--wa-green)!important;border:none;color:#fff!important;cursor:pointer;
  border-radius:50%!important;width:42px!important;height:42px!important;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  transition:transform .15s,box-shadow .15s;
  box-shadow:0 2px 8px rgba(0,168,132,.3);
}
.wa-rec-send:hover{transform:scale(1.08);box-shadow:0 3px 12px rgba(0,168,132,.45)}
.wa-rec-send:active{transform:scale(.95)}
.wa-rec-send svg{width:20px;height:20px}

/* === SEARCH IN CHAT === */
.wa-search-bar{padding:8px 12px;background:var(--wa-header);display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--wa-border);animation:wa-rec-slideIn .2s ease-out}
.wa-search-bar input{flex:1;padding:7px 12px;border-radius:8px;border:none;background:var(--wa-input-bg);color:var(--wa-text);font-size:.85rem;outline:none}
.wa-search-bar input::placeholder{color:var(--wa-text2)}
.wa-search-bar .wa-search-count{font-size:.75rem;color:var(--wa-text2);white-space:nowrap}
.wa-search-bar button{background:none;border:none;color:var(--wa-text2);cursor:pointer;padding:6px;border-radius:4px;display:flex;align-items:center}
.wa-search-bar button:hover{color:var(--wa-text);background:var(--wa-hover)}

/* === RESPONSIVE === */
@media(max-width:768px){
  .wa-sidebar{width:100%;min-width:100%;position:absolute;inset:0;z-index:2;transition:transform .25s ease}
  .wa-sidebar.hidden{transform:translateX(-100%)}
  .wa-chat{position:absolute;inset:0;z-index:3;transform:translateX(100%);transition:transform .25s ease}
  .wa-chat.active{transform:translateX(0)}
  .wa-chat-header .wa-back-btn{display:flex}
  .wa-msg{max-width:85%}
  .wa-messages{padding:12px 10px 12px 16px}
  .wa-msg-media img,.wa-msg-media video{max-width:240px}
  .wa-tpl-dialog{width:96%;max-height:90vh;border-radius:8px}
}

*{scrollbar-width:thin}

/* ═══════ WhatsApp Calling UI ═══════ */
.wa-call-header-btn{
  background:none;border:none;color:var(--wa-text2);cursor:pointer;
  padding:8px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  transition:all .15s;width:40px;height:40px;flex-shrink:0;margin-left:auto;
}
.wa-call-header-btn:hover{color:var(--wa-green);background:var(--wa-hover)}
.wa-call-header-btn svg{width:22px;height:22px}
.wa-call-overlay{
  position:absolute;inset:0;z-index:200;
  background:linear-gradient(180deg,#0b141a 0%,#111b21 40%,#1a2830 100%);
  display:flex;align-items:center;justify-content:center;
  animation:wa-call-fadeIn .35s ease-out;
}
.wa-call-overlay.wa-call-exit{animation:wa-call-fadeOut .3s ease-in forwards}
@keyframes wa-call-fadeIn{from{opacity:0;transform:scale(1.03)}to{opacity:1;transform:scale(1)}}
@keyframes wa-call-fadeOut{from{opacity:1}to{opacity:0}}
.wa-call-card{text-align:center;padding:40px 32px}
.wa-call-card.ringing .wa-call-avatar{animation:wa-call-ring 1.8s ease-in-out infinite}
@keyframes wa-call-ring{0%,100%{box-shadow:0 0 0 0 rgba(0,168,132,.45)}50%{box-shadow:0 0 0 22px rgba(0,168,132,0)}}
.wa-call-avatar{
  width:96px;height:96px;border-radius:50%;background:#6b7b8d;
  display:flex;align-items:center;justify-content:center;
  font-size:2rem;font-weight:500;color:#fff;margin:0 auto 20px;text-transform:uppercase;
  transition:box-shadow .3s;
}
.wa-call-name{font-size:1.35rem;color:var(--wa-text);font-weight:400;margin-bottom:4px}
.wa-call-phone{font-size:.88rem;color:var(--wa-text2);margin-bottom:14px}
.wa-call-status{font-size:.9rem;color:var(--wa-green);margin-bottom:48px;min-height:1.2em}
.wa-call-buttons{display:flex;align-items:center;justify-content:center;gap:28px}
.wa-call-btn{
  border-radius:50%;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:transform .15s,box-shadow .15s;
}
.wa-call-btn:hover{transform:scale(1.1)}
.wa-call-btn:active{transform:scale(.93)}
.wa-call-btn svg{width:28px;height:28px}
.wa-call-btn.answer{width:64px;height:64px;background:var(--wa-green);color:#fff;box-shadow:0 4px 20px rgba(0,168,132,.45)}
.wa-call-btn.reject,.wa-call-btn.hangup{width:64px;height:64px;background:var(--wa-danger);color:#fff;box-shadow:0 4px 20px rgba(239,68,68,.4)}
.wa-call-btn.small{width:50px;height:50px;background:var(--wa-input-bg);color:var(--wa-text);box-shadow:none}
.wa-call-btn.small:hover{background:rgba(134,150,160,.2)}
.wa-call-btn.small.active{background:var(--wa-green);color:#fff}
.wa-call-btn.small svg{width:22px;height:22px}
#wa-call-timer{font-variant-numeric:tabular-nums;font-size:.95rem}

.wa-conv-item{position:relative;overflow:hidden}
.wa-conv-order-bar{position:absolute;right:0;top:4px;bottom:4px;width:4px;border-radius:2px}
.wa-conv-order-bar.confirmed{background:#25D366}
.wa-conv-order-bar.cancelled{background:#EF4444}
.wa-conv-order-bar.modified{background:#3B82F6}
.wa-conv-order-bar.none{background:transparent}






.wa-window-closed-bar{display:flex;align-items:center;justify-content:center;padding:14px 20px}





button.wa-tpl-open-btn{width:auto!important;height:auto!important;display:inline-flex!important;align-items:center!important;gap:10px!important;background:linear-gradient(135deg,#25D366 0%,#128C7E 100%)!important;color:#fff!important;border:none!important;border-radius:28px!important;padding:12px 28px!important;font-size:15px!important;font-weight:600!important;cursor:pointer!important;box-shadow:0 4px 15px rgba(37,211,102,0.3)!important;white-space:nowrap!important;letter-spacing:0.3px}
button.wa-tpl-open-btn:hover{transform:translateY(-1px)!important;box-shadow:0 6px 20px rgba(37,211,102,0.4)!important;background:linear-gradient(135deg,#2be672 0%,#159e8c 100%)!important}
button.wa-tpl-open-btn svg{flex-shrink:0;width:22px;height:22px}
