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