@import "https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=Fraunces:wght@600;700&display=swap";.login-container{--ink:#0f172a;--ink-soft:#475569;--accent:#0fbf6b;--accent-dark:#0aa55b;--paper:#fff;--paper-soft:#f8fafc;background:radial-gradient(900px 500px at 15% 10%,#e6fff2 0%,#0000 55%),radial-gradient(700px 380px at 85% 0,#eaf2ff 0%,#0000 45%),linear-gradient(135deg,#0f172a 0%,#162645 45%,#101827 100%);justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;font-family:Space Grotesk,system-ui,-apple-system,sans-serif;display:flex}.login-card{background:#fffffffa;border:1px solid #fff6;border-radius:20px;width:100%;max-width:440px;animation:.6s ease-out fadeIn;position:relative;overflow:hidden;box-shadow:0 30px 80px #09142859}.login-header{text-align:center;background:radial-gradient(240px 120px at 50% 0,#0fbf6b1f 0%,#0000 70%),linear-gradient(#f6f8fb 0%,#fff 100%);padding:2.75rem 2rem 1.75rem}.login-icon{background:linear-gradient(135deg,#0fbf6b 0%,#25d366 100%);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1rem;display:flex;box-shadow:0 12px 30px #0fbf6b59}.login-header h1{color:var(--ink);letter-spacing:-.02em;margin:0 0 .5rem;font-family:Fraunces,serif;font-size:1.9rem}.login-header p{color:var(--ink-soft);margin:0;font-size:.95rem}.login-form{padding:2rem 2.25rem 2.25rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--ink);align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.95rem;font-weight:500;display:flex}.form-group input{background:var(--paper-soft);width:100%;color:var(--ink);border:1.5px solid #e2e8f0;border-radius:12px;padding:.9rem 1rem;font-size:1rem;transition:all .2s}.password-field{align-items:center;display:flex;position:relative}.password-field input{padding-right:2.75rem}.btn-toggle-password{color:var(--ink-soft);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;right:.85rem}.btn-toggle-password:hover{color:var(--ink)}.form-group input:focus{border-color:var(--accent);background:var(--paper);outline:none;box-shadow:0 0 0 4px #0fbf6b1f}.form-group input::placeholder{color:#94a3b8}.btn-login{background:linear-gradient(135deg, var(--accent) 0%, #22c55e 100%);width:100%;color:var(--white);cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;padding:1rem;font-size:1.02rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 12px 24px #10b98140}.btn-login:hover:not(:disabled){background:linear-gradient(135deg, var(--accent-dark) 0%, #16a34a 100%);transform:translateY(-2px)}.btn-login:active:not(:disabled){transform:translateY(0);box-shadow:0 8px 16px #10b98133}.btn-login:disabled{opacity:.7;cursor:not-allowed}.login-footer{text-align:center;background:#f1f5f9;border-top:1px solid #e2e8f0;padding:1.5rem 2rem}.login-footer p{color:var(--ink-soft);margin:0;font-size:.9rem}@media (width<=480px){.login-card{border-radius:0}.login-header{padding:2.25rem 1.5rem 1rem}.login-form{padding:1.5rem}.login-footer{padding:1rem 1.5rem}}.dashboard{flex-direction:column;gap:1.5rem;max-width:1400px;margin:0 auto;display:flex}.dashboard-loading{flex-direction:column;justify-content:center;align-items:center;gap:.875rem;min-height:420px;display:flex}.dashboard-loading p{color:var(--dark-gray)}.dashboard-hero{color:var(--white);box-shadow:var(--shadow-md);background:linear-gradient(135deg,#0b3f38 0%,#128c7e 55%,#1cae65 100%);border-radius:16px;justify-content:space-between;gap:1.25rem;padding:1.5rem;display:flex}.dashboard-hero-copy h1{margin:0;font-size:1.75rem;line-height:1.25}.dashboard-hero-copy p{color:#ffffffe6;max-width:620px;margin:.5rem 0 0;font-size:.97rem}.dashboard-hero-meta{flex-direction:column;align-items:flex-end;gap:.5rem;min-width:220px;display:flex}.dashboard-live-indicator{background:#ffffff2e;border:1px solid #ffffff47;border-radius:999px;align-items:center;gap:.5rem;padding:.35rem .7rem;font-size:.82rem;font-weight:600;display:inline-flex}.dashboard-live-indicator.is-refreshing{animation:1.2s ease-in-out infinite dashboardPulse}.dashboard-live-dot{background:#b9ffd7;border-radius:50%;width:8px;height:8px}.dashboard-sync-time{color:#ffffffe6;font-size:.82rem}.dashboard-refresh-button{color:var(--white);cursor:pointer;background:#ffffff26;border:1px solid #ffffff59;border-radius:10px;align-items:center;gap:.45rem;padding:.45rem .8rem;font-size:.85rem;font-weight:600;transition:background .2s,transform .2s;display:inline-flex}.dashboard-refresh-button:hover:not(:disabled){background:#ffffff3d;transform:translateY(-1px)}.dashboard-refresh-button:disabled{cursor:not-allowed;opacity:.75}.spin-icon{animation:.7s linear infinite spin}.dashboard-error-banner{color:#b91c1c;background:#fff1f2;border:1px solid #fecaca;border-radius:12px;justify-content:space-between;align-items:center;gap:1rem;padding:.8rem 1rem;font-size:.9rem;display:flex}.dashboard-error-banner button{color:var(--white);cursor:pointer;background:#ef4444;border:none;border-radius:8px;padding:.4rem .75rem;font-size:.82rem;font-weight:600}.dashboard-stats-grid{grid-template-columns:repeat(auto-fit,minmax(215px,1fr));gap:1rem;display:grid}.dashboard-stat-card{background:var(--white);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:14px;align-items:center;gap:.75rem;padding:1rem;transition:transform .2s,box-shadow .2s;display:flex}.dashboard-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.dashboard-stat-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.dashboard-stat-content{min-width:0}.dashboard-stat-label{color:var(--dark-gray);text-transform:uppercase;letter-spacing:.4px;font-size:.78rem;font-weight:600}.dashboard-stat-value{color:var(--black);margin-top:.15rem;font-size:1.45rem;font-weight:700;line-height:1.2}.dashboard-stat-note{color:var(--gray);white-space:nowrap;text-overflow:ellipsis;margin-top:.2rem;font-size:.8rem;overflow:hidden}.dashboard-panels-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;display:grid}.dashboard-panel{background:var(--white);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:14px;padding:1rem}.dashboard-panel-header{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:.9rem;display:flex}.dashboard-panel-header h2{color:var(--black);margin:0;font-size:1rem}.dashboard-panel-header p{color:var(--dark-gray);margin:.22rem 0 0;font-size:.84rem}.dashboard-panel-link{color:#0f766e;white-space:nowrap;background:#ccfbf1;border-radius:999px;padding:.28rem .62rem;font-size:.78rem;font-weight:700;text-decoration:none}.dashboard-panel-link:hover{background:#99f6e4}.dashboard-trend-badge{color:#065f46;background:#d1fae5;border-radius:999px;padding:.3rem .58rem;font-size:.78rem;font-weight:700}.dashboard-trend-bars{justify-content:space-between;align-items:flex-end;gap:.6rem;min-height:190px;display:flex}.dashboard-trend-bar-column{flex-direction:column;flex:1;align-items:center;gap:.35rem;min-width:0;display:flex}.dashboard-trend-bar{background:linear-gradient(#f3f4f6 0%,#e5e7eb 100%);border:1px solid #e5e7eb;border-radius:10px;align-items:flex-end;width:100%;height:140px;display:flex;position:relative;overflow:hidden}.dashboard-trend-fill{background:linear-gradient(#34d399 0%,#16a34a 100%);border-radius:8px;width:100%;transition:height .25s}.dashboard-trend-bar.is-today .dashboard-trend-fill{background:linear-gradient(#22d3ee 0%,#0284c7 100%)}.dashboard-trend-value{color:var(--black);font-size:.83rem;font-weight:600}.dashboard-trend-label{color:var(--gray);font-size:.75rem}.dashboard-health-list{flex-direction:column;gap:.95rem;display:flex}.dashboard-health-item{flex-direction:column;gap:.42rem;display:flex}.dashboard-health-head{color:var(--dark-gray);justify-content:space-between;align-items:center;font-size:.86rem;display:flex}.dashboard-health-head strong{color:var(--black)}.dashboard-progress-track{background:#edf2f7;border-radius:999px;width:100%;height:8px;overflow:hidden}.dashboard-progress-fill{border-radius:inherit;height:100%}.dashboard-progress-fill.fill-outgoing{background:linear-gradient(90deg,#25d366 0%,#128c7e 100%)}.dashboard-progress-fill.fill-incoming{background:linear-gradient(90deg,#22d3ee 0%,#0284c7 100%)}.dashboard-progress-fill.fill-response{background:linear-gradient(90deg,#f59e0b 0%,#ea580c 100%)}.dashboard-progress-fill.fill-discipline{background:linear-gradient(90deg,#14b8a6 0%,#0f766e 100%)}.dashboard-snapshot-list{flex-direction:column;gap:.7rem;margin:0;padding:0;list-style:none;display:flex}.dashboard-snapshot-list li{border:1px solid var(--border);border-radius:10px;justify-content:space-between;align-items:center;gap:.8rem;padding:.58rem .7rem;font-size:.87rem;display:flex}.dashboard-snapshot-list li span{color:var(--dark-gray);align-items:center;gap:.4rem;display:inline-flex}.dashboard-snapshot-list li strong{color:var(--black);font-size:.88rem}.dashboard-discipline-list{flex-direction:column;gap:.75rem;display:flex}.dashboard-discipline-item{flex-direction:column;gap:.32rem;display:flex}.dashboard-discipline-head{color:var(--dark-gray);justify-content:space-between;align-items:center;font-size:.85rem;display:flex}.dashboard-empty{color:var(--gray);padding:.6rem 0;font-size:.9rem}.dashboard-notification-list{flex-direction:column;gap:.7rem;display:flex}.dashboard-notification-item{border:1px solid var(--border);border-radius:10px;grid-template-columns:auto 1fr auto;align-items:center;gap:.65rem;padding:.55rem .65rem;display:grid}.dashboard-notification-item.severity-critical{background:#fff1f2;border-color:#fca5a5}.dashboard-notification-item.severity-warning{background:#fffbeb;border-color:#fcd34d}.dashboard-notification-item.severity-info{background:#eff6ff;border-color:#93c5fd}.dashboard-notification-icon{justify-content:center;align-items:center;display:inline-flex}.dashboard-notification-item.severity-critical .dashboard-notification-icon{color:#b91c1c}.dashboard-notification-item.severity-warning .dashboard-notification-icon{color:#b45309}.dashboard-notification-item.severity-info .dashboard-notification-icon{color:#1d4ed8}.dashboard-notification-content{min-width:0}.dashboard-notification-title{color:var(--black);font-size:.84rem;font-weight:700}.dashboard-notification-detail{color:var(--dark-gray);margin-top:.08rem;font-size:.8rem}.dashboard-notification-time{color:var(--gray);white-space:nowrap;font-size:.75rem}.dashboard-queue-list{flex-direction:column;gap:.7rem;display:flex}.dashboard-queue-item{border:1px solid var(--border);background:#fcfcfc;border-radius:10px;padding:.62rem .7rem;text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .15s;display:block}.dashboard-queue-item:hover{border-color:#ef444459;transform:translateY(-1px);box-shadow:0 8px 18px #0f172a0f}.dashboard-queue-head{justify-content:space-between;align-items:center;gap:.7rem;display:flex}.dashboard-queue-head strong{color:var(--black);font-size:.86rem}.dashboard-queue-badge{color:#b91c1c;white-space:nowrap;background:#fee2e2;border-radius:999px;padding:.2rem .52rem;font-size:.72rem;font-weight:700}.dashboard-queue-item p{color:var(--dark-gray);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:.36rem 0 0;font-size:.81rem;line-height:1.35;display:-webkit-box;overflow:hidden}.dashboard-queue-meta{color:var(--gray);justify-content:space-between;align-items:center;gap:.6rem;margin-top:.42rem;font-size:.75rem;display:flex}@keyframes dashboardPulse{0%{transform:translateY(0)}50%{transform:translateY(-1px)}to{transform:translateY(0)}}@media (width<=1024px){.dashboard-hero{flex-direction:column}.dashboard-hero-meta{align-items:flex-start}.dashboard-panels-grid{grid-template-columns:1fr}}@media (width<=640px){.dashboard{gap:1rem}.dashboard-hero{border-radius:14px;padding:1.1rem}.dashboard-hero-copy h1{font-size:1.4rem}.dashboard-stats-grid{grid-template-columns:1fr}.dashboard-trend-bar{height:118px}}.chat-inbox{background:var(--white);border-radius:16px;height:100%;min-height:0;max-height:100%;display:flex;position:relative;overflow:hidden;box-shadow:0 10px 40px #0000001a}.chat-sidebar{border-right:1px solid var(--border);background:linear-gradient(#fff 0%,#f8f9fa 100%);flex-direction:column;width:380px;display:flex}.chat-sidebar-header{background:linear-gradient(135deg, var(--whatsapp-green) 0%, #1ea952 100%);color:var(--white);border-bottom:none;padding:1.5rem;box-shadow:0 2px 8px #25d36633}.chat-sidebar-header h2{color:var(--white);letter-spacing:.5px;margin:0;font-size:1.5rem;font-weight:600}.search-box{border-bottom:1px solid var(--border);background:var(--white);padding:1rem 1.5rem}.search-box input{border:2px solid var(--border);background:var(--light-gray);border-radius:24px;width:100%;padding:.75rem 1rem .75rem 2.5rem;font-size:.9375rem;transition:all .2s}.search-box input:focus{border-color:var(--whatsapp-green);background:var(--white);outline:none;box-shadow:0 0 0 3px #25d3661a}.search-box{position:relative}.sidebar-actions{margin:.8rem 1.5rem 1rem}.btn-add-user{color:#14532d;cursor:pointer;background:linear-gradient(#f7fff9 0%,#ebfff2 100%);border:1px solid #25d36659;border-radius:10px;justify-content:center;align-items:center;gap:.4rem;width:100%;padding:.6rem .75rem;font-size:.85rem;font-weight:700;transition:all .15s;display:inline-flex}.btn-add-user:hover{background:linear-gradient(#ebfff2 0%,#defce7 100%);border-color:#25d36699}.unread-summary{color:#991b1b;background:#fff5f5;border:1px solid #ef444433;border-radius:12px;justify-content:space-between;align-items:center;margin:0 1.5rem 1rem;padding:.45rem 1rem;font-size:.85rem;font-weight:600;display:flex}.unread-summary-count{color:#fff;text-align:center;background:#ef4444;border-radius:999px;min-width:22px;height:22px;padding:0 8px;font-size:.75rem;font-weight:700;line-height:22px}.search-box svg{color:var(--gray);pointer-events:none;z-index:1;position:absolute;top:50%;left:2.25rem;transform:translateY(-50%)}.users-list{scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex:1;overflow-y:auto}.users-list::-webkit-scrollbar{width:6px}.users-list::-webkit-scrollbar-track{background:0 0}.users-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.users-list::-webkit-scrollbar-thumb:hover{background:var(--gray)}.loading-users,.no-users{color:var(--gray);justify-content:center;align-items:center;padding:2rem;display:flex}.user-item{cursor:pointer;border-bottom:1px solid #0000000d;align-items:center;gap:1rem;padding:.9rem 1.25rem;transition:all .2s;display:flex;position:relative}.user-item:before{content:"";background:var(--whatsapp-green);width:0;transition:width .2s;position:absolute;top:0;bottom:0;left:0}.user-item:hover{background:linear-gradient(90deg,#25d36614 0%,#0000 100%)}.user-item:hover:before{width:4px}.user-item.active{background:linear-gradient(90deg,#25d3662e 0%,#25d3660f 100%)}.user-item.active:before{width:4px}.user-item.human-required{background:linear-gradient(90deg,#ef444424 0%,#f871710d 100%)}.user-item.human-required:before{background:#ef4444;width:4px}.user-item.human-required:hover{background:linear-gradient(90deg,#ef44442e 0%,#f8717114 100%)}.user-item.human-required.active{background:linear-gradient(90deg,#ef444438 0%,#f8717114 100%)}.user-avatar{width:46px;height:46px;color:var(--white);text-transform:uppercase;border:2px solid var(--white);background:linear-gradient(135deg,#25d366 0%,#20ba5f 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;display:flex;box-shadow:0 2px 6px #25d36633}.user-info{flex-direction:column;flex:1;gap:.3rem;width:100%;min-width:0;display:flex}.user-row{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:.75rem;width:100%;display:grid}.user-row-right{flex-shrink:0;justify-content:flex-end;align-items:center;gap:.45rem;display:flex}.user-actions{opacity:0;pointer-events:none;align-items:center;gap:.3rem;transition:opacity .16s;display:inline-flex}.user-item:hover .user-actions,.user-item.active .user-actions{opacity:1;pointer-events:auto}.user-action-btn{color:#475569;cursor:pointer;background:#fff;border:1px solid #94a3b880;border-radius:6px;justify-content:center;align-items:center;width:24px;height:24px;transition:all .15s;display:inline-flex}.user-action-btn:hover{color:#166534;background:#25d36617;border-color:#25d36699}.user-action-btn.delete:hover{color:#991b1b;background:#ef44441a;border-color:#ef444480}.user-unread-badge{color:#fff;text-align:center;background:#ef4444;border-radius:999px;flex-shrink:0;min-width:18px;height:18px;padding:0 6px;font-size:.7rem;font-weight:700;line-height:18px;box-shadow:0 0 0 3px #ef44442e}.user-name{color:var(--black);font-family:Gill Sans,Gill Sans MT,Calibri,Trebuchet MS,sans-serif;font-size:1rem;font-weight:700;line-height:1.3}.user-meta{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.user-phone{color:#64748b;letter-spacing:.2px;font-size:.85rem}.user-badge{color:#0f5132;background:#25d36626;border:1px solid #25d36640;border-radius:999px;padding:.2rem .45rem;font-size:.72rem;font-weight:600}.user-support-badge{color:#991b1b;background:#ef44441f;border-color:#ef44444d}.user-time{color:#8a94a6;white-space:nowrap;font-size:.75rem;font-weight:500}.chat-main{background-color:#e5ddd5;background-image:linear-gradient(#ffffffe6,#ffffffe6),repeating-linear-gradient(45deg,#0000,#0000 10px,#00000005 10px 20px);background-position:0 0;background-repeat:repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;flex-direction:column;flex:1;display:flex}.chat-header{border-bottom:1px solid var(--border);background:linear-gradient(135deg,#f0f2f5 0%,#fff 100%);justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex;box-shadow:0 2px 8px #00000014}.chat-header-user{align-items:center;gap:1rem;display:flex}.chat-header-name{color:var(--black);flex-wrap:wrap;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;display:flex}.chat-header-phone{color:var(--gray);font-size:.875rem;font-weight:500}.chat-header-badge{letter-spacing:0;color:#991b1b;background:#ef44441f;border:1px solid #ef444440;border-radius:999px;align-items:center;padding:.22rem .55rem;font-size:.7rem;font-weight:700;display:inline-flex}.chat-header-actions{align-items:center;gap:.5rem;display:flex}.btn-handoff-action{cursor:pointer;border:1px solid #0000;border-radius:10px;align-items:center;gap:.4rem;min-height:36px;padding:0 .75rem;font-size:.82rem;font-weight:700;transition:all .15s;display:inline-flex}.btn-handoff-action.accept{color:#065f46;background:#10b98124;border-color:#10b9814d}.btn-handoff-action.close{color:#991b1b;background:#ef44441a;border-color:#ef444442}.btn-handoff-action:hover:not(:disabled){transform:translateY(-1px)}.btn-handoff-action:disabled{opacity:.65;cursor:not-allowed}.chat-header-actions .btn-icon{border:1px solid var(--border);background:var(--white);cursor:pointer;width:36px;height:36px;color:var(--black);border-radius:10px;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}.chat-header-actions .btn-icon:hover{background:#25d36614;border-color:#25d36666}.btn-clear-template{border:1px solid var(--border);color:var(--black);cursor:pointer;background:0 0;border-radius:999px;padding:.25rem .6rem;font-size:.8rem}.template-modal-overlay{z-index:9999;background:#0b12208c;justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.template-modal{background:var(--white);transform-origin:50%;border-radius:16px;width:100%;max-width:520px;animation:.18s ease-out modalPop;overflow:hidden;box-shadow:0 30px 80px #00000059}.template-modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.template-modal-body{max-height:60vh;padding:.75rem 1rem 1rem;overflow:auto}.template-list-modal{flex-direction:column;gap:.5rem;display:flex}.template-item-modal{text-align:left;border:1px solid var(--border);background:var(--white);cursor:pointer;border-radius:12px;padding:.75rem .9rem;transition:all .15s}.template-item-modal:hover{background:#25d3660f;border-color:#25d36680}.template-item-modal.selected{background:#25d3661f;border-color:#25d366cc}@keyframes modalPop{0%{opacity:0;transform:translateY(10px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.template-item-title{color:var(--black);font-size:.95rem;font-weight:600}.template-item-meta{color:var(--gray);gap:.35rem;margin-top:.15rem;font-size:.8rem;display:flex}.template-item-preview{color:var(--black);opacity:.85;-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-top:.5rem;font-size:.85rem;line-height:1.4;display:-webkit-box;overflow:hidden}.template-item-params{flex-wrap:wrap;gap:.4rem;margin-top:.5rem;display:flex}.param-pill{color:#0f5132;background:#25d36624;border:1px solid #25d36640;border-radius:999px;padding:.2rem .5rem;font-size:.7rem}.template-modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:.5rem;padding:.9rem 1rem 1rem;display:flex}.new-user-modal{max-width:440px}.new-user-modal-copy{color:#475569;margin:0 0 .75rem;font-size:.9rem;line-height:1.45}.new-user-modal-input{color:#0f172a;background:#fff;border:1px solid #94a3b873;border-radius:10px;width:100%;padding:.65rem .75rem;font-size:.95rem}.new-user-modal-input:focus{border-color:#25d366b3;outline:none;box-shadow:0 0 0 3px #25d3661f}.new-user-modal-input+.new-user-modal-input{margin-top:.6rem}.btn-add-user-confirm{color:#fff;cursor:pointer;background:#25d366;border:none;border-radius:8px;padding:.5rem .85rem;font-size:.85rem;font-weight:600}.btn-add-user-confirm:hover{background:#20ba5f}.chat-messages{scrollbar-width:thin;scrollbar-color:#0003 transparent;scroll-behavior:smooth;background:0 0;flex:1;padding:1.5rem;position:relative;overflow:hidden auto}.messages-loading{height:100%;min-height:200px;color:var(--gray);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;display:flex}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:0 0}.chat-messages::-webkit-scrollbar-thumb{background:#0003;border-radius:4px}.message{margin-bottom:.75rem;animation:.3s ease-out messageSlideIn;display:flex}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.sent{justify-content:flex-end}.message.received{justify-content:flex-start}.message-bubble{overflow-wrap:anywhere;border-radius:7.5px;width:fit-content;min-width:0;max-width:min(72%,640px);padding:.45rem .55rem .35rem .65rem;position:relative;overflow:visible;box-shadow:0 1px 1px #0b141a21}.message.sent .message-bubble{background:#d9fdd3;border-bottom-right-radius:2px;padding-right:.7rem}.message.sent .message-bubble:before{content:"";filter:drop-shadow(2px 2px 2px #00000014);border-bottom:8px solid #0000;border-left:8px solid #dcf8c6;width:0;height:0;position:absolute;bottom:0;right:-8px}.message.received .message-bubble{background:#fff;border-bottom-left-radius:2px}.message.received .message-bubble:before{content:"";border-right:8px solid var(--white);filter:drop-shadow(-2px 2px 2px #00000014);border-bottom:8px solid #0000;width:0;height:0;position:absolute;bottom:0;left:-8px}.message-content{color:#111b21;word-wrap:break-word;word-break:break-word;white-space:normal;max-width:100%;font-size:.92rem;font-weight:400;line-height:1.42}.message-content strong{font-weight:700}.message-content em{font-style:italic}.message-content del{text-decoration-thickness:1.5px}.message-content a{color:#027eb5;overflow-wrap:anywhere;text-decoration:none}.message-content a:hover{text-decoration:underline}.message-inline-code{background:#111b2114;border-radius:4px;padding:.08rem .28rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:.86em}.message-code-block{color:#111b21;white-space:pre-wrap;background:#111b2114;border-radius:6px;margin:.4rem 0;padding:.55rem .65rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,monospace;font-size:.84rem;line-height:1.4;display:block;overflow-x:auto}.message-reply-context,.reply-text{word-break:break-word;overflow-wrap:anywhere;max-width:100%}.message-image{background:#00000005;border-radius:8px;max-width:280px;margin-bottom:.5rem;position:relative;overflow:hidden}.message-image img{max-width:100%;height:auto;display:block}.image-placeholder{background:#eef1f5;border-radius:8px;width:100%;height:200px}.shimmer{background:linear-gradient(90deg,#eef1f5 0%,#f7f9fc 50%,#eef1f5 100%) 0 0/200% 100%;animation:1.2s ease-in-out infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.message-image img{object-fit:contain;cursor:pointer;border-radius:8px;width:100%;height:auto;max-height:240px;display:block}.image-error{text-align:center;color:var(--gray);padding:2rem;font-size:.875rem}.image-error .btn-retry{border:1px solid var(--border);background:var(--white);color:var(--black);cursor:pointer;border-radius:6px;margin-top:.75rem;padding:.4rem .75rem;font-size:.8125rem}.message-caption{color:var(--black);margin-top:.5rem;font-size:.875rem;line-height:1.4}.btn-download-image{width:32px;height:32px;color:var(--white);cursor:pointer;opacity:0;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;bottom:.5rem;right:.5rem}.message-image:hover .btn-download-image{opacity:1}.btn-download-image:hover{background:#000c;transform:scale(1.1)}.message-document{cursor:pointer;background:#0000000d;border-radius:8px;align-items:center;gap:.75rem;margin-bottom:.5rem;padding:.875rem;transition:all .2s;display:flex}.message-document:hover{background:#00000014}.document-info{flex-direction:column;flex:1;gap:.25rem;display:flex}.document-download{color:var(--whatsapp-green);align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;text-decoration:none;display:inline-flex}.document-download:hover{text-decoration:underline}.message-document span{color:var(--black);font-size:.875rem;font-weight:500}.message-audio audio,.message-video video{border-radius:12px;width:320px;max-width:100%}.message-video video{background:#000;height:auto}.message-media-unavailable{width:320px;max-width:100%;color:var(--black);background:#ffffff8c;border-radius:12px;align-items:center;gap:.75rem;padding:.85rem;display:flex}.media-unavailable-info{flex-direction:column;min-width:0;display:flex}.media-unavailable-info span{text-overflow:ellipsis;white-space:nowrap;font-size:.9rem;font-weight:600;overflow:hidden}.media-unavailable-info small{color:var(--gray);margin-top:.15rem;font-size:.75rem;line-height:1.25}.message-footer{justify-content:flex-end;align-items:center;gap:.3rem;min-height:1rem;margin-top:.2rem;line-height:1;display:flex}.message.sent .message-footer{padding-right:.15rem}.message-time{color:#111b2185;text-align:right;font-size:.68rem;font-weight:500}.message-status{flex:none;justify-content:center;align-items:center;line-height:0;display:flex}.message-status svg{display:block}.message-bubble{position:relative}.message-actions{opacity:0;gap:.25rem;transition:opacity .2s;display:flex;position:absolute;top:.5rem;right:-70px}.message.sent .message-actions{left:-70px;right:auto}.message:hover .message-actions{opacity:1}.unread-divider{color:#991b1b;cursor:pointer;background:#fff5f5;border:1px solid #ef444433;border-radius:999px;justify-content:space-between;align-items:center;gap:.75rem;width:fit-content;margin:.75rem auto;padding:.4rem .9rem;font-size:.8rem;font-weight:600;display:flex}.unread-divider button{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:999px;padding:.15rem .55rem;font-size:.7rem;font-weight:700}.message-action-btn{background:var(--white);border:1px solid var(--border);width:32px;height:32px;color:var(--dark-gray);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000001a}.message-action-btn:hover{background:var(--whatsapp-green);color:var(--white);border-color:var(--whatsapp-green);transform:scale(1.1)}.message-delete-btn:hover{background:#ef4444;border-color:#ef4444}.message-highlight .message-bubble{animation:6s ease-out messageGlow;box-shadow:0 0 #25d36659}.message-bubble-highlight{background:#25d36614;border:1px solid #25d36659}@keyframes messageGlow{0%{box-shadow:0 0 #25d36699}40%{box-shadow:0 0 0 10px #25d36633}to{box-shadow:0 0 #25d36600}}.message-reply-context{background:#0000000d;border-radius:6px;gap:.5rem;margin-bottom:.5rem;padding:.5rem;display:flex}.reply-line{background:var(--whatsapp-green);border-radius:2px;flex-shrink:0;width:3px}.reply-author{color:var(--whatsapp-green);margin-bottom:.25rem;font-size:.8125rem;font-weight:600;display:block}.reply-text{color:var(--dark-gray);text-overflow:ellipsis;white-space:nowrap;max-width:250px;font-size:.8125rem;display:block;overflow:hidden}.reply-preview{border-bottom:1px solid var(--border);background:linear-gradient(90deg,#25d3661a 0%,#0000 100%);justify-content:space-between;align-items:center;padding:.75rem 1.5rem;display:flex}.reply-preview-content{flex:1;gap:.5rem;display:flex}.btn-cancel-reply{width:32px;height:32px;color:var(--gray);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-cancel-reply:hover{color:var(--black);background:#0000000d}.no-messages{height:100%;color:var(--gray);justify-content:center;align-items:center;font-size:.9375rem;display:flex}.chat-input-container{background:var(--white);border-top:1px solid var(--border);box-shadow:0 -2px 8px #0000000d}.service-window-warning{color:#8a5a00;background:#ffc1072e;border:1px solid #ffc10766;border-radius:10px;margin:.75rem 1.5rem 0;padding:.6rem .75rem;font-size:.82rem}.send-error-banner{color:#8a1d2a;background:#dc35451f;border:1px solid #dc354559;border-radius:10px;margin:.75rem 1.5rem 0;padding:.6rem .75rem;font-size:.82rem}.handoff-session-banner{border-radius:10px;margin:.75rem 1.5rem 0;padding:.6rem .75rem;font-size:.82rem;line-height:1.4}.handoff-session-banner.waiting{color:#991b1b;background:#ef44441a;border:1px solid #ef444447}.handoff-session-banner.active{color:#065f46;background:#10b9811c;border:1px solid #10b9814d}.template-params-container{border-bottom:1px solid var(--border);background:var(--primary-light);scrollbar-width:thin;scrollbar-color:#0f172a2e transparent;max-height:min(42vh,360px);padding:1rem 1.5rem;overflow-y:auto}.template-params-container::-webkit-scrollbar{width:8px}.template-params-container::-webkit-scrollbar-thumb{background:#0f172a2e;border-radius:8px}.template-params-container::-webkit-scrollbar-track{background:0 0}.template-selected-info{color:var(--primary-dark);margin-bottom:.75rem;font-size:.875rem;font-weight:600}.template-preview-card{background:#fff;border:1px solid #1018281f;border-radius:10px;margin-bottom:.75rem;padding:.75rem}.template-preview-title{color:#334155;margin-bottom:.5rem;font-size:.82rem;font-weight:700}.template-preview-row{align-items:flex-start;gap:.5rem;margin-bottom:.45rem;display:flex}.template-preview-row:last-child{margin-bottom:0}.template-preview-label{color:#475569;text-transform:uppercase;letter-spacing:.02em;min-width:52px;font-size:.76rem;font-weight:700}.template-preview-content{color:#0f172a;white-space:pre-wrap;word-break:break-word;font-size:.84rem;line-height:1.45}.template-preview-token{color:#166534;background:#25d36624;border-radius:6px;margin:0 .08rem;padding:0 .3rem;font-weight:700;display:inline-block}.template-preview-text{color:inherit}.template-params{flex-wrap:wrap;gap:.75rem;display:flex}.param-input{border:1px solid var(--border);border-radius:6px;flex:1;min-width:150px;padding:.625rem;font-size:.875rem}.param-input:focus{border-color:var(--primary);outline:none}.template-header-media-upload{background:#25d3660f;border:1px dashed #25d36659;border-radius:10px;margin-top:.75rem;padding:.75rem}.template-header-media-title{color:#0f5132;margin-bottom:.55rem;font-size:.82rem;font-weight:700}.template-header-media-actions{flex-wrap:wrap;align-items:center;gap:.55rem;display:flex}.template-header-media-upload .btn-secondary{color:#0f5132;cursor:pointer;background:#fff;border:1px solid #0f513240;border-radius:8px;padding:.42rem .7rem;font-size:.8rem;font-weight:600}.template-header-media-upload .btn-secondary:hover{background:#25d3661f}.template-header-media-upload .btn-secondary.disabled{opacity:.65;cursor:not-allowed}.template-header-media-meta{color:#1f2937;align-items:flex-start;gap:.35rem;margin-top:.6rem;font-size:.76rem;display:flex}.template-header-media-label{color:#334155;font-weight:700}.template-header-media-value{word-break:break-all}.template-header-media-preview-wrap{margin-top:.65rem}.template-header-media-preview{background:#fff;border:1px solid #94a3b866;border-radius:8px;max-width:220px;max-height:180px}@media (width<=768px){.template-params-container{max-height:min(36vh,320px)}}.chat-input{background:var(--white);align-items:flex-end;gap:.75rem;padding:1rem 1.5rem;display:flex}.attach-menu-container{position:relative}.btn-attach{width:42px;height:42px;color:var(--gray);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.btn-attach:hover{background:var(--light-gray);color:var(--whatsapp-green);transform:scale(1.1)}.btn-attach:disabled{opacity:.5;cursor:not-allowed}.attach-menu{background:var(--white);border:1px solid var(--border);z-index:100;border-radius:12px;flex-direction:column;gap:.25rem;min-width:180px;padding:.5rem;animation:.2s ease-out slideUp;display:flex;position:absolute;bottom:calc(100% + .5rem);left:0;box-shadow:0 8px 24px #0000001f}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.attach-option{cursor:pointer;color:var(--black);text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.75rem;padding:.75rem 1rem;font-size:.9375rem;transition:all .2s;display:flex}.attach-option:hover{color:var(--whatsapp-green);background:linear-gradient(90deg,#25d3661a 0%,#25d3660d 100%)}.file-preview-container{border-bottom:1px solid var(--border);background:var(--light-gray);padding:1rem 1.5rem}.file-preview{max-width:300px;display:inline-block;position:relative}.preview-image{border-radius:8px;max-width:100%;max-height:200px;display:block}.preview-video{background:#000;border-radius:12px;width:100%;max-height:260px}.preview-audio{width:100%}.preview-audio-card{background:var(--white);border:1px solid var(--border);border-radius:12px;flex-direction:column;gap:.5rem;min-width:260px;padding:.75rem;display:flex}.preview-audio-info{color:var(--dark-gray);flex-direction:column;gap:.2rem;display:flex}.preview-audio-info span{color:var(--black);font-size:.9rem;font-weight:600}.preview-audio-info small{color:var(--gray);font-size:.75rem}.preview-document{background:var(--white);border:2px dashed var(--border);color:var(--dark-gray);border-radius:8px;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem;display:flex}.preview-document span{color:var(--black);font-weight:600}.preview-document small{color:var(--gray);font-size:.8125rem}.btn-remove-file{width:32px;height:32px;color:var(--white);cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;position:absolute;top:.5rem;right:.5rem}.btn-remove-file:hover{background:#000c}.chat-input textarea{border:1px solid var(--border);resize:none;scrollbar-gutter:stable both-edges;scrollbar-width:thin;scrollbar-color:#64748b99 transparent;background:#f7f8fa;border-radius:18px;flex:1;max-height:120px;padding:.9rem 1.1rem;font-size:.9375rem;line-height:1.4;transition:all .2s;overflow-y:auto}.chat-input textarea::-webkit-scrollbar{width:10px}.chat-input textarea::-webkit-scrollbar-button{width:0;height:0;display:none}.chat-input textarea::-webkit-scrollbar-track{background:0 0;margin:6px 0}.chat-input textarea::-webkit-scrollbar-thumb{background:#64748b8c;border:3px solid #f7f8fa;border-radius:999px}.chat-input textarea:hover::-webkit-scrollbar-thumb{background:#64748b99}.chat-input textarea:focus{background:var(--white);border-color:#25d366b3;outline:none;box-shadow:0 6px 20px #25d3661f}.chat-input textarea:disabled{opacity:.6;cursor:not-allowed}.btn-send{cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;box-shadow:0 2px 8px #25d36666;color:var(--white)!important;background:#25d366!important}.btn-send:disabled{opacity:.5;cursor:not-allowed;background:#25d366!important}.chat-empty{background:0 0;flex:1;justify-content:center;align-items:center;display:flex}.chat-empty-content{text-align:center;color:var(--gray);padding:2rem}.chat-empty-content h3{color:var(--black);margin:1rem 0 .5rem;font-size:1.5rem}.chat-empty-content p{color:var(--gray)}@media (width<=768px){.chat-sidebar{width:100%;display:none}.chat-sidebar.show{display:flex}.message-bubble{max-width:85%}}.bulk-sender{max-width:1600px;margin:0 auto}.bulk-content{flex-direction:column;gap:1.5rem;display:flex}.form-card,.contacts-card,.info-card{background:var(--white);box-shadow:var(--shadow-sm);border-radius:12px;overflow:hidden}.card-header{background:var(--light-gray);border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1.25rem 1.5rem;display:flex}.card-header h2{margin:0;font-size:1.25rem}.card-subtitle{color:var(--dark-gray);margin:1rem 1.5rem;font-size:.9rem}.header-actions{align-items:center;gap:.75rem;display:flex}.template-selector-inline{width:100%;position:relative}.dropdown-backdrop{z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0000004d;position:fixed;inset:0}.btn-template-large{background:var(--white);width:100%;color:var(--dark-gray);border:3px dashed var(--border);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;gap:.75rem;padding:1.25rem 2rem;font-size:1.125rem;font-weight:600;transition:all .3s;display:flex}.btn-template-large:hover{background:var(--light-gray);border-color:var(--whatsapp-green);box-shadow:var(--shadow-md);transform:translateY(-2px)}.btn-template-large.active{color:var(--black);border-color:var(--whatsapp-green);box-shadow:var(--shadow-md);background:#f2fff7;border-style:solid}.template-dropdown{background:var(--white);border:1px solid var(--border);z-index:1000;border-radius:16px;flex-direction:column;width:90%;max-width:500px;max-height:80vh;animation:.3s ease-out slideIn;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%);box-shadow:0 20px 60px #0000004d}@keyframes slideIn{0%{opacity:0;transform:translate(-100%)}to{opacity:1;transform:translate(0)}}.btn-template{background:var(--white);color:var(--dark-gray);border:2px solid var(--border);cursor:pointer;border-radius:8px;align-items:center;gap:.5rem;padding:.625rem 1rem;font-size:.9375rem;font-weight:500;transition:all .2s;display:flex}.btn-template:hover{background:var(--light-gray);border-color:var(--whatsapp-green)}.btn-template.active{background:var(--whatsapp-green);color:var(--white);border-color:var(--whatsapp-green)}.template-dropdown-header{background:var(--whatsapp-green);color:var(--white);border-bottom:1px solid #fff3;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.template-dropdown-header h3{margin:0;font-size:1.125rem;font-weight:600}.template-dropdown-header button{color:var(--white);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:1.5rem;transition:background .2s;display:flex}.template-dropdown-header button:hover{background:#fff3}.template-dropdown-list{max-height:340px;overflow-y:auto}.template-item{border-bottom:1px solid var(--border);cursor:pointer;padding:1rem 1.25rem;transition:all .2s}.template-item:hover{background:var(--light-gray)}.template-item.selected{border-left:4px solid var(--whatsapp-green);background:#e6f7ed}.template-preview{color:#475569;text-overflow:ellipsis;max-height:3.6rem;margin-top:.5rem;font-size:.875rem;line-height:1.4;overflow:hidden}.template-params-pills{flex-wrap:wrap;gap:.35rem;margin-top:.5rem;display:flex}.param-pill{color:#0f172a;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:999px;padding:.15rem .55rem;font-size:.72rem;font-weight:600}.template-item-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.template-name{color:var(--black);font-size:.9375rem;font-weight:600}.template-category,.template-language{color:var(--dark-gray);margin-top:.25rem;font-size:.8125rem}.template-category{background:var(--light-gray);border-radius:4px;margin-right:.5rem;padding:.25rem .625rem;display:inline-block}.no-templates{text-align:center;color:var(--dark-gray);padding:2rem}.format-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin:1rem 0;display:grid}.format-item{background:var(--light-gray);border-left:3px solid var(--whatsapp-green);border-radius:8px;padding:1rem}.format-item strong{color:var(--black);margin-bottom:.5rem;display:block}.format-item pre,.format-item p{color:var(--dark-gray);margin:.5rem 0 0;font-size:.8125rem}.template-selection-section{padding:1.5rem}.template-info-box{border:2px solid var(--whatsapp-green);background:linear-gradient(135deg,#e6f7ed 0%,#f0f9f4 100%);border-radius:12px;margin-top:1.5rem;padding:1.5rem;animation:.4s ease-out fadeIn}.template-summary-header{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.template-name{color:var(--dark-gray);margin-top:.25rem;font-size:1rem}.template-summary-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem;margin-bottom:1rem;display:grid}.template-summary-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:.9rem 1rem}.template-summary-card h5{color:var(--black);margin:0 0 .5rem;font-size:.9rem}.template-summary-card p{color:var(--dark-gray);margin:0;font-size:.9rem;line-height:1.4}.template-summary-card pre{white-space:pre-wrap;color:var(--black);margin:0;font-family:inherit;font-size:.9rem;line-height:1.4}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.template-info-box h4{color:var(--whatsapp-green);align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1.125rem;display:flex}.template-details{gap:.5rem;margin-bottom:1rem;display:flex}.badge{background:var(--white);border:1px solid var(--whatsapp-green);color:var(--whatsapp-green);border-radius:20px;padding:.375rem .75rem;font-size:.8125rem;font-weight:600;display:inline-block}.template-params-info{border-top:2px dashed #25d3664d;margin-top:1rem;padding-top:1rem}.template-params-info h5{color:var(--black);margin:0 0 .75rem;font-size:1rem}.params-list{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-bottom:1rem;display:grid}.param-box{background:var(--white);border-left:3px solid var(--whatsapp-green);border-radius:6px;padding:.75rem 1rem;font-size:.875rem;box-shadow:0 2px 4px #0000000d}.param-box strong{color:var(--whatsapp-green);font-weight:700}.param-example{color:var(--gray);margin-top:.25rem;font-size:.75rem;font-style:italic;font-weight:400;display:block}.info-text{color:var(--dark-gray);background:#ffffffb3;border-radius:6px;margin:0;padding:.75rem 1rem;font-size:.875rem;font-weight:500}.btn-secondary.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.template-badge{background:var(--primary-light);color:var(--primary-dark);border-radius:6px;padding:.375rem .75rem;font-size:.875rem;font-weight:600}.form-grid{grid-template-columns:1.5fr 1.5fr 1fr auto;gap:1rem;padding:1.5rem;display:grid}.form-input{border:2px solid var(--border);border-radius:8px;padding:.875rem 1rem;font-size:.9375rem;transition:all .2s}.form-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #25d3661a}.btn-primary,.btn-secondary{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.875rem 1.25rem;font-size:.9375rem;font-weight:600;transition:all .2s;display:flex}.btn-primary{background:var(--primary);color:var(--white)}.btn-primary:hover{background:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-secondary{background:var(--secondary);color:var(--white)}.btn-secondary:hover{background:var(--secondary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.template-params-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;padding:1.5rem;display:grid}.param-field label{color:var(--dark-gray);margin-bottom:.5rem;font-size:.875rem;font-weight:500;display:block}.param-hint{color:var(--gray);padding:0 1.5rem 1.5rem;font-size:.8125rem;line-height:1.5;display:block}.warning-banner{color:#856404;background:#fff3cd;border:1px solid #ffe69c;align-items:center;gap:.75rem;padding:1rem 1.5rem;font-size:.875rem;font-weight:500;display:flex}.info-banner{color:#1d4ed8;background:#eef6ff;border:1px solid #cfe4ff;align-items:center;gap:.75rem;padding:1rem 1.5rem;font-size:.875rem;font-weight:500;display:flex}.info-banner-error{color:#b42318;background:#fff1f1;border-color:#fecaca}.info-banner-details{margin-top:.35rem;font-size:.8125rem;font-weight:400}.info-banner-details div{margin-top:.2rem}.table-wrapper{overflow-x:auto}.empty-contacts{text-align:center;color:var(--gray);flex-direction:column;justify-content:center;align-items:center;padding:3rem;display:flex}.empty-contacts p{color:var(--dark-gray);margin:1rem 0 .5rem;font-size:1.125rem;font-weight:500}.empty-contacts small{font-size:.875rem}.contacts-table{border-collapse:collapse;width:100%}.contacts-table thead{background:var(--light-gray)}.contacts-table th{text-align:left;color:var(--dark-gray);text-transform:uppercase;letter-spacing:.5px;padding:1rem 1.5rem;font-size:.875rem;font-weight:600}.contacts-table tbody tr{border-bottom:1px solid var(--border);transition:background .2s}.contacts-table tbody tr:hover{background:var(--light-gray)}.contacts-table tbody tr:last-child{border-bottom:none}.contacts-table td{color:var(--black);padding:1rem 1.5rem}.phone-cell{color:var(--dark-gray);font-family:Courier New,monospace}.text-muted{color:var(--gray);font-style:italic}.required-cell{background:#fff1f1}.required-text{color:#b42318;font-weight:600}.btn-delete{cursor:pointer;color:var(--error);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:.5rem;transition:all .2s;display:flex}.btn-delete:hover{background:#dc35451a}.btn-send-bulk{background:var(--primary);color:var(--white);cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-weight:600;transition:all .2s;display:flex}.btn-send-bulk:hover:not(:disabled){background:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-send-bulk:disabled{opacity:.6;cursor:not-allowed}.header-media-upload{border:1px dashed var(--border);background:#f8fafc;border-radius:10px;margin:1rem 1.5rem 0;padding:1rem}.header-media-title{color:var(--dark-gray);margin-bottom:.75rem;font-weight:600}.header-media-actions{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.header-media-meta{color:var(--dark-gray);word-break:break-all;margin-top:.75rem;font-size:.875rem}.header-media-label{margin-right:.5rem;font-weight:600}.header-media-preview{object-fit:cover;border:1px solid var(--border);border-radius:8px;width:auto;max-width:220px;height:auto;max-height:140px;margin-top:.75rem}.info-card{padding:1.5rem}.info-card p{color:var(--dark-gray);margin:0 0 .75rem}.info-card pre{background:var(--light-gray);color:var(--black);border-radius:8px;margin:.75rem 0;padding:1rem;font-size:.875rem;overflow-x:auto}.info-card small{color:var(--gray);margin-top:.75rem;line-height:1.5;display:block}@media (width<=768px){.form-grid{grid-template-columns:1fr}.card-header{flex-direction:column;align-items:flex-start;gap:1rem}.template-params-grid{grid-template-columns:1fr}.contacts-table{font-size:.875rem}.contacts-table th,.contacts-table td{padding:.75rem 1rem}}.template-manager{max-width:1400px;margin:0 auto}.page-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.page-header h1{color:var(--black);margin:0 0 .5rem;font-size:2rem}.page-header p{color:var(--dark-gray);margin:0}.btn-refresh{background:var(--primary);color:var(--white);cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-weight:600;transition:all .2s;display:flex}.btn-refresh:hover:not(:disabled){background:var(--primary-dark);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.btn-refresh:disabled{opacity:.6;cursor:not-allowed}.templates-loading,.templates-empty{text-align:center;min-height:400px;color:var(--gray);flex-direction:column;justify-content:center;align-items:center;display:flex}.templates-empty h2{color:var(--dark-gray);margin:1rem 0 .5rem}.templates-empty p{margin-bottom:1.5rem}.btn-external{background:var(--secondary);color:var(--white);border-radius:8px;align-items:center;gap:.5rem;padding:.875rem 1.5rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex}.btn-external:hover{background:var(--secondary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.templates-stats{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem;display:grid}.stat-item{background:var(--white);box-shadow:var(--shadow-sm);text-align:center;border-radius:12px;padding:1.5rem}.stat-value{color:var(--primary);margin-bottom:.5rem;font-size:2rem;font-weight:700;display:block}.stat-label{color:var(--dark-gray);text-transform:uppercase;letter-spacing:.5px;font-size:.875rem;display:block}.templates-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.template-card{background:var(--white);box-shadow:var(--shadow-sm);border:1px solid var(--border);border-radius:12px;transition:all .2s;overflow:hidden}.template-card:hover{box-shadow:var(--shadow-md);transform:translateY(-4px)}.template-card-header{background:var(--light-gray);border-bottom:1px solid var(--border);padding:1.25rem}.template-card-header h3{color:var(--black);margin:0 0 .75rem;font-size:1.125rem}.template-badges{flex-wrap:wrap;gap:.5rem;display:flex}.badge{text-transform:uppercase;letter-spacing:.5px;border-radius:6px;padding:.375rem .75rem;font-size:.75rem;font-weight:600}.template-meta{border-bottom:1px solid var(--border);flex-direction:column;gap:.5rem;padding:1rem 1.25rem;display:flex}.meta-item{justify-content:space-between;font-size:.875rem;display:flex}.meta-label{color:var(--gray);font-weight:500}.meta-value{color:var(--black)}.template-id{font-family:Courier New,monospace;font-size:.8125rem}.template-preview{border-bottom:1px solid var(--border);padding:1.25rem}.preview-label{color:var(--gray);margin-bottom:.75rem;font-size:.875rem;font-weight:600}.preview-content{background:var(--light-gray);color:var(--black);white-space:pre-wrap;border-radius:8px;padding:1rem;font-size:.9375rem;line-height:1.6}.template-components{padding:1rem 1.25rem}.components-label{color:var(--gray);margin-bottom:.75rem;font-size:.875rem;font-weight:600}.components-list{flex-wrap:wrap;gap:.5rem;display:flex}.component-tag{background:var(--accent);color:var(--white);border-radius:6px;padding:.375rem .75rem;font-size:.75rem;font-weight:600}.info-card{background:var(--white);box-shadow:var(--shadow-sm);border-radius:12px;padding:1.5rem}.info-card h3{color:var(--secondary-dark);margin:0 0 1rem}.info-card ul{color:var(--dark-gray);margin:0;padding-left:1.5rem;line-height:1.8}.info-card li{margin-bottom:.5rem}.info-card strong{color:var(--black)}@media (width<=768px){.templates-grid{grid-template-columns:1fr}.templates-stats{grid-template-columns:repeat(2,1fr)}.page-header{flex-direction:column;align-items:flex-start;gap:1rem}}.cost-analyzer{max-width:1400px;margin:0 auto;padding:2rem}.loading-container{flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:400px;display:flex}.analyzer-header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.analyzer-header h1{color:var(--black);margin:0 0 .5rem;font-size:2rem}.analyzer-header p{color:var(--gray);margin:0;font-size:1rem}.btn-export{background:var(--whatsapp-green);color:var(--white);cursor:pointer;z-index:1;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.875rem 1.75rem;font-size:.9375rem;font-weight:600;transition:all .2s;display:flex;box-shadow:0 2px 8px #25d3664d}.btn-export:hover{background:#20ba5f;transform:translateY(-2px);box-shadow:0 4px 12px #25d36666}.date-filter-card{background:var(--white);border:1px solid var(--border);border-radius:12px;margin-bottom:2rem;padding:2rem;box-shadow:0 2px 12px #00000014}.filter-inputs{flex-wrap:wrap;align-items:flex-end;gap:1.5rem;display:flex}.input-group{flex:1;min-width:220px;max-width:300px}.input-group label{color:var(--dark-gray);align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:flex}.input-group input[type=date]{border:2px solid var(--border);border-radius:8px;width:100%;padding:.75rem;font-size:.9375rem;transition:all .2s}.input-group input[type=date]:focus{border-color:var(--whatsapp-green);outline:none;box-shadow:0 0 0 3px #25d3661a}.filter-actions{align-items:center;gap:.75rem;display:flex}.btn-filter,.btn-clear{cursor:pointer;white-space:nowrap;z-index:1;border:none;border-radius:8px;padding:.875rem 1.75rem;font-size:.9375rem;font-weight:600;transition:all .2s}.btn-filter{background:var(--whatsapp-green);color:var(--black);box-shadow:0 3px 10px #25d36659}.btn-filter:hover{color:var(--white);background:#20ba5f;transform:translateY(-2px);box-shadow:0 5px 15px #25d36673}.btn-clear{background:var(--light-gray);color:var(--dark-gray);box-shadow:0 2px 4px #00000014}.btn-clear:hover{background:var(--border);box-shadow:0 3px 8px #0000001f}.overview-cards{grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--white);border-radius:12px;gap:1rem;padding:1.5rem;transition:all .2s;display:flex;box-shadow:0 2px 8px #0000001a}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000026}.stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.stat-card.primary .stat-icon{color:var(--white);background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.stat-card.success .stat-icon{background:linear-gradient(135deg, var(--whatsapp-green) 0%, #20ba5f 100%);color:var(--white)}.stat-card.info .stat-icon{color:var(--white);background:linear-gradient(135deg,#4fc3f7 0%,#29b6f6 100%)}.stat-card.warning .stat-icon{color:var(--white);background:linear-gradient(135deg,#ffb74d 0%,#ffa726 100%)}.stat-content{flex:1}.stat-label{color:var(--gray);margin-bottom:.5rem;font-size:.875rem}.stat-value{color:var(--black);margin-bottom:.25rem;font-size:1.75rem;font-weight:700}.stat-change{color:var(--gray);font-size:.8125rem}.breakdown-section,.timeline-section,.pricing-info-section{background:var(--white);border-radius:12px;margin-bottom:2rem;padding:2rem;box-shadow:0 2px 8px #0000001a}.breakdown-section h2,.timeline-section h2,.pricing-info-section h2{color:var(--black);margin:0 0 1.5rem;font-size:1.5rem}.breakdown-cards{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;display:grid}.breakdown-card{border-left:4px solid var(--whatsapp-green);background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border-radius:12px;padding:1.5rem}.breakdown-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.type-badge{background:var(--whatsapp-green);color:var(--white);text-transform:capitalize;border-radius:20px;padding:.375rem .75rem;font-size:.8125rem;font-weight:600}.type-count{color:var(--gray);font-size:.875rem}.breakdown-cost{color:var(--black);margin-bottom:.75rem;font-size:2rem;font-weight:700}.pricing-type-chips{flex-wrap:wrap;gap:.5rem;margin:.75rem 0 1rem;display:flex}.pricing-type-chip{color:var(--dark-gray);background:#25d3661f;border-radius:999px;padding:.375rem .625rem;font-size:.75rem;font-weight:600}.breakdown-bar{background:#dee2e6;border-radius:4px;width:100%;height:8px;overflow:hidden}.breakdown-bar-fill{background:linear-gradient(90deg, var(--whatsapp-green) 0%, #20ba5f 100%);height:100%;transition:width .5s}.timeline-table{overflow-x:auto}.timeline-table table{border-collapse:collapse;width:100%}.timeline-table thead{background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%)}.timeline-table th{text-align:left;color:var(--dark-gray);border-bottom:2px solid var(--border);padding:1rem;font-weight:600}.timeline-table td{border-bottom:1px solid var(--border);padding:1rem}.timeline-table tbody tr:hover{background:#25d3660d}.date-cell{color:var(--black);font-weight:600}.count-cell{color:var(--dark-gray)}.cost-cell{color:var(--whatsapp-green);font-size:1.125rem;font-weight:700}.status-badge{border-radius:20px;padding:.375rem .75rem;font-size:.8125rem;font-weight:600}.status-badge.success{color:var(--whatsapp-green);background:#25d36626}.pricing-source-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem;margin-bottom:1.25rem;display:grid}.pricing-source-item{border:1px solid var(--border);background:linear-gradient(135deg,#f8f9fa 0%,#fff 100%);border-radius:8px;padding:1rem}.pricing-source-item.wide{grid-column:span 2}.pricing-source-item span{color:var(--gray);text-transform:uppercase;letter-spacing:0;margin-bottom:.375rem;font-size:.75rem;font-weight:700;display:block}.pricing-source-item strong{color:var(--black);overflow-wrap:anywhere;font-size:.9375rem;font-weight:700}.pricing-note{color:var(--gray);text-align:center;margin:0;font-size:.875rem;font-style:italic}@media (width<=768px){.cost-analyzer{padding:1rem}.analyzer-header{flex-direction:column;align-items:flex-start;gap:1rem}.filter-inputs{flex-direction:column;width:100%}.input-group{width:100%;max-width:100%}.filter-actions{flex-direction:column;width:100%}.btn-filter,.btn-clear{flex:1;justify-content:center;width:100%}.pricing-source-item.wide{grid-column:span 1}}.navbar{background:var(--white);border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);z-index:100;position:sticky;top:0}.navbar-container{justify-content:space-between;align-items:center;max-width:100%;padding:.75rem 1.5rem;display:flex}.navbar-brand{color:var(--primary);align-items:center;gap:.75rem;font-size:1.25rem;font-weight:600;text-decoration:none;transition:opacity .2s;display:flex}.brand-logo-text{background:linear-gradient(135deg, var(--whatsapp-green) 0%, #20ba5f 100%);width:44px;height:44px;color:var(--white);letter-spacing:.5px;border-radius:8px;justify-content:center;align-items:center;font-size:1.125rem;font-weight:700;display:flex;box-shadow:0 2px 8px #25d3664d}.navbar-brand:hover{opacity:.8}.navbar-brand span{color:var(--black)}.navbar-menu{flex:1;justify-content:center;align-items:center;gap:.5rem;display:flex}.nav-link{color:var(--dark-gray);border-radius:8px;align-items:center;gap:.5rem;padding:.625rem 1rem;font-size:.9375rem;font-weight:500;text-decoration:none;transition:all .2s;display:flex;position:relative}.nav-link-label{align-items:center;display:inline-flex}.nav-unread-badge{color:#fff;background:#ef4444;border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:20px;padding:0 .35rem;font-size:.72rem;font-weight:700;line-height:1;display:inline-flex}.nav-link:hover{background:var(--light-gray);color:var(--black)}.nav-link.active{background:var(--primary-light);color:var(--primary-dark)}.nav-link.active:after{content:"";background:var(--primary);border-radius:3px 3px 0 0;width:80%;height:3px;position:absolute;bottom:-.75rem;left:50%;transform:translate(-50%)}.navbar-actions{align-items:center;gap:1rem;display:flex}.user-info{background:var(--light-gray);border-radius:8px;align-items:center;padding:.5rem 1rem;display:flex}.user-email{color:var(--dark-gray);font-size:.875rem;font-weight:500}.btn-logout{background:var(--error);color:var(--white);cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.625rem 1rem;font-size:.9375rem;font-weight:500;transition:all .2s;display:flex}.btn-logout:hover{box-shadow:var(--shadow-sm);background:#c82333;transform:translateY(-1px)}.btn-logout:active{transform:translateY(0)}@media (width<=768px){.navbar-container{flex-wrap:wrap;padding:.75rem 1rem}.navbar-brand span{display:none}.navbar-menu{order:3;justify-content:flex-start;gap:.25rem;width:100%;margin-top:.75rem;overflow-x:auto}.nav-link-label{display:none}.nav-link{padding:.5rem}.user-email{text-overflow:ellipsis;white-space:nowrap;max-width:120px;overflow:hidden}.btn-logout span{display:none}}.layout{background:var(--light-gray);flex-direction:column;height:100vh;display:flex}.layout-content{flex:1;display:flex;overflow:hidden}.main-content{flex:1;padding:1.5rem;animation:.3s ease-out fadeIn;overflow-y:auto}@media (width<=1024px){.layout-content{flex-direction:column}.main-content{padding:1rem}}.spinner{border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}.spinner-sm{border-width:2px;width:20px;height:20px}#root{background:var(--light-gray);min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#25d366;--primary-dark:#20ba5a;--primary-light:#dcf8c6;--secondary:#128c7e;--secondary-dark:#075e54;--accent:#34b7f1;--white:#fff;--light-gray:#f0f2f5;--gray:#8696a0;--dark-gray:#667781;--black:#111b21;--sent-message:#d9fdd3;--received-message:#fff;--border:#e9edef;--success:#25d366;--error:#dc3545;--warning:orange;--info:#34b7f1;--shadow-sm:0 1px 3px #00000014;--shadow-md:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #0000001f}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--light-gray);color:var(--black);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6;overflow:hidden auto}#root{min-height:100vh;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--gray);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--dark-gray)}@keyframes spin{to{transform:rotate(360deg)}}.animate-fadeIn{animation:.3s ease-out fadeIn}.animate-slideIn{animation:.3s ease-out slideIn}.text-center{text-align:center}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.w-full{width:100%}.h-full{height:100%}.rounded{border-radius:.375rem}.shadow{box-shadow:var(--shadow-md)}.transition{transition:all .2s}
