.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--secondary-dark) 0%,var(--secondary) 100%);padding:1rem}.login-card{width:100%;max-width:420px;background:var(--white);border-radius:16px;box-shadow:0 20px 60px #0000004d;overflow:hidden;animation:fadeIn .5s ease-out}.login-header{text-align:center;padding:2.5rem 2rem 1.5rem;background:linear-gradient(to bottom,var(--light-gray),var(--white))}.login-icon{width:80px;height:80px;margin:0 auto 1rem;background:var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-md)}.login-header h1{margin:0 0 .5rem;font-size:1.75rem;color:var(--black)}.login-header p{margin:0;color:var(--dark-gray);font-size:.9375rem}.login-form{padding:2rem}.form-group{margin-bottom:1.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-weight:500;color:var(--black);font-size:.9375rem}.form-group input{width:100%;padding:.875rem 1rem;border:2px solid var(--border);border-radius:8px;font-size:1rem;transition:all .2s;background:var(--white);color:var(--black)}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #25d3661a}.form-group input::placeholder{color:var(--gray)}.btn-login{width:100%;padding:1rem;background:var(--primary);color:var(--white);border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .2s}.btn-login:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{opacity:.7;cursor:not-allowed}.login-footer{padding:1.5rem 2rem;background:var(--light-gray);text-align:center;border-top:1px solid var(--border)}.login-footer p{margin:0;color:var(--dark-gray);font-size:.875rem}@media (max-width: 480px){.login-card{border-radius:0}.login-header{padding:2rem 1.5rem 1rem}.login-form{padding:1.5rem}.login-footer{padding:1rem 1.5rem}}.dashboard{max-width:1400px;margin:0 auto}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:2rem;margin:0 0 .5rem;color:var(--black)}.dashboard-header p{margin:0;color:var(--dark-gray);font-size:1rem}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:1rem}.dashboard-loading p{color:var(--gray)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:var(--white);padding:1.5rem;border-radius:12px;box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:1rem;transition:all .2s}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.stat-icon{width:60px;height:60px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-value{font-size:1.75rem;font-weight:700;color:var(--black);line-height:1.2}.stat-label{font-size:.875rem;color:var(--dark-gray);margin-top:.25rem}.recent-conversations{background:var(--white);border-radius:12px;box-shadow:var(--shadow-sm);overflow:hidden}.section-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;background:var(--light-gray);border-bottom:1px solid var(--border)}.section-header h2{margin:0;font-size:1.25rem;color:var(--black)}.table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse}.data-table thead{background:var(--light-gray)}.data-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}.data-table tbody tr{border-bottom:1px solid var(--border);transition:background .2s}.data-table tbody tr:hover{background:var(--light-gray)}.data-table tbody tr:last-child{border-bottom:none}.data-table td{padding:1rem 1.5rem;color:var(--black)}.user-name-cell{display:flex;align-items:center;gap:.75rem}.user-avatar{width:36px;height:36px;border-radius:50%;background:var(--primary);color:var(--white);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem}.discipline-badge{display:inline-block;padding:.375rem .75rem;background:var(--primary-light);color:var(--primary-dark);border-radius:6px;font-size:.8125rem;font-weight:500}.text-muted{color:var(--gray)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:var(--gray)}.empty-state p{margin:1rem 0 .5rem;font-size:1.125rem;font-weight:500;color:var(--dark-gray)}.empty-state small{font-size:.875rem}@media (max-width: 768px){.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1.25rem}.data-table{font-size:.875rem}.data-table th,.data-table td{padding:.75rem 1rem}.user-avatar{width:32px;height:32px;font-size:.75rem}}.chat-inbox{display:flex;height:calc(100vh - 120px);background:var(--white);border-radius:16px;overflow:hidden;box-shadow:0 10px 40px #0000001a;position:relative;max-height:calc(100vh - 120px)}.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}.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:1rem 1.5rem;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,.05) 0%,transparent 100%)}.user-item:hover:before{width:4px}.user-item.active{background:linear-gradient(90deg,#25d36626,#25d3660d)}.user-item.active:before{width:4px}.user-avatar{width:52px;height:52px;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.25rem;flex-shrink:0;box-shadow:0 3px 10px #25d36640;text-transform:uppercase;border:3px solid var(--white)}.user-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.25rem}.user-name{font-weight:600;color:var(--black);font-size:1rem;line-height:1.3}.user-last-message{font-size:.875rem;color:var(--gray);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:220px;font-weight:400;line-height:1.3}.user-time{font-size:.75rem;color:var(--gray);align-self:flex-start;margin-top:.25rem;font-weight:500}.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-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}.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:65%;padding:.625rem 1rem;border-radius:8px;box-shadow:0 2px 4px #00000014;position:relative}.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;line-height:1.5;font-size:.9375rem;font-weight:400}.message-image{margin-bottom:.5rem;border-radius:8px;overflow:hidden;position:relative;max-width:300px;background:#00000005}.message-image img{width:100%;height:auto;max-height:400px;object-fit:contain;display:block;border-radius:8px;cursor:pointer}.image-error{padding:2rem;text-align:center;color:var(--gray);font-size:.875rem}.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-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:hover .message-actions{opacity:1}.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-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)}.template-params-container{padding:1rem 1.5rem;border-bottom:1px solid var(--border);background:var(--primary-light)}.template-selected-info{font-size:.875rem;color:var(--primary-dark);font-weight:600;margin-bottom:.75rem}.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)}.chat-input{padding:1rem 1.5rem;display:flex;gap:.75rem;align-items:center;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-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 input{flex:1;padding:.875rem 1rem;border:1px solid transparent;border-radius:24px;font-size:.9375rem;background:#f0f2f5;transition:all .2s}.chat-input input:focus{outline:none;background:var(--white);border-color:var(--whatsapp-green);box-shadow:0 0 0 3px #25d3661a}.chat-input input: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:1200px;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}.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:var(--whatsapp-green);color:var(--white);border-color:var(--whatsapp-green);border-style:solid}.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-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-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}.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}color: var(--black); } .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}.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}.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}.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(--white);box-shadow:0 3px 10px #25d36659}.btn-filter:hover{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{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: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 span{display:none}.nav-link{padding:.5rem}.user-email{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-logout span{display:none}}.template-selector{width:360px;height:calc(100vh - 60px);background:linear-gradient(180deg,#fff,#f8f9fa);border-left:1px solid var(--border);display:flex;flex-direction:column;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:-2px 0 12px #00000014}.template-selector.collapsed{width:0}.toggle-btn{position:absolute;top:1.5rem;left:-18px;width:36px;height:36px;background:linear-gradient(135deg,var(--whatsapp-green) 0%,#20ba5f 100%);border:2px solid var(--white);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:1000;transition:all .3s ease;box-shadow:0 4px 12px #25d36666,0 0 0 4px #25d3661a;color:var(--white)}.toggle-btn:hover{background:linear-gradient(135deg,#20ba5f 0%,var(--whatsapp-green) 100%);transform:scale(1.15);box-shadow:0 6px 16px #25d36680,0 0 0 6px #25d36626}.template-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem 1.25rem;border-bottom:none;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 8px #667eea33}.template-header-title{display:flex;align-items:center;gap:.75rem;color:var(--white)}.template-header-title h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--white);letter-spacing:.3px}.btn-icon{background:#fff3;border:none;padding:.5rem;cursor:pointer;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s;color:var(--white)}.btn-icon:hover{background:#ffffff4d;transform:scale(1.05)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.spinning{animation:spin 1s linear infinite}.template-list{flex:1;overflow-y:auto;padding:.75rem}.template-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;gap:1rem;color:var(--gray)}.template-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center;color:var(--gray);gap:.5rem}.template-empty p{margin:.5rem 0 .25rem;font-weight:500;color:var(--dark-gray)}.template-empty small{font-size:.8125rem;color:var(--gray)}.template-item{padding:1rem;margin-bottom:.75rem;border:1px solid transparent;border-radius:12px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);background:var(--white);box-shadow:0 2px 6px #0000000f}.template-item:hover{border-color:var(--whatsapp-green);background:linear-gradient(135deg,#25d36614,#25d36605);transform:translateY(-2px);box-shadow:0 6px 16px #25d36626}.template-item.selected{border-color:var(--whatsapp-green);background:linear-gradient(135deg,#25d3661f,#25d3660a);box-shadow:0 0 0 3px #25d36626,0 4px 12px #25d36633}.template-item-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.template-name{font-weight:600;font-size:.9375rem;color:var(--black)}.template-meta{display:flex;gap:.5rem;margin-bottom:.5rem}.template-category,.template-language{font-size:.75rem;padding:.25rem .5rem;border-radius:4px;background:var(--light-gray);color:var(--dark-gray);font-weight:500;text-transform:uppercase}.template-preview{font-size:.8125rem;color:var(--gray);line-height:1.4;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border)}@media (max-width: 1024px){.template-selector{position:fixed;right:0;top:60px;z-index:50;box-shadow:var(--shadow-lg)}.template-selector.collapsed{right:-320px}.toggle-btn{left:-40px}}.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}
