.layout{display:flex;min-height:100vh}.sidebar{position:fixed;top:0;left:0;bottom:0;width:72px;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;z-index:50;transition:width .25s cubic-bezier(.4,0,.2,1);overflow:hidden}.layout.sidebar-expanded .sidebar{width:260px;overflow:visible}.main{margin-left:72px;transition:margin-left .25s cubic-bezier(.4,0,.2,1)}.layout.sidebar-expanded .main{margin-left:260px}.sidebar .sidebar-search{flex-shrink:0;padding:1rem;position:relative;min-height:48px;border-bottom:1px solid var(--border);display:flex!important;align-items:center;justify-content:center;overflow:hidden;box-sizing:border-box}.layout.sidebar-expanded .sidebar .sidebar-search{padding:1rem;justify-content:flex-start}.sidebar .sidebar-search{position:relative}.sidebar .sidebar-search-icon{flex-shrink:0;color:var(--text);transition:opacity .2s}.sidebar .sidebar-search-input{position:absolute;left:0;top:0;width:0;max-width:0;padding:0;margin:0;border:none;opacity:0;overflow:hidden;pointer-events:none;transition:opacity .2s}.layout.sidebar-expanded .sidebar .sidebar-search-icon{display:none}.layout.sidebar-expanded .sidebar .sidebar-search-input{position:relative;left:auto;top:auto;flex:1;min-width:0;width:100%;max-width:none;padding:.75rem 1rem;margin:0;border:1px solid var(--border);border-radius:999px;background:#ffffffe6;color:var(--text);font-size:.9rem;text-align:left;opacity:1;overflow:visible;pointer-events:auto;box-sizing:border-box;transition:border-color .2s,box-shadow .2s,background .2s}.layout.sidebar-expanded .sidebar .sidebar-search-input:hover{border-color:#8b5cb859;background:#fff}.layout.sidebar-expanded .sidebar .sidebar-search-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #8b5cb81f;background:#fff}.sidebar-search-input::placeholder{color:var(--text-muted)}.sidebar-search-empty{padding:1rem;text-align:center;color:var(--text-muted);font-size:.9rem}.layout:not(.sidebar-expanded) .sidebar-search-empty{display:none}.sidebar-brand{padding:1.5rem;display:flex;align-items:center;gap:.75rem;font-weight:600;font-size:1.1rem;color:var(--accent)}.sidebar-brand svg{flex-shrink:0}.sidebar-nav{flex:1;padding:.5rem;display:flex;flex-direction:column;align-items:center;gap:.25rem;overflow-y:auto;overflow-x:hidden;min-height:0;scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none}.layout.sidebar-expanded .sidebar-nav{padding:1rem .75rem;align-items:stretch}.nav-link{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.75rem;border-radius:8px;color:var(--text-muted);transition:all .15s;text-decoration:none;width:100%;box-sizing:border-box}.layout.sidebar-expanded .nav-link{justify-content:flex-start;padding:.75rem 1rem}.layout:not(.sidebar-expanded) .nav-link,.layout:not(.sidebar-expanded) .nav-link--parent{justify-content:center;min-width:0}.layout:not(.sidebar-expanded) .nav-dropdown{display:flex;justify-content:center;width:100%}.nav-link span{white-space:nowrap;overflow:hidden}.layout:not(.sidebar-expanded) .nav-link span,.layout:not(.sidebar-expanded) .nav-dropdown-chevron{display:none!important}.nav-link:hover{background:var(--bg-hover);color:var(--text);text-decoration:none}.nav-link.active{background:var(--accent-bg);color:var(--accent);text-decoration:none}.sidebar-nav a:hover,.sidebar-nav a.nav-link:hover,.sidebar-nav button.nav-link:hover{text-decoration:none!important}.nav-dropdown{position:relative}.nav-link--parent{cursor:default;justify-content:flex-start}.nav-link--parent .nav-dropdown-chevron{margin-left:auto;opacity:.6;transition:transform .25s cubic-bezier(.4,0,.2,1)}.nav-dropdown:hover .nav-dropdown-chevron{transform:rotate(180deg)}.nav-dropdown-content{position:absolute;top:100%;left:0;right:0;margin-top:0;padding:.5rem;max-height:320px;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--border) transparent;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;box-shadow:0 4px 6px -1px #8b5cb814,0 10px 20px -5px #8b5cb81a,0 0 0 1px #8b5cb80a;flex-direction:column;gap:0;z-index:100;display:flex;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-4px);transition:opacity .2s ease,transform .2s cubic-bezier(.4,0,.2,1)}.layout:not(.sidebar-expanded) .nav-dropdown-content{display:none!important}.nav-dropdown-content:before{content:"";position:absolute;top:-5px;left:1.25rem;border-left:5px solid transparent;border-right:5px solid transparent;border-bottom:5px solid var(--bg-card)}.nav-dropdown-content:after{content:"";position:absolute;top:-6px;left:calc(1.25rem - 1px);border-left:6px solid transparent;border-right:6px solid transparent;border-bottom:6px solid var(--border);z-index:-1}.nav-dropdown:hover .nav-dropdown-content{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}.nav-link--nested{padding:.5rem;margin-bottom:2px;font-size:.9rem;font-weight:500;border-radius:8px;transition:background .15s ease,color .15s ease}.nav-link--nested:last-child{margin-bottom:0}.nav-link--nested:hover{background:var(--bg-hover)}.nav-link--nested.active{background:var(--accent-bg);color:var(--accent)}.nav-link--nested svg{width:18px;height:18px;flex-shrink:0;opacity:.85}.nav-link--nested.active svg{opacity:1}.nav-dropdown-content::-webkit-scrollbar{width:6px}.nav-dropdown-content::-webkit-scrollbar-track{background:transparent}.nav-dropdown-content::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.nav-dropdown-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.nav-link--logout{width:100%;text-align:left;background:none;border:none;cursor:pointer;font-family:inherit;font-size:inherit;color:var(--danger)}.nav-link--logout:hover{background:#dc26261f;color:var(--danger)}.sidebar-footer{flex-shrink:0;padding:.75rem;border-top:1px solid var(--border);display:flex;flex-direction:column;align-items:center}.layout.sidebar-expanded .sidebar-footer{padding:1rem}.sidebar-logo{display:flex;justify-content:center;align-items:center}.sidebar-logo img{height:24px;width:auto;opacity:.9;transition:height .2s}.layout.sidebar-expanded .sidebar-logo img{height:48px}.main{flex:1;padding:1.5rem;overflow-y:auto;min-height:100vh}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#fff;color:#4a4568}:root{color-scheme:light;--bg-dark: #ffffff;--bg-card: #ffffff;--bg-hover: #ede5f5;--border: #ddd0e8;--text: #020356;--text-muted: #4a4568;--accent: #8b5cb8;--accent-dim: #7c4aad;--accent-bg: rgba(139, 92, 184, .2);--primary: #020356;--danger: #dc2626;--success: #020356;--warning: #f59e0b}*{box-sizing:border-box}body{margin:0;font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;background:#fff!important;color:#020356!important;min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.page{max-width:100%;width:100%}.coming-soon{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center;padding:2rem}.coming-soon h1{margin:0 0 .5rem;font-size:1.75rem;color:var(--text)}.coming-soon p{margin:0;color:var(--text-muted);font-size:1rem}.page-header{margin-bottom:2rem}.page-header h1{margin:0 0 .25rem;font-size:1.75rem}.page-subtitle{margin:0;color:var(--text-muted);font-size:.95rem}.flex-between{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:1rem}.flex{display:flex;align-items:center}.flex-wrap{flex-wrap:wrap}.gap-2{gap:.5rem}.gap-1{gap:.25rem}.flex-1{flex:1}.mb-2{margin-bottom:1rem}.mt-2{margin-top:1rem}.mt-1{margin-top:.25rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 1px 3px #0f172a0a}.card-list{display:flex;flex-direction:column;gap:.75rem}.card h3{margin:0 0 1rem;font-size:1.1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:0 1px 3px #0f172a0a;border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem}.stat-card-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:10px;background:var(--accent-bg);color:var(--accent)}.stat-card-icon svg{color:var(--accent);flex-shrink:0}.stat-value{display:block;font-size:1.5rem;font-weight:600}.stat-label{color:var(--text-muted);font-size:.9rem}.stat-accent .stat-value{color:var(--accent)}.stat-green .stat-value{color:var(--success)}.dashboard-section{margin-bottom:2rem}.dashboard-section-title{margin:0 0 1rem;font-size:1.1rem;color:var(--text-muted);font-weight:600}.dashboard-stats{grid-template-columns:repeat(4,1fr)}@media (max-width: 900px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.dashboard-stats{grid-template-columns:1fr}}.meta-setup-complete{display:flex;align-items:center;gap:1rem;padding:1rem;background:#00c85314;border:1px solid rgba(0,200,83,.2);border-radius:10px}.meta-setup-complete .meta-setup-icon{color:var(--success);flex-shrink:0}.meta-setup-guide ol{font-size:.95rem}.quick-actions h2{margin-bottom:1rem;font-size:1.1rem}.action-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}.action-card{background:var(--bg-card);border:1px solid var(--border);box-shadow:0 1px 3px #0f172a0a;border-radius:12px;padding:1.25rem;text-decoration:none;color:inherit;transition:border-color .15s}.action-card:hover{border-color:var(--accent)}.action-card svg{color:var(--accent);margin-bottom:.5rem}.action-card span{display:block;font-weight:600;margin-bottom:.25rem}.action-card p{margin:0;font-size:.85rem;color:var(--text-muted)}.btn-primary{background:#020356!important;color:#fff!important;border:none;padding:.6rem 1.2rem;border-radius:8px;font-weight:600;display:inline-flex;align-items:center;gap:.5rem}.btn-primary:hover:not(:disabled){background:var(--accent-dim)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--bg-hover);color:var(--text);border:1px solid var(--border);padding:.5rem 1rem;border-radius:8px;display:inline-flex;align-items:center;gap:.5rem}.btn-secondary:hover{background:var(--border)}.btn-icon{background:none;border:none;color:var(--text-muted);padding:.25rem;border-radius:4px}.btn-icon:hover{color:var(--text);background:var(--bg-hover)}.btn-icon-danger{color:var(--text-muted)}.btn-icon-danger:hover{color:var(--danger);background:#dc26261a}.btn-danger{background:var(--danger);color:#fff;border:none}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-danger:disabled{opacity:.6;cursor:not-allowed}.contacts-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.contacts-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;box-shadow:0 1px 3px #0203560a}.contacts-stat-icon{width:44px;height:44px;border-radius:10px;background:var(--accent-bg);color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0}.contacts-stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--text)}.contacts-stat-label{display:block;font-size:.85rem;color:var(--text-muted);margin-top:.15rem}@media (max-width: 900px){.contacts-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.contacts-stats-grid{grid-template-columns:1fr}}.contacts-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1.25rem}.contacts-toolbar-left{display:flex;gap:.75rem;flex:1;min-width:0}.contacts-select{width:180px;padding:.65rem 2rem .65rem 1rem;font-size:.9rem;font-weight:500;color:var(--text);background:#fff;border:1px solid #e2dfe8;border-radius:8px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23888' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.contacts-select:hover{border-color:#d0cad8}.contacts-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #8b5cb826}.contacts-search{flex:1;min-width:180px;max-width:340px;display:flex;align-items:center;gap:.6rem;padding:.65rem 1rem;background:#fff;border:1px solid #e2dfe8;border-radius:8px;transition:border-color .15s,box-shadow .15s}.contacts-search:hover{border-color:#d0cad8}.contacts-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 2px #8b5cb826}.contacts-search svg{flex-shrink:0;color:#9a94a8}.contacts-search input{flex:1;min-width:0;border:none;padding:0;font-size:.9rem;background:transparent}.contacts-search input::placeholder{color:#9a94a8}.contacts-search input:focus{outline:none}.contacts-toolbar-right{display:flex;gap:.5rem;flex-wrap:wrap}.contacts-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.1rem;font-size:.9rem;font-weight:500;border-radius:8px;border:none;cursor:pointer;transition:background .15s,color .15s,box-shadow .15s}.contacts-btn:disabled{opacity:.5;cursor:not-allowed}.contacts-btn-primary{background:var(--accent);color:#fff}.contacts-btn-primary:hover:not(:disabled){background:var(--accent-dim);color:#fff}.contacts-btn-ghost{background:transparent;color:var(--text-muted);border:1px solid #e2dfe8}.contacts-btn-ghost:hover:not(:disabled){background:#f6f4f9;color:var(--text);border-color:#d0cad8}.contacts-btn-danger{background:transparent;color:var(--danger);border:1px solid rgba(220,38,38,.4)}.contacts-btn-danger:hover:not(:disabled){background:#dc262614}.contacts-form-card{padding:1.5rem;border-radius:12px;border:1px solid var(--border);box-shadow:0 2px 8px #0203560a}.contacts-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.contacts-form-header h3{margin:0;font-size:1.05rem;font-weight:600}.contacts-close-btn{padding:.35rem}.contacts-form-inline{display:flex;gap:.5rem;flex-wrap:wrap}.contacts-form-inline .input{min-width:160px;padding:.65rem 1rem;border-radius:10px}.contacts-upload-hint{margin:0 0 1rem;font-size:.9rem;color:var(--text-muted)}.contacts-upload-hint code{background:var(--bg-hover);padding:.15rem .4rem;border-radius:4px;font-size:.85rem}.contacts-file-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.contacts-no-connection{padding:2rem;text-align:center}.contacts-no-connection svg{color:var(--accent);opacity:.7;margin-bottom:1rem}.contacts-no-connection p{margin:0;font-weight:500}.contacts-no-connection-desc{margin-top:.35rem!important;font-size:.9rem;font-weight:400!important;color:var(--text-muted)}.contacts-no-connection-modal{padding:2.5rem}.contacts-go-link{margin-top:1rem;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;color:#fff!important}.upload-empty-state{padding:2.5rem 2rem;text-align:center}.upload-empty-icon{width:72px;height:72px;margin:0 auto 1.25rem;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-bg),rgba(139,92,184,.08));color:var(--accent);border-radius:50%}.upload-empty-title{margin:0 0 .5rem;font-size:1.2rem;font-weight:600;color:var(--text)}.upload-empty-desc{margin:0 0 1.5rem;font-size:.95rem;color:var(--text-muted);line-height:1.5;max-width:320px;margin-left:auto;margin-right:auto}.upload-empty-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}.upload-empty-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.25rem;border-radius:10px;font-size:.95rem;font-weight:600;text-decoration:none;transition:all .2s}.upload-empty-btn-primary{background:var(--accent);color:#fff!important;border:none}.upload-empty-btn-primary:hover{background:var(--accent-dim);color:#fff!important}.upload-empty-btn-secondary{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.upload-empty-btn-secondary:hover{background:var(--bg-hover);color:var(--accent);border-color:var(--accent)}.groups-page .contacts-toolbar{margin-bottom:1.25rem}.groups-filter-wrap{position:relative}.groups-filter-dropdown{position:absolute;top:100%;left:0;margin-top:4px;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 12px #0203561a;min-width:160px;z-index:50;overflow:hidden}.groups-filter-dropdown button{display:block;width:100%;padding:.65rem 1rem;text-align:left;border:none;background:none;font-size:.9rem;color:var(--text);cursor:pointer}.groups-filter-dropdown button:hover{background:var(--bg-hover)}.groups-filter-dropdown button.active{background:var(--accent-bg);color:var(--accent);font-weight:500}.groups-create-form{display:flex;flex-direction:column;gap:1rem}.groups-create-form label{display:flex;flex-direction:column;gap:.4rem;font-size:.9rem;font-weight:500;color:var(--text)}.groups-create-form .input{padding:.65rem 1rem;border-radius:8px}.groups-form-hint{font-weight:400;color:var(--text-muted);font-size:.8rem}.groups-form-actions{display:flex;gap:.5rem;margin-top:.5rem}.groups-empty-actions{display:flex;gap:.75rem;justify-content:center;margin-top:1.25rem;flex-wrap:wrap}.groups-cell-name .groups-name{font-weight:500;color:var(--text)}.groups-cell-desc{max-width:280px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-muted);font-size:.9rem}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .8s linear infinite}.upload-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#02035666;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.upload-modal{background:#fff;border-radius:16px;box-shadow:0 24px 48px #02035633;width:100%;max-width:480px;overflow:hidden}.upload-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.upload-modal-header h3{margin:0;font-size:1.2rem;font-weight:600}.upload-modal-close{padding:.35rem}.add-contact-modal-form{padding:1.5rem}.add-contact-modal-field{margin-bottom:1.25rem}.add-contact-modal-field label{display:block;font-size:.9rem;font-weight:500;color:var(--text);margin-bottom:.5rem}.add-contact-modal-field .input{width:100%;padding:.65rem .85rem;border:1px solid var(--border);border-radius:8px;font-size:1rem}.add-contact-modal-field .input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #8b5cb826}.add-contact-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid var(--border)}.upload-dropzone{padding:2.5rem 2rem;border:2px dashed var(--border);border-radius:12px;margin:1.5rem;text-align:center;cursor:pointer;transition:all .2s;background:#faf9fc}.upload-dropzone:hover,.upload-dropzone--active{border-color:var(--accent);background:#8b5cb80f}.upload-dropzone-icon{color:var(--accent);margin-bottom:1rem;opacity:.9}.upload-dropzone-title{margin:0 0 .35rem;font-size:1.05rem;font-weight:600;color:var(--text)}.upload-dropzone-sub{margin:0 0 .5rem;font-size:.9rem;color:var(--text-muted)}.upload-dropzone-formats{margin:0;font-size:.8rem;color:var(--text-muted)}.download-modal{background:#fff;border-radius:16px;box-shadow:0 24px 48px #02035633;width:100%;max-width:480px;overflow:hidden}.download-modal-content{padding:2rem 1.5rem;text-align:center}.download-modal-title{margin:0 0 .5rem;font-size:1.1rem;font-weight:600}.download-modal-desc{margin:0 0 1.5rem;font-size:.9rem;color:var(--text-muted)}.download-modal-btn{padding:.75rem 1.5rem}.contacts-upload-textarea{width:100%;font-family:ui-monospace,SF Mono,monospace;font-size:.9rem;resize:vertical;padding:1rem;border-radius:10px;min-height:140px}.contacts-list-card{padding:0;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0203560a}.contacts-list-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);background:#faf9fc}.contacts-list-header h3{margin:0;font-size:1.05rem;font-weight:600}.contacts-count{font-size:.9rem;font-weight:600;color:var(--accent);background:var(--accent-bg);padding:.25rem .75rem;border-radius:8px}.contacts-loading{padding:3rem 2rem;text-align:center;color:var(--text-muted)}.contacts-loading-spinner{width:40px;height:40px;margin:0 auto 1rem;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:contacts-spin .8s linear infinite}@keyframes contacts-spin{to{transform:rotate(360deg)}}.contacts-empty-state{padding:3rem 2rem;text-align:center}.contacts-empty-icon{width:80px;height:80px;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;background:var(--accent-bg);color:var(--accent);border-radius:50%}.contacts-empty-title{margin:0 0 .35rem;font-size:1.1rem;font-weight:600}.contacts-empty-desc{margin:0;font-size:.9rem;color:var(--text-muted)}.contacts-table-wrap{overflow-x:auto}.contacts-table{width:100%;border-collapse:collapse}.contacts-table thead{background:#faf9fc;border-bottom:1px solid var(--border)}.contacts-table th{padding:.9rem 1.25rem;text-align:left;font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.contacts-table td{padding:1rem 1.25rem;border-bottom:1px solid rgba(221,208,232,.4);font-size:.95rem}.contacts-table tbody tr:hover{background:#8b5cb80a}.contacts-table .contacts-th-check,.contacts-td-check{width:44px;text-align:center;padding-left:1rem}.contacts-table .contacts-th-actions,.contacts-td-actions{width:52px;text-align:right;padding-right:1rem}.contacts-table input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent);cursor:pointer}.btn-sm{padding:.25rem .5rem;font-size:.8rem;border-radius:6px;border:none}.btn-success{background:var(--success);color:#fff}.input{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:.6rem 1rem;color:var(--text);font-size:1rem}.input:focus{outline:none;border-color:var(--accent)}.input-group{display:flex;align-items:center;gap:.5rem}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.4rem;font-size:.9rem;color:var(--text-muted)}.form-grid{display:grid;grid-template-columns:1fr 1fr auto auto;gap:.5rem;align-items:center}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#faf8fc,#f5f0fa,#eee5f5)!important;position:relative;overflow:hidden}.auth-page__bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.auth-page__blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.5}.auth-page__blob--1{width:400px;height:400px;background:#d3a9f5;top:-120px;right:-80px}.auth-page__blob--2{width:300px;height:300px;background:#b88ce8;bottom:-60px;left:-60px;opacity:.35}.auth-page__blob--3{width:200px;height:200px;background:#d3a9f5;top:50%;left:50%;transform:translate(-50%,-50%);opacity:.2}.auth-card{width:100%;max-width:420px;background:#fffffff2!important;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(226,232,240,.8);box-shadow:0 25px 50px -12px #0f172a1a,0 0 0 1px #0f172a08;border-radius:20px;padding:2.5rem;position:relative;z-index:1}.auth-logo{text-align:center;margin-bottom:2rem}.auth-logo__icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;background:linear-gradient(135deg,#020356,#1a1568);color:#fff!important;border-radius:14px;margin-bottom:1rem;box-shadow:0 4px 14px #0203564d}.auth-logo h1{margin:0 0 .25rem;font-size:1.5rem;font-weight:700;color:#020356;letter-spacing:-.02em}.auth-logo p{margin:0;color:#64748b;font-size:.95rem}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.auth-form>input{padding:.75rem 1rem;border-radius:10px;border:1px solid #e2e8f0;background:#fff!important;color:#020356!important;font-size:1rem}.auth-form>input:focus{outline:none;border-color:#d3a9f5;box-shadow:0 0 0 3px #d3a9f540}.auth-form>.btn-primary{margin-top:.5rem}.auth-form__group{display:flex;flex-direction:column;gap:.4rem}.auth-form__group label{font-size:.875rem;font-weight:500;color:#4a4568}.auth-form__input-wrap{position:relative;display:flex;align-items:center}.auth-form__icon{position:absolute;left:1rem;color:#94a3b8;flex-shrink:0;pointer-events:none;transition:color .2s}.auth-form__input-wrap:focus-within .auth-form__icon{color:#d3a9f5}.auth-form__input-wrap--password{position:relative}.auth-form__password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#94a3b8;cursor:pointer;padding:.25rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:color .2s}.auth-form__password-toggle:hover{color:#d3a9f5}.auth-form__input-wrap input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border-radius:10px;border:1px solid #e2e8f0;background:#fff!important;color:#020356!important;font-size:1rem;transition:border-color .2s,box-shadow .2s}.auth-form__input-wrap input::placeholder{color:#94a3b8}.auth-form__input-wrap input:focus{outline:none;border-color:#d3a9f5;box-shadow:0 0 0 3px #d3a9f540}.auth-form__submit{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1.25rem;margin-top:.5rem;background:#020356!important;color:#fff!important;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .15s,box-shadow .15s}.auth-form__submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #02035659;background:#1a1568!important}.auth-form__submit:active:not(:disabled){transform:translateY(0)}.auth-form__submit:disabled{opacity:.7;cursor:not-allowed}.auth-form__submit--compact{width:auto!important}.auth-form__spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:auth-spin .7s linear infinite}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-error{background:#dc262614;color:#dc2626;padding:.75rem 1rem;border-radius:10px;font-size:.9rem;border:1px solid rgba(220,38,38,.2)}.toast-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:flex-start;justify-content:center;padding:3rem 1.5rem 2rem}.toast-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0203561f;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);cursor:pointer}.toast-popup{position:relative;z-index:1;display:flex;align-items:center;gap:1rem;width:100%;max-width:400px;padding:1.25rem 1.5rem;border-radius:16px;box-shadow:0 24px 48px -12px #0203562e,0 0 0 1px #0203560f;background:#fff;animation:toast-slide-in .35s cubic-bezier(.21,.47,.32,.98)}.toast-popup--error{background:linear-gradient(135deg,#fff,#fef8fa);box-shadow:0 24px 48px -12px #8b5cb833,0 0 0 1px #8b5cb81f}.toast-popup--success{background:linear-gradient(135deg,#fff,#f8f7fc);box-shadow:0 24px 48px -12px #0203562e,0 0 0 1px #02035614}.toast-icon-wrap{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:#8b5cb81f;color:#8b5cb8}.toast-popup--success .toast-icon-wrap{background:#0203561a;color:#020356}.toast-message{flex:1;margin:0;font-size:1rem;font-weight:500;color:#020356;line-height:1.5;letter-spacing:-.01em}.toast-close{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:#0203560f;border:none;border-radius:10px;color:#4a4568;cursor:pointer;transition:all .2s ease}.toast-close:hover{background:#0203561a;color:#020356}.toast-close:active{transform:scale(.96)}@keyframes toast-slide-in{0%{opacity:0;transform:translateY(-24px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.auth-footer{text-align:center;margin:1.5rem 0 0;padding-top:1.5rem;border-top:1px solid #f1f5f9;color:#64748b;font-size:.95rem}.auth-footer a{color:#d3a9f5!important;font-weight:600;text-decoration:none;transition:color .2s}.auth-footer a:hover{color:#b88ce8!important;text-decoration:underline}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .6rem;border-radius:6px;font-size:.8rem}.badge-success{background:#00c85333;color:var(--success)}.badge-muted{background:var(--bg-hover);color:var(--text-muted)}.badge-warning{background:#ff980033;color:var(--warning)}.badge-info{background:#2196f333;color:#2196f3}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border)}.table th{color:var(--text-muted);font-weight:500;font-size:.85rem}.empty-state{text-align:center;padding:3rem 2rem;color:var(--text-muted)}.empty-state svg{margin-bottom:1rem;opacity:.5}.connection-card{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.connection-info{display:flex;flex-direction:column;gap:.25rem}.connection-info h3{margin:0}.connection-actions{display:flex;align-items:center;gap:.5rem}.qr-overlay{text-align:center}.qr-overlay h3{margin-bottom:1rem}.campaign-card .campaign-stats{font-size:.9rem;color:var(--text-muted);margin:.5rem 0}.campaign-card .campaign-message{font-size:.9rem;color:var(--text-muted)}.campaign-info{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.flow-card{display:flex;justify-content:space-between;align-items:center}.flow-info{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.flow-info h3{margin:0}.flow-actions{display:flex;gap:.5rem}.template-card{position:relative}.template-card .template-body{font-size:.9rem;color:var(--text-muted);margin:.5rem 0}.template-info{display:flex;align-items:center;gap:.5rem}.text-muted{color:var(--text-muted);font-size:.9rem}.text-success{color:#059669}.text-danger{color:var(--danger)}.api-webhook-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:2rem}.api-webhook-header-text h1{margin:0 0 .25rem;font-size:1.75rem}.api-webhook-header-text p{margin:0;color:var(--text-muted);font-size:.95rem}.api-webhook-status{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#0596691a;color:#059669;border-radius:10px;font-size:.9rem;font-weight:600}.api-webhook-status-dot{width:8px;height:8px;background:#059669;border-radius:50%;animation:api-pulse 2s ease-in-out infinite}@keyframes api-pulse{0%,to{opacity:1}50%{opacity:.5}}.api-webhook-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(360px,1fr));gap:1.5rem}.api-webhook-section{background:#fff;border:1px solid var(--border);border-radius:14px;padding:1.5rem;box-shadow:0 2px 8px #0203560a}.api-webhook-section-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.25rem}.api-webhook-num{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--accent);color:#fff;border-radius:10px;font-weight:700;font-size:1rem;flex-shrink:0}.api-webhook-section-header h3{display:flex;align-items:center;gap:.5rem;margin:0 0 .25rem;font-size:1.1rem;font-weight:600}.api-webhook-section-header h3 svg{color:var(--accent)}.api-webhook-section-header p{margin:0;font-size:.875rem;color:var(--text-muted)}.api-webhook-url-block{margin-bottom:1rem}.api-webhook-url-inner{display:flex;gap:.75rem;align-items:stretch;background:#f8f7fa;border:1px solid #e8e5f0;border-radius:10px;overflow:hidden}.api-webhook-url-inner code{flex:1;padding:.9rem 1.1rem;font-size:.85rem;word-break:break-all;color:var(--text);font-family:ui-monospace,monospace}.api-webhook-copy{display:inline-flex;align-items:center;gap:.4rem;padding:0 1.1rem;background:transparent;border:none;border-left:1px solid #e8e5f0;color:var(--accent);font-weight:500;font-size:.9rem;cursor:pointer;transition:background .15s,color .15s}.api-webhook-copy:hover{background:#8b5cb814}.api-webhook-copy.copied{color:#059669}.api-webhook-note{font-size:.85rem;color:var(--text-muted);line-height:1.5}.api-webhook-note p{margin:0 0 .5rem}.api-webhook-note a{display:inline-flex;align-items:center;gap:.35rem;color:var(--accent);font-weight:500}.api-webhook-note a:hover{text-decoration:underline}.api-webhook-form{display:flex;flex-direction:column;gap:1.1rem}.api-webhook-field label{display:block;margin-bottom:.4rem;font-size:.9rem;font-weight:500;color:var(--text)}.api-webhook-field input{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:10px;font-size:.95rem;background:#fff}.api-webhook-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}.api-webhook-field input::placeholder{color:#9a94a8}.api-webhook-alert{padding:.75rem 1rem;border-radius:10px;font-size:.9rem;line-height:1.4}.api-webhook-alert.success{background:#0596691a;color:#059669}.api-webhook-alert.error{background:#dc262614;color:var(--danger)}.api-webhook-submit{padding:.8rem 1.25rem;min-width:11rem;background:var(--accent);color:#fff;border:none;border-radius:10px;font-weight:600;font-size:1rem;cursor:pointer;transition:background .15s}.api-webhook-form-submit-wrap{display:flex;justify-content:flex-end}.api-webhook-submit:hover:not(:disabled){background:var(--accent-dim)}.api-webhook-submit:disabled{opacity:.6;cursor:not-allowed}.api-webhook-success-msg{margin-top:1rem;padding:.85rem 1rem;background:#05966914;color:#059669;border-radius:10px;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.whatsapp-setup-page{max-width:100%}.whatsapp-setup-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;align-items:start}@media (max-width: 900px){.whatsapp-setup-row{grid-template-columns:1fr}}.whatsapp-setup-section{background:#fff;border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #0203560f;min-width:0}.whatsapp-setup-section-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border)}.whatsapp-setup-section-title{margin:0;font-size:1.125rem;font-weight:600;color:var(--text);letter-spacing:-.01em}.whatsapp-setup-section-badges{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.whatsapp-setup-badge{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:8px;font-size:.75rem;font-weight:600;letter-spacing:.02em}.whatsapp-setup-badge--ok{background:#0596691f;color:#047857}.whatsapp-setup-badge--error{background:#dc26261a;color:#b91c1c}.whatsapp-setup-badge svg{flex-shrink:0;width:14px;height:14px}.whatsapp-setup-section-body{padding:1.5rem}.whatsapp-setup-section-body>p:first-child{margin:0 0 1.25rem;font-size:.9rem;color:var(--text-muted);line-height:1.5}.whatsapp-setup-copy-row{display:flex;align-items:stretch;gap:0;background:#f8f7fb;border:1px solid #eae8f0;border-radius:12px;overflow:hidden;margin-bottom:1rem}.whatsapp-setup-copy-row:last-of-type{margin-bottom:0}.whatsapp-setup-copy-row code{flex:1;padding:.85rem 1.15rem;font-size:.875rem;font-family:ui-monospace,SF Mono,monospace;word-break:break-all;color:var(--text)}.whatsapp-setup-copy-btn{display:inline-flex;align-items:center;gap:.4rem;padding:0 1rem;background:transparent;border:none;border-left:1px solid #eae8f0;color:var(--accent);font-weight:500;font-size:.875rem;cursor:pointer;transition:background .15s,color .15s}.whatsapp-setup-copy-btn:hover{background:#8b5cb814}.whatsapp-setup-copy-btn.copied{color:#059669}.whatsapp-setup-note{margin-top:1.25rem;padding-top:1.25rem;border-top:1px solid var(--border);font-size:.85rem;color:var(--text-muted);line-height:1.55}.whatsapp-setup-note p{margin:0 0 .5rem}.whatsapp-setup-note a{display:inline-flex;align-items:center;gap:.35rem;color:var(--accent);font-weight:500}.whatsapp-setup-btn-outline{padding:.45rem .9rem;border-radius:8px;font-size:.8rem;font-weight:600;background:transparent;color:#b91c1c;border:1px solid rgba(220,38,38,.4);cursor:pointer;transition:background .15s,color .15s}.whatsapp-setup-btn-outline:hover{background:#dc262614}.whatsapp-setup-form{display:flex;flex-direction:column;gap:1.25rem}.whatsapp-setup-field label{display:block;margin-bottom:.45rem;font-size:.9rem;font-weight:500;color:var(--text)}.whatsapp-setup-field input{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:12px;font-size:.95rem;background:#fff;transition:border-color .15s,box-shadow .15s}.whatsapp-setup-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.whatsapp-setup-field input::placeholder{color:#9a94a8}.whatsapp-setup-field-hint{margin-top:.35rem;font-size:.8rem;color:var(--text-muted);line-height:1.4}.whatsapp-setup-alert{padding:.85rem 1rem;border-radius:12px;font-size:.9rem;line-height:1.45}.whatsapp-setup-alert--success{background:#0596691a;color:#047857}.whatsapp-setup-alert--error{background:#dc262614;color:#b91c1c}.whatsapp-setup-submit-wrap{display:flex;justify-content:flex-end;margin-top:.5rem}.whatsapp-setup-submit{padding:.75rem 1.5rem;min-width:10rem;background:var(--accent);color:#fff;border:none;border-radius:12px;font-weight:600;font-size:.95rem;cursor:pointer;transition:background .15s}.whatsapp-setup-submit:hover:not(:disabled){background:var(--accent-dim)}.whatsapp-setup-submit:disabled{opacity:.6;cursor:not-allowed}.whatsapp-setup-done{margin-top:1rem;padding:.9rem 1rem;background:#05966914;color:#047857;border-radius:12px;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.chats-page{height:100vh;min-height:500px;padding:0;display:flex;flex-direction:column;overflow:hidden;margin:-1.5rem}.chats-layout{flex:1;min-height:0;display:grid;grid-template-columns:300px 1fr;gap:0;background:var(--bg-card);border-radius:14px;overflow:hidden;box-shadow:0 4px 24px #0203560f}.chats-sidebar{background:#faf9fc;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}.chats-sidebar-toolbar{padding:.75rem 1rem;border-bottom:1px solid var(--border);flex-shrink:0}.chats-connection-select{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:8px;font-size:.9rem;background:#fff;color:var(--text)}.chats-list{flex:1;min-height:0;overflow-y:auto}.chats-empty,.chats-loading{padding:1.5rem;color:var(--text-muted);text-align:center;font-size:.9rem}.chats-empty-state{padding:2.5rem 1.5rem;text-align:center;color:var(--text-muted)}.chats-empty-state svg{margin-bottom:.75rem;opacity:.35;color:var(--accent)}.chats-empty-state p{margin:0 0 .35rem;font-weight:600;color:var(--text);font-size:.95rem}.chats-empty-state span{font-size:.8rem;line-height:1.4}.chat-list-item{display:flex;align-items:center;gap:.875rem;padding:1rem;border:none;width:100%;text-align:left;background:transparent;cursor:pointer;font-family:inherit;border-bottom:1px solid rgba(221,208,232,.5);transition:background .2s ease}.chat-list-item:hover{background:#8b5cb80f}.chat-list-item--selected{background:#fff;box-shadow:inset 3px 0 0 var(--accent)}.chat-list-avatar{flex-shrink:0;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent-bg),rgba(139,92,184,.12));color:var(--accent);display:flex;align-items:center;justify-content:center}.chat-list-item--selected .chat-list-avatar{background:var(--accent);color:#fff}.chat-list-content{flex:1;min-width:0}.chat-list-name{font-weight:600;font-size:.925rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-list-preview{font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:.2rem;line-height:1.3}.chat-list-time{font-size:.7rem;color:var(--text-muted);flex-shrink:0;font-weight:500}.chats-main{display:flex;flex-direction:column;min-height:0;overflow:hidden;background:#fff}.chats-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted);background:linear-gradient(180deg,#faf9fc,#fff)}.chats-placeholder svg{margin-bottom:1rem;opacity:.25;color:var(--accent)}.chats-placeholder p{margin:0;font-size:.95rem;font-weight:500}.chats-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:1rem;flex-shrink:0;background:#faf9fc}.chats-header-name{margin:0 0 .15rem;font-size:1rem;font-weight:600}.chats-messages{flex:1;overflow-y:auto;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.875rem;background:#f7f6fa}.chat-bubble{max-width:70%;padding:.75rem 1.1rem;border-radius:16px;align-self:flex-start;box-shadow:0 1px 2px #0000000a}.chat-bubble--out{align-self:flex-end;background:linear-gradient(135deg,var(--accent),var(--accent-dim));color:#fff;border-bottom-right-radius:4px}.chat-bubble--in{background:#fff;color:var(--text);border-bottom-left-radius:4px}.chat-bubble-text{margin:0;font-size:.925rem;line-height:1.45;white-space:pre-wrap;word-break:break-word}.chat-bubble-time{font-size:.65rem;opacity:.9;margin-top:.35rem;display:block}.chat-bubble--out .chat-bubble-time{color:#ffffffd9}.chats-reply-form{display:flex;gap:.5rem;padding:1rem 1.5rem;border-top:1px solid var(--border);flex-shrink:0;background:#fff}.chats-reply-input{flex:1;padding:.75rem 1.1rem;border-radius:24px;border:1px solid var(--border);font-size:.95rem;outline:none;transition:border-color .2s,box-shadow .2s}.chats-reply-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.chats-send-btn{padding:.75rem 1rem;border-radius:50%;min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center}@media (max-width: 768px){.chats-page{margin:-1.5rem;height:calc(100vh - 2rem)}.chats-layout{grid-template-columns:1fr;border-radius:0}.chats-sidebar{flex:0 0 auto;max-height:50vh}}
