*{margin:0;padding:0;box-sizing:border-box}
:root{
  --primary:#2563EB;--primary-dark:#1D4ED8;--primary-light:#EFF6FF;
  --accent:#F59E0B;--accent-light:#FFFBEB;
  --success:#10B981;--success-light:#ECFDF5;
  --danger:#EF4444;--danger-light:#FEF2F2;
  --warning:#F59E0B;--warning-light:#FFFBEB;
  --purple:#7C3AED;--purple-light:#F5F3FF;
  --bg:#F8FAFC;--surface:#FFFFFF;--surface2:#F1F5F9;
  --text:#0F172A;--text-muted:#64748B;--text-light:#94A3B8;
  --border:#E2E8F0;--border-dark:#CBD5E1;
  --sidebar-w:268px;
  --radius-sm:8px;--radius:12px;--radius-lg:18px;--radius-xl:24px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --shadow:0 4px 16px rgba(0,0,0,.06),0 2px 4px rgba(0,0,0,.04);
  --shadow-lg:0 10px 40px rgba(0,0,0,.1),0 4px 12px rgba(0,0,0,.06);
}

.page-loader {
    display: none;
    position: fixed;
    inset: 0; 
    background: transparent;
    backdrop-filter: blur(4px); 
    z-index: 9999; 
    align-items: center;
    justify-content: center;
    flex-direction: column;
    gap: 15px;
}

.loc-count-badge {
    background: var(--primary-light);
    color: var(--primary);
    padding: 2px 8px;
    border-radius: 20px;
    font-size: 10px;
    font-weight: 800;
    margin-left: auto;
    border: 1px solid rgba(37, 99, 235, 0.2);
}

.loader-spinner {
    width: 50px;
    height: 50px;
    border: 5px solid #E2E8F0;
    border-top: 5px solid #2563EB;
    border-radius: 50%;
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.loader-text {
    color: #2563EB;
    font-weight: 800;
    font-size: 15px;
    font-family: 'Space Grotesk', sans-serif;
    letter-spacing: 0.5px;
}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--text);display:flex;min-height:100vh;font-size:14px}
.sidebar {
  width: 260px;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  position: fixed;
  height: 100vh;
  left: 0;
  top: 0;
  z-index: 1000;
  background-color: rgb(4, 14, 45);
  overflow-y: auto; 
  overflow-x: hidden;
}
.sidebar::-webkit-scrollbar {
  width: 5px;
}
.sidebar.minimized {
  width: 80px;
}

.sidebar.minimized .brand-name,
.sidebar.minimized .brand-sub,
.sidebar.minimized .admin-chip,
.sidebar.minimized .nav-group-label,
.sidebar.minimized .nav-badge,
.sidebar.minimized .nav-badge-green,
.sidebar.minimized .sidebar-footer #admin-email-label {
  display: none !important;
}

.service-card-tag {
  position: absolute;
  top: 0; right: 120px;
  
  color: rgb(6, 45, 185);
  font-size: 9px;
  padding: 2px 8px;
  border-radius: 0 0 6px 6px;
  font-weight: 700;
}

.sidebar-toggle {
  position: absolute;
  right: -3px;
  top: 22px;
  width: 22px;
  height: 22px;
  background: var(--primary);
  color: white;
  border-radius: 50%;
  border: 2px solid white;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 100;
  transition: 0.3s;
  box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}

.sidebar-toggle:hover {
  transform: scale(1.1);
}


.main {
  transition: margin-left 0.3s ease;
  margin-left: 260px;
}

body:has(.sidebar.minimized) .main {
  margin-left: 80px;
}

.sidebar.minimized .sidebar-toggle i {
  transform: rotate(180deg);
}

.sidebar.minimized .nav-item {
  justify-content: center;
  padding: 12px;
  font-size: 0; 
}
.sidebar.minimized .nav-icon {
  margin-right: 0;
  font-size: 20px;
}

.msg-text-limit {
    max-width: 250px; 
    word-wrap: break-word;
    word-break: break-all;
    white-space: normal;
    line-height: 1.4;
    font-size: 12.5px;
    display: block;
    display: -webkit-box;
    -webkit-line-clamp: 4; 
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.view-detail-box {
    background: var(--surface2);
    padding: 15px;
    border-radius: 12px;
    border: 1px solid var(--border);
    line-height: 1.6;
    font-size: 14px;
    white-space: pre-wrap; 
    word-wrap: break-word;
    margin-top: 10px;
    color: var(--text);
}

.color-picker-wrap{position:relative;display:inline-flex}
.color-picker-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;border:1px solid var(--border);border-radius:6px;background:#fff;cursor:pointer;font-size:12px;font-weight:600;color:var(--ink2);height:28px;font-family:inherit;transition:all .15s}
.color-picker-btn:hover{border-color:var(--teal);color:var(--teal-d)}
.color-dot{width:13px;height:13px;border-radius:50%;border:1.5px solid rgba(0,0,0,.15);flex-shrink:0}
.color-dropdown{display:none;position:absolute;top:34px;left:0;background:#fff;border:1.5px solid var(--border);border-radius:10px;padding:8px;box-shadow:var(--shadow-lg);z-index:200;gap:6px;flex-wrap:wrap;width:160px}
.color-dropdown.open{display:flex}
.color-swatch{width:26px;height:26px;border-radius:6px;cursor:pointer;border:2px solid transparent;transition:all .15s;flex-shrink:0}
.color-swatch:hover{transform:scale(1.18);border-color:rgba(0,0,0,.25)}
.color-swatch.selected{border-color:var(--ink);transform:scale(1.1)}

.sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:4px}
.sidebar-brand{padding:24px 20px 18px;border-bottom:1px solid rgba(255,255,255,.07)}
.brand-icon img{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:12px;box-shadow:0 4px 12px rgba(37,99,235,.4);border-radius:50%}
.brand-name{font-size:17px;font-weight:800;letter-spacing:-.3px;font-family:'Space Grotesk',sans-serif}
.brand-sub{font-size:11px;color:rgba(255,255,255,.4);margin-top:2px}
.admin-chip{display:inline-flex;align-items:center;gap:5px;background:rgba(37,99,235,.2);border:1px solid rgba(37,99,235,.3);color:#93C5FD;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;margin-top:10px}
.nav-group-label{padding:18px 20px 6px;font-size:10px;font-weight:700;color:rgba(255, 255, 255, 0.445);letter-spacing:1.2px;text-transform:uppercase}
.nav-item{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;border-radius:var(--radius-sm);margin:2px 8px;font-size:13px;font-weight:600;color:rgba(255,255,255,.55);transition:all .2s;position:relative}
.nav-item:hover{color:#fff;background:rgba(255,255,255,.07)}
.nav-item.active{color:#fff;background:rgba(37,99,235,.25);border:1px solid rgba(37,99,235,.2)}
.nav-item .nav-icon{width:18px;text-align:center;font-size:15px}
.nav-badge{margin-left:auto;background:var(--danger);color:#fff;font-size:10px;font-weight:800;padding:2px 7px;border-radius:20px;min-width:20px;text-align:center;animation:pulse 2s infinite}
.nav-badge-green{margin-left:auto;background:var(--success);color:#fff;font-size:10px;font-weight:800;padding:2px 7px;border-radius:20px;min-width:20px;text-align:center;display:none}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.7}}
.sidebar-footer{margin-top:auto;padding:16px 8px;border-top:1px solid rgba(255,255,255,.07)}
.logout-btn{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;border-radius:var(--radius-sm);color:rgba(255,255,255,.4);font-size:13px;font-weight:600;transition:all .2s;width:100%;background:none;border:none;font-family:inherit}
.logout-btn:hover{color:var(--danger);background:rgba(239,68,68,.1)}
.main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh}
.topbar{background:rgba(255,255,255,.9);backdrop-filter:blur(12px);padding:0 28px;height:64px;display:flex;align-items:center;gap:16px;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}
.topbar-left{flex:1}
.page-title{font-size:20px;font-weight:800;color:var(--text);font-family:'Space Grotesk',sans-serif}
.page-breadcrumb{font-size:12px;color:var(--text-muted);margin-top:1px}
.topbar-right{display:flex;align-items:center;gap:12px}
.admin-email-badge{display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:6px 14px;font-size:12px;font-weight:600;color:var(--text-muted)}
.admin-email-badge .dot{width:8px;height:8px;background:var(--success);border-radius:50%;flex-shrink:0}
.content{padding:24px 28px;flex:1}
.page{display:none}.page.active{display:block}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.stat-card{background:var(--surface);border-radius:var(--radius-lg);padding:22px;border:1px solid var(--border);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:all .2s;cursor:default}
.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}
.stat-card-accent{position:absolute;top:0;right:0;width:90px;height:90px;border-radius:50%;transform:translate(30px,-30px);opacity:.08}
.sc-blue .stat-card-accent{background:var(--primary)}.sc-green .stat-card-accent{background:var(--success)}
.sc-orange .stat-card-accent{background:var(--accent)}.sc-purple .stat-card-accent{background:var(--purple)}
.stat-icon-wrap{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:14px}
.sc-blue .stat-icon-wrap{background:var(--primary-light)}.sc-green .stat-icon-wrap{background:var(--success-light)}
.sc-orange .stat-icon-wrap{background:var(--accent-light)}.sc-purple .stat-icon-wrap{background:var(--purple-light)}
.stat-value{font-size:36px;font-weight:900;font-family:'Space Grotesk',sans-serif;line-height:1}
.sc-blue .stat-value{color:var(--primary)}.sc-green .stat-value{color:var(--success)}
.sc-orange .stat-value{color:var(--accent)}.sc-purple .stat-value{color:var(--purple)}
.stat-label{font-size:12px;font-weight:600;color:var(--text-muted);margin-top:6px}
.section-card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;margin-bottom:20px}
.section-header{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;background:var(--surface);flex-wrap:wrap}
.section-header-icon{width:32px;height:32px;border-radius:9px;background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.section-header h3{font-size:15px;font-weight:800;font-family:'Space Grotesk',sans-serif}
.section-body{padding:20px 22px}
table{width:100%;border-collapse:collapse}
thead{background:var(--surface2)}
th{text-align:left;padding:11px 14px;font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.6px;border-bottom:1px solid var(--border)}
td{padding:13px 14px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text)}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(37,99,235,.02)}
.badge{padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;display:inline-flex;align-items:center;gap:4px}
.badge::before{content:'';width:6px;height:6px;border-radius:50%;flex-shrink:0}
.b-pending{background:#FEF9C3;color:#A16207}.b-pending::before{background:#EAB308}
.b-approved{background:var(--success-light);color:#065F46}.b-approved::before{background:var(--success)}
.b-rejected,.b-banned{background:var(--danger-light);color:#991B1B}.b-rejected::before,.b-banned::before{background:var(--danger)}
.b-blue{background:var(--primary-light);color:var(--primary-dark)}.b-blue::before{background:var(--primary)}
.b-purple{background:var(--purple-light);color:#5B21B6}.b-purple::before{background:var(--purple)}
.b-orange{background:#FFF7ED;color:#C2410C}.b-orange::before{background:#F97316}
.b-gray{background:var(--surface2);color:var(--text-muted)}.b-gray::before{background:var(--text-light)}
.btn{padding:8px 16px;border-radius:var(--radius-sm);border:none;cursor:pointer;font-weight:700;font-size:12px;font-family:'Plus Jakarta Sans',sans-serif;transition:all .18s;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 2px 8px rgba(37,99,235,.25)}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}
.btn-success{background:var(--success);color:#fff;box-shadow:0 2px 8px rgba(16,185,129,.25)}.btn-success:hover:not(:disabled){background:#059669}
.btn-danger{background:var(--danger);color:#fff;box-shadow:0 2px 8px rgba(239,68,68,.25)}.btn-danger:hover:not(:disabled){background:#DC2626}
.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover:not(:disabled){background:#D97706}
.btn-purple{background:var(--purple);color:#fff}.btn-purple:hover:not(:disabled){background:#6D28D9}
.btn-ghost{background:var(--surface2);color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--border);color:var(--text)}
.btn-sm{padding:5px 11px;font-size:11px;border-radius:6px}
.btn-xs{padding:3px 8px;font-size:11px;border-radius:5px}
.btn-outline{background:transparent;border:1.5px solid var(--primary);color:var(--primary)}.btn-outline:hover{background:var(--primary-light)}
.form-group{margin-bottom:16px}
.form-label{font-size:12px;font-weight:700;color:var(--text);margin-bottom:7px;display:flex;align-items:center;gap:6px}
.form-label .opt{font-weight:400;color:var(--text-muted)}
.form-control{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;transition:border-color .15s,box-shadow .15s;outline:none;background:var(--surface);color:var(--text)}
.form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.08)}
.form-control::placeholder{color:var(--text-light)}
textarea.form-control{min-height:90px;resize:vertical;line-height:1.5}
select.form-control{cursor:pointer;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='7'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2394A3B8' fill='none' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.5);z-index:999;align-items:center;justify-content:center;backdrop-filter:blur(6px)}
.modal-overlay.open{display:flex}
.modal{background:var(--surface);border-radius:var(--radius-xl);padding:0;max-width:780px;width:92%;max-height:92vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);animation:modalIn .25s cubic-bezier(.4,0,.2,1)}
@keyframes modalIn{from{transform:scale(.95) translateY(10px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.modal-lg{max-width:900px}
.modal-head{padding:22px 26px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.modal-head h3{font-size:17px;font-weight:800;font-family:'Space Grotesk',sans-serif}
.modal-close{background:var(--surface2);border:1px solid var(--border);border-radius:7px;width:30px;height:30px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text-muted);transition:all .15s}
.modal-close:hover{background:var(--danger-light);color:var(--danger);border-color:var(--danger)}
.modal-body{padding:22px 26px;overflow-y:auto;flex:1}
.modal-body::-webkit-scrollbar{width:4px}
.modal-body::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:4px}
.notif-banner{background:linear-gradient(135deg,#EFF6FF,#DBEAFE);border:1px solid #BFDBFE;border-radius:var(--radius-sm);padding:12px 16px;margin-bottom:18px;font-size:12.5px;color:#1E40AF;display:flex;align-items:flex-start;gap:8px;line-height:1.5}
.notif-banner strong{font-weight:700}
.compress-info{background:linear-gradient(135deg,#ECFDF5,#D1FAE5);border:1px solid #A7F3D0;border-radius:var(--radius-sm);padding:8px 14px;margin-top:8px;font-size:11.5px;color:#065F46;display:flex;align-items:center;gap:6px;font-weight:600}
.app-photos{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.app-photo{width:100px;height:75px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border)}
.scheme-card{border:1.5px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px;display:flex;align-items:center;gap:16px;transition:all .2s;background:var(--surface)}
.scheme-card:hover{border-color:var(--primary);box-shadow:var(--shadow)}
.scheme-thumb{width:72px;height:60px;object-fit:cover;border-radius:10px;flex-shrink:0;border:1px solid var(--border)}
.scheme-thumb-ph{width:72px;height:60px;background:linear-gradient(135deg,var(--primary-light),#BFDBFE);border-radius:10px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:26px}
.scheme-info{flex:1;min-width:0}
.scheme-info strong{font-size:14px;font-weight:700;display:block}
.scheme-info .desc{font-size:12px;color:var(--text-muted);margin-top:4px;line-height:1.6;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.scheme-link-pill{display:inline-flex;align-items:center;gap:4px;color:var(--primary);font-size:11px;font-weight:600;margin-top:6px;text-decoration:none}
.switch{position:relative;display:inline-block;width:40px;height:22px;margin:0;vertical-align:middle;}
.switch input{opacity:0;width:0;height:0}
.slider{position:absolute;inset:0;background:#CBD5E1;border-radius:22px;cursor:pointer;transition:.25s}
.slider:before{position:absolute;content:'';height:16px;width:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.25s;box-shadow:0 1px 4px rgba(0,0,0,.2)}
input:checked+.slider{background:var(--success)}
input:checked+.slider:before{transform:translateX(18px)}
#login-screen{position:fixed;inset:0;background:url(bg.png) no-repeat center center/cover;display:flex;align-items:center;justify-content:center;z-index:9999;overflow:hidden}
#login-screen::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%, rgba(37,99,235,.15) 0%, transparent 50%),radial-gradient(circle at 80% 20%, rgba(124,58,237,.1) 0%, transparent 40%);pointer-events:none}
.login-card {
  background: rgba(14, 110, 235, 0);
  backdrop-filter: blur(1px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 28px;
  padding: 44px 40px;
  width: 90%;
  max-width: 420px;
  position: relative;
  z-index: 1;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4),
              inset 0 1px 0 rgba(255,255,255,0.2);
}

.login-logo-wrap{  
  width: 72px;
  height: 72px;
  border-radius: 20px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 24px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.2),
              inset 0 1px 0 rgba(255,255,255,0.3);}
.login-logo-wrap img{width:72px;height:72px;border-radius:20px}
.login-card h2{
  color: #F8FAFC;
  text-align: center;
  font-size: 22px;
  font-weight: 700;}
.login-card p{color: rgba(148, 163, 184, 0.9);
  text-align: center;
  margin-bottom: 20px;
  margin-top:10px;
  font-size: 13px;}
.google-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 14px;
  padding: 13px 20px;
  font-size: 14px;
  font-weight: 500;
  color: #ffffff;
  cursor: pointer;
  transition: all 0.2s;
  box-shadow: 0 2px 12px rgba(0,0,0,0.2),
              inset 0 1px 0 rgba(255,255,255,0.8);
}
.google-btn:hover {
  background: rgba(255, 255, 255, 1);
  color:#062e4f;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.25);
}
.google-btn img{width:20px}
.login-warning{margin-top:18px;font-size:11.5px;color:rgba(255,255,255,.3);line-height:1.5}
.search-input{padding:9px 14px 9px 36px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;outline:none;transition:all .15s;background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cpath d='m21 21-4.35-4.35'%3E%3C/path%3E%3C/svg%3E") no-repeat 12px center;color:var(--text)}
.search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.08)}
.img-preview-wrap{position:relative;margin-top:10px;display:none}
.img-preview-wrap.show{display:block}
.img-preview-wrap img{width:100%;height:180px;object-fit:cover;border-radius:var(--radius);border:1.5px solid var(--border)}
.img-preview-remove{position:absolute;top:8px;right:8px;width:26px;height:26px;background:rgba(0,0,0,.6);border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px}
.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:99999}
.toast{background:var(--text);color:#fff;padding:13px 18px;border-radius:12px;font-size:13px;font-weight:600;box-shadow:0 8px 30px rgba(0,0,0,.25);display:flex;align-items:center;gap:10px;min-width:260px;max-width:340px;animation:toastIn .3s cubic-bezier(.4,0,.2,1)}
.toast.out{animation:toastOut .3s forwards}
.toast.success{background:#065F46;border-left:3px solid var(--success)}
.toast.error{background:#7F1D1D;border-left:3px solid var(--danger)}
.toast.info{background:#1E3A5F;border-left:3px solid var(--primary)}
@keyframes toastIn{from{transform:translateX(20px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes toastOut{to{transform:translateX(20px);opacity:0}}
.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}
.empty-state .es-icon{font-size:44px;margin-bottom:12px;opacity:.5}
.empty-state p{font-size:14px;font-weight:600;margin-bottom:4px}
.empty-state small{font-size:12px;opacity:.7}
.info-row{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.info-pill{background:var(--surface2);border:1px solid var(--border);border-radius:7px;padding:5px 11px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:5px}
.tab-bar{display:flex;gap:4px;background:var(--surface2);border-radius:10px;padding:4px;margin-bottom:20px;border:1px solid var(--border)}
.tab-btn{flex:1;padding:8px 12px;border-radius:7px;border:none;background:transparent;font-family:inherit;font-size:12px;font-weight:700;color:var(--text-muted);cursor:pointer;transition:all .2s}
.tab-btn.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.agent-detail-row{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-bottom:16px}
.flex{display:flex}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}
.ml-auto{margin-left:auto}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mb-3{margin-bottom:12px}
.text-sm{font-size:12px}.font-bold{font-weight:700}.text-muted{color:var(--text-muted)}
.w-full{width:100%}.truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.plt-yt{background:#FEE2E2;color:#991B1B}
.plt-ig{background:#FCE7F3;color:#831843}
.table-responsive {overflow-x:auto;}
.entity-list{display:flex;flex-direction:column;gap:0;padding:0}
.entity-row{display:flex;align-items:center;gap:16px;padding:14px 22px;border-bottom:1px solid var(--border);background:var(--surface);transition:background .15s;position:relative}
.entity-row:last-child{border-bottom:none}
.entity-row:hover{background:#F8FAFF}
.entity-row-banned{background:#FFF8F8 !important}
.entity-row-banned:hover{background:#FFF0F0 !important}
.entity-avatar{width:42px;height:42px;border-radius:11px;object-fit:cover;border:2px solid var(--border);flex-shrink:0}
.entity-initials{width:42px;height:42px;border-radius:11px;background:linear-gradient(135deg,var(--primary),#60A5FA);display:flex;align-items:center;justify-content:center;color:#fff;font-size:17px;font-weight:800;flex-shrink:0;font-family:'Space Grotesk',sans-serif}
.entity-initials-user{background:linear-gradient(135deg,var(--purple),#A78BFA)}
.entity-identity{min-width:160px;flex-shrink:0}
.entity-name{font-size:14px;font-weight:800;font-family:'Space Grotesk',sans-serif;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:155px}
.entity-sub{font-size:11px;color:var(--text-muted);margin-top:2px}
.entity-chips{display:flex;align-items:center;gap:6px;flex:1;flex-wrap:wrap}
.entity-chip{background:var(--surface2);border:1px solid var(--border);border-radius:6px;padding:3px 9px;font-size:11px;font-weight:600;color:var(--text-muted);white-space:nowrap;display:inline-flex;align-items:center;gap:4px}
.entity-chip-em{color:var(--text)}
.entity-badges{display:flex;gap:5px;align-items:center;flex-shrink:0}
.entity-actions{display:flex;gap:6px;align-items:center;flex-shrink:0;margin-left:auto}
.load-more-wrap{padding:16px 22px;text-align:center;border-top:1px solid var(--border)}
.search-panel{background:var(--surface2);border-radius:var(--radius-lg);padding:20px;margin-bottom:20px;border:1px solid var(--border)}
.search-type-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.search-type-btn{padding:7px 16px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface);font-family:inherit;font-size:12px;font-weight:700;cursor:pointer;transition:all .2s;color:var(--text-muted)}
.search-type-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}
.search-type-btn:hover:not(.active){border-color:var(--primary);color:var(--primary)}
.profile-header{background:linear-gradient(135deg,#0F172A,#1E3A5F);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px;color:#fff;position:relative;overflow:hidden}
.profile-header::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(37,99,235,.3),transparent 60%);pointer-events:none}
.profile-avatar-lg{width:72px;height:72px;border-radius:20px;border:3px solid rgba(255,255,255,.2);object-fit:cover;flex-shrink:0}
.profile-initials-lg{width:72px;height:72px;border-radius:20px;background:rgba(255,255,255,.1);border:3px solid rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;color:#fff;flex-shrink:0;font-family:'Space Grotesk',sans-serif}
.profile-name{font-size:22px;font-weight:800;font-family:'Space Grotesk',sans-serif;margin-bottom:4px}
.profile-sub{font-size:13px;color:rgba(255,255,255,.6)}
.profile-badges{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.profile-badge{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.85);padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600}
.profile-section{margin-bottom:20px}
.profile-section-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.profile-section-title::after{content:'';flex:1;height:1px;background:var(--border)}
.profile-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.profile-info-item{background:var(--surface2);border-radius:10px;padding:12px 14px;border:1px solid var(--border)}
.profile-info-label{font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;margin-bottom:4px}
.profile-info-value{font-size:13px;font-weight:700;color:var(--text)}
.icon-picker-wrap{margin-bottom:16px}
.icon-selected-preview{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface2);border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;user-select:none}
.icon-selected-preview:hover{border-color:var(--primary);background:var(--primary-light)}
.icon-preview-circle{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#2563EB,#1e40af);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;flex-shrink:0}
.icon-preview-info{flex:1}
.icon-preview-label{font-size:13px;font-weight:700;color:var(--text)}
.icon-preview-sub{font-size:11px;color:var(--text-muted);margin-top:2px}
.icon-picker-btn{padding:6px 14px;border-radius:6px;background:var(--primary);color:#fff;border:none;font-size:12px;font-weight:700;cursor:pointer;font-family:inherit;flex-shrink:0}
.icon-picker-modal{display:none;position:fixed;inset:0;background:rgba(15,23,42,.6);z-index:1100;align-items:center;justify-content:center;backdrop-filter:blur(8px)}
.icon-picker-modal.open{display:flex}
.icon-picker-box{background:#fff;border-radius:20px;width:94%;max-width:720px;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 24px 80px rgba(0,0,0,.25);overflow:hidden;animation:modalIn .25s cubic-bezier(.4,0,.2,1)}
.icon-picker-head{padding:18px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px;flex-shrink:0}
.icon-picker-head h4{font-size:16px;font-weight:800;font-family:'Space Grotesk',sans-serif;flex:1}
.ip-close{background:var(--surface2);border:1px solid var(--border);border-radius:7px;width:28px;height:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px}
.ip-close:hover{background:var(--danger-light);color:var(--danger)}
.icon-picker-search{padding:14px 18px;border-bottom:1px solid var(--border);flex-shrink:0}
.ip-search-input{width:100%;padding:10px 14px 10px 38px;border:1.5px solid var(--border);border-radius:10px;font-family:inherit;font-size:13px;outline:none;background:var(--surface2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cpath d='m21 21-4.35-4.35'%3E%3C/path%3E%3C/svg%3E") no-repeat 12px center}
.ip-search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.08);background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%232563EB' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'%3E%3C/circle%3E%3Cpath d='m21 21-4.35-4.35'%3E%3C/path%3E%3C/svg%3E") no-repeat 12px center}
.icon-picker-cats{padding:10px 18px;border-bottom:1px solid var(--border);display:flex;gap:6px;flex-wrap:wrap;flex-shrink:0}
.ip-cat-btn{padding:5px 12px;border-radius:20px;border:1.5px solid var(--border);background:var(--surface2);font-family:inherit;font-size:11px;font-weight:700;cursor:pointer;transition:all .18s;color:var(--text-muted)}
.ip-cat-btn:hover{border-color:var(--primary);color:var(--primary)}
.ip-cat-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}
.icon-picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:6px;padding:16px 18px;overflow-y:auto;flex:1}
.icon-picker-grid::-webkit-scrollbar{width:4px}
.icon-picker-grid::-webkit-scrollbar-thumb{background:var(--border-dark);border-radius:4px}
.ip-icon-item{display:flex;flex-direction:column;align-items:center;gap:5px;padding:10px 6px;border-radius:10px;cursor:pointer;border:2px solid transparent;transition:all .18s;background:var(--surface2)}
.ip-icon-item:hover{background:var(--primary-light);border-color:var(--primary)}
.ip-icon-item.selected{background:var(--primary);border-color:var(--primary-dark)}
.ip-icon-item.selected i,.ip-icon-item.selected .ip-icon-name{color:#fff}
.ip-icon-item i{font-size:20px;color:var(--primary);transition:color .18px}
.ip-icon-item:hover i{color:var(--primary-dark)}
.ip-icon-name{font-size:9px;color:var(--text-muted);text-align:center;line-height:1.2;word-break:break-all;max-width:60px}
.ip-empty{text-align:center;padding:40px;color:var(--text-muted);grid-column:1/-1}
.ip-empty i{font-size:32px;opacity:.3;display:block;margin-bottom:8px}
.pagination-info{font-size:12px;color:var(--text-muted);font-weight:600;padding:12px 22px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.loc-item{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:9px;border:1px solid var(--border);background:var(--surface);margin-bottom:8px;transition:all .2s}
.loc-item:hover{border-color:var(--primary);background:var(--primary-light)}
.loc-item-name{flex:1;font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px}
.loc-item-edit{display:none;flex:1}

.loc-item.editing .loc-item-name { display: none; }
.loc-edit-controls {
    display: none; 
    gap: 8px;
    align-items: center;
    flex-wrap: wrap; 
    width: 100%;
}

.loc-item.editing .loc-edit-controls {
    display: flex;
}

.loc-edit-controls input, 
.loc-edit-controls select {
    padding: 4px 8px;
    height: 32px;
    font-size: 13px;
    border: 1px solid var(--primary);
    border-radius: 6px;
}
.loc-edit-controls { display: none; flex: 1; gap: 5px; }
.loc-item-name { flex: 1; font-weight: 600; }
.loc-item.editing .loc-item-name{display:none}
.loc-item.editing .loc-item-edit{display:flex;align-items:center;gap:6px;flex:1}
.loc-edit-input{flex:1;padding:6px 10px;border:1.5px solid var(--primary);border-radius:7px;font-family:inherit;font-size:13px;outline:none;font-weight:600}
.expiry-badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700}
.expiry-active{background:#DCFCE7;color:#166534}
.expiry-soon{background:#FEF3C7;color:#92400E}
.expiry-expired{background:#FEE2E2;color:#991B1B}
.expiry-none{background:var(--surface2);color:var(--text-muted)}

.rich-toolbar{display:flex;flex-wrap:wrap;gap:3px;padding:8px;background:var(--bg);border:1.5px solid var(--border);border-bottom:none;border-radius:var(--radius) var(--radius) 0 0}
.tb-btn{padding:5px 9px;border:1px solid transparent;border-radius:6px;background:none;cursor:pointer;font-size:13px;font-family:inherit;color:var(--ink2);transition:all .15s;line-height:1;display:inline-flex;align-items:center;justify-content:center;min-width:30px;height:28px}
.tb-btn:hover{background:#fff;border-color:var(--border);color:var(--ink)}
.tb-btn.active{background:#fff;border-color:var(--teal-mid);color:var(--teal-d);font-weight:700}
.tb-sep{width:1px;background:var(--border);margin:2px 4px;align-self:stretch}
.tb-select{padding:3px 7px;border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:12px;color:var(--ink2);background:#fff;cursor:pointer;height:28px;outline:none}
.tb-select:focus{border-color:var(--teal)}
.color-picker-wrap{position:relative;display:inline-flex}
.color-picker-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;border:1px solid var(--border);border-radius:6px;background:#fff;cursor:pointer;font-size:12px;font-weight:600;color:var(--ink2);height:28px;font-family:inherit;transition:all .15s}
.color-picker-btn:hover{border-color:var(--teal);color:var(--teal-d)}
.color-dot{width:13px;height:13px;border-radius:50%;border:1.5px solid rgba(0,0,0,.15);flex-shrink:0}
.color-dropdown{display:none;position:absolute;top:34px;left:0;background:#fff;border:1.5px solid var(--border);border-radius:10px;padding:8px;box-shadow:var(--shadow-lg);z-index:200;gap:6px;flex-wrap:wrap;width:160px}
.color-dropdown.open{display:flex}
.color-swatch{width:26px;height:26px;border-radius:6px;cursor:pointer;border:2px solid transparent;transition:all .15s;flex-shrink:0}
.color-swatch:hover{transform:scale(1.18);border-color:rgba(0,0,0,.25)}
.color-swatch.selected{border-color:var(--ink);transform:scale(1.1)}
.editor-instruction{background:linear-gradient(135deg,#EFF6FF,#DBEAFE);border:1px solid #BFDBFE;border-radius:8px;padding:8px 12px;margin-bottom:8px;font-size:11.5px;color:#1E40AF;display:flex;gap:7px;align-items:flex-start;line-height:1.5}
.editor-instruction strong{font-weight:700}
.rich-editor{width:100%;min-height:120px;max-height:300px;overflow-y:auto;padding:10px 13px;border:1.5px solid var(--border);border-radius:0 0 var(--radius) var(--radius);font-family:inherit;font-size:13px;outline:none;line-height:1.6;background:#fff;color:var(--ink)}
.rich-editor:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,148,136,.08)}
.rich-editor:empty::before{content:attr(data-placeholder);color:var(--light);pointer-events:none}
.rich-editor h1{font-size:22px;font-weight:800;margin:.5em 0}
.rich-editor h2{font-size:18px;font-weight:700;margin:.5em 0}
.rich-editor h3{font-size:15px;font-weight:700;margin:.4em 0}
.rich-editor ul{padding-left:20px;margin:.3em 0}
.rich-editor ol{padding-left:20px;margin:.3em 0}
.rich-editor blockquote{border-left:3px solid var(--teal);padding-left:12px;color:var(--muted);margin:.4em 0;font-style:italic}
.rich-editor a{color:var(--blue);text-decoration:underline}
.rich-editor table{border-collapse:collapse;width:100%;margin:.5em 0}
.rich-editor table td,.rich-editor table th{border:1px solid var(--border);padding:6px 10px}
.rich-editor table th{background:var(--bg);font-weight:700}
.rich-editor img{max-width:100%;border-radius:6px}
.char-count{font-size:11px;color:var(--light);text-align:right;margin-top:4px}


.msg-split{display:flex;height:calc(100vh - 132px);border:1px solid #E5E7EB;border-radius:16px;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.06);background:#fff;}
.msg-list-panel{width:280px;flex-shrink:0;background:#fff;border-right:1px solid #F0F0F0;display:flex;flex-direction:column;}
.msg-list-head{padding:16px 16px 14px;background:linear-gradient(135deg,#1E1B4B,#3730A3);flex-shrink:0;}
.msg-list-head-top{display:flex;align-items:center;gap:10px}
.msg-list-head-icon{width:34px;height:34px;background:rgba(255,255,255,.15);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.msg-list-head h3{font-family:'Space Grotesk',sans-serif;font-size:14px;font-weight:700;color:#fff;margin-bottom:1px;}
.msg-list-head p{font-size:11px;color:rgba(255,255,255,.5)}
.msg-list-search{padding:10px 12px;background:#FAFAFA;border-bottom:1px solid #F0F0F0;flex-shrink:0;}
.msg-list-search input{width:100%;padding:8px 10px 8px 32px;border:1.5px solid #E5E7EB;border-radius:8px;font-family:inherit;font-size:12px;outline:none;color:#374151;background:#fff 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='%239CA3AF' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") no-repeat 10px center;transition:border-color .15s;}
.msg-list-search input:focus{border-color:#6366F1;box-shadow:0 0 0 3px rgba(99,102,241,.1)}
.msg-list-body{flex:1;overflow-y:auto;min-height:0}
.msg-list-body::-webkit-scrollbar{width:3px}
.msg-list-body::-webkit-scrollbar-thumb{background:#E5E7EB;border-radius:3px}
.conv-item{display:flex;gap:10px;padding:12px 14px;border-bottom:1px solid #F3F4F6;cursor:pointer;transition:background .12s;}
.conv-item:last-child{border-bottom:none}
.conv-item:hover{background:#F9F8FF}
.conv-item.active{background:#EEF2FF;border-left:3px solid #6366F1;padding-left:11px}
.conv-av{width:42px;height:42px;border-radius:10px;object-fit:cover;flex-shrink:0;border:2px solid #E5E7EB;}
.conv-av-ph{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,#059669,#34D399);display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:800;font-family:'Space Grotesk',sans-serif;flex-shrink:0;}
.conv-info{flex:1;min-width:0}
.conv-name{font-size:13px;font-weight:700;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.conv-item.active .conv-name{color:#4338CA}
.conv-biz{font-size:10px;color:#6B7280;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.conv-last{font-size:11px;color:#9CA3AF;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.conv-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}
.conv-time{font-size:10px;color:#9CA3AF;font-weight:500}
.conv-unread{min-width:18px;height:18px;padding:0 5px;background:#EF4444;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff;font-weight:800;}
.chat-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#F8F9FC;min-width:0}
.chat-agent-bar{background:#fff;border-bottom:1px solid #EAECF0;flex-shrink:0}
.chat-agent-bar-inner{display:flex;align-items:center;gap:12px;padding:12px 18px}
.chat-agent-av{width:44px;height:44px;border-radius:11px;object-fit:cover;border:2px solid #E5E7EB;flex-shrink:0;}
.chat-agent-av-ph{width:44px;height:44px;border-radius:11px;background:linear-gradient(135deg,#059669,#34D399);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:800;font-family:'Space Grotesk',sans-serif;flex-shrink:0;}
.chat-agent-info{flex:1;min-width:0}
.chat-agent-name{font-size:15px;font-weight:800;font-family:'Space Grotesk',sans-serif;color:#111827}
.chat-agent-detail{font-size:11px;color:#6B7280;margin-top:2px}
.chat-agent-chips{display:flex;gap:5px;flex-wrap:wrap;margin-top:5px}
.chat-agent-chip{background:#F3F4F6;border-radius:6px;padding:3px 8px;font-size:10px;font-weight:600;color:#4B5563;}
.chat-agent-chip.verified{background:#D1FAE5;color:#065F46}
.chat-agent-bar-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}
.chat-info-bar{background:linear-gradient(90deg,#F0FDF4,#F0F9FF);border-bottom:1px solid #E5E7EB;padding:5px 18px;display:flex;align-items:center;gap:7px;font-size:11px;color:#4B5563;font-weight:500;}
.chat-info-dot{width:6px;height:6px;border-radius:50%;background:#22C55E;flex-shrink:0;animation:gb 2s infinite;}
@keyframes gb{0%,100%{opacity:1}50%{opacity:.3}}
.chat-msgs{flex:1;overflow-y:auto;min-height:0;padding:18px 20px;display:flex;flex-direction:column;gap:2px;background:#F8F9FC;}
.chat-msgs::-webkit-scrollbar{width:4px}
.chat-msgs::-webkit-scrollbar-thumb{background:#D1D5DB;border-radius:4px}
.chat-msg-row{display:flex;gap:8px;align-items:flex-end;max-width:68%;position:relative;margin-bottom:3px;}
.chat-msg-row.sent{flex-direction:row-reverse;margin-left:auto}
.chat-msg-av{width:28px;height:28px;border-radius:7px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;}
.chat-msg-av-admin{background:linear-gradient(135deg,#4F46E5,#7C3AED);color:#fff}
.chat-msg-av-agent{background:linear-gradient(135deg,#059669,#34D399);color:#fff}
.chat-bubble-wrap{position:relative;max-width:100%}
.chat-bubble{padding:9px 13px 6px;border-radius:14px;font-size:13px;line-height:1.55;word-break:break-word;}
.chat-bubble.sent{background:linear-gradient(135deg,#4F46E5,#6366F1);color:#fff;border-bottom-right-radius:3px;box-shadow:0 2px 8px rgba(79,70,229,.18);}
.chat-bubble.recv{background:#fff;color:#111827;border:1px solid #E5E7EB;border-bottom-left-radius:3px;box-shadow:0 1px 3px rgba(0,0,0,.05);}
.chat-bubble-foot{display:flex;align-items:center;justify-content:flex-end;gap:3px;margin-top:2px;}
.chat-bubble.sent .chat-bubble-time{font-size:10px;color:rgba(255,255,255,.6)}
.chat-bubble.recv .chat-bubble-time{font-size:10px;color:#9CA3AF}
.chat-tick{font-size:10px;color:rgba(255,255,255,.5)}
.chat-tick.read{color:#A5F3FC}
.chat-del-btn{display:none;position:absolute;top:-8px;width:20px;height:20px;background:#EF4444;border:2px solid #fff;border-radius:50%;color:#fff;cursor:pointer;font-size:9px;font-weight:900;align-items:center;justify-content:center;box-shadow:0 1px 4px rgba(239,68,68,.4);z-index:10;line-height:1;}
.chat-msg-row.sent .chat-del-btn{left:-10px}
.chat-msg-row.recv .chat-del-btn{right:-10px}
.chat-msg-row:hover .chat-del-btn{display:flex}
.chat-del-btn:hover{transform:scale(1.15)}
.chat-date-div{text-align:center;padding:6px 0;margin:6px 0;position:relative;}
.chat-date-div::before {content:absolute;top:50%;left:0;right:0;height:1px;background:#E5E7EB;}
.chat-date-div span{background:#F8F9FC;padding:0 12px;font-size:10px;color:#9CA3AF;font-weight:600;position:relative;}
.chat-input-area{padding:11px 14px;background:#fff;border-top:1px solid #EAECF0;display:flex;gap:8px;align-items:flex-end;flex-shrink:0;}
.chat-textarea{flex:1;padding:10px 13px;border:1.5px solid #E5E7EB;border-radius:12px;font-family:inherit;font-size:13px;outline:none;resize:none;min-height:42px;max-height:120px;line-height:1.5;color:#111827;background:#F9FAFB;transition:all .15s;}
.chat-textarea:focus{border-color:#6366F1;background:#fff;box-shadow:0 0 0 3px rgba(99,102,241,.1);}
.chat-textarea::placeholder{color:#9CA3AF}
.chat-send-btn{width:42px;height:42px;background:linear-gradient(135deg,#4F46E5,#6366F1);border:none;border-radius:11px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .18s;box-shadow:0 2px 8px rgba(79,70,229,.25);}
.chat-send-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(79,70,229,.35)}
.chat-send-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.chat-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#F8F9FC;}
.chat-empty .icon{font-size:48px;margin-bottom:14px;opacity:.2}
.chat-empty h3{font-family:'Space Grotesk',sans-serif;font-size:15px;font-weight:700;color:#374151;margin-bottom:6px;}
.chat-empty p{font-size:12px;color:#9CA3AF;max-width:200px;text-align:center;line-height:1.7}
.no-conv{text-align:center;padding:44px 16px}
.no-conv .icon{font-size:32px;margin-bottom:8px;opacity:.2}
.no-conv p{font-size:13px;color:#6B7280;font-weight:600;margin-bottom:4px}
.no-conv small{font-size:11px;color:#9CA3AF}

.unban-user-info { display: flex; align-items: center; gap: 12px; }
.unban-avatar { width: 48px; height: 48px; border-radius: 50%; object-fit: cover; border: 2px solid var(--primary-light); box-shadow: var(--shadow-sm); }
.unban-id-pill { background: var(--primary-light); color: var(--primary); padding: 2px 8px; border-radius: 6px; font-size: 10px; font-weight: 800; margin-top: 4px; display: inline-block; }
.unban-reason-box { font-size: 12px; color: var(--danger); background: var(--danger-light); padding: 8px 12px; border-radius: 8px; border-left: 3px solid var(--danger); line-height: 1.4; }
.unban-explanation-card { background: var(--surface2); padding: 10px 14px; border-radius: 10px; border: 1px dashed var(--border-dark); max-width: 280px; position: relative; cursor: pointer; transition: all 0.2s; }
.unban-explanation-card:hover { border-color: var(--primary); background: #fff; transform: translateY(-2px); }
.unban-explanation-text { font-size: 12.5px; color: var(--text); line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.timeline-item { display: flex; align-items: center; gap: 6px; font-size: 11px; color: var(--text-muted); font-weight: 600; }
.btn-action-group { display: flex; flex-direction: column; gap: 6px; }

@media(max-width:1024px){.stat-grid{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}
@media(max-width:768px){.sidebar{width:60px}.sidebar-brand,.nav-group-label,.sidebar-footer{display:none}.nav-item{padding:10px;width:50px;height:50px;border-radius:50%;justify-content:center}.main{margin-left:60px}.stat-grid{grid-template-columns:1fr}.topbar{padding:0 16px}.content{padding:16px}}

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --primary:#2563EB;--primary-light:#EFF6FF;--primary-mid:#BFDBFE;
  --success:#16A34A;--success-light:#F0FDF4;
  --warning:#D97706;--warning-light:#FFFBEB;--warning-mid:#FDE68A;
  --danger:#DC2626;--danger-light:#FEF2F2;
  --ink:#111827;--ink2:#374151;--muted:#6B7280;--faint:#9CA3AF;
  --border:#E5E7EB;--border2:#D1D5DB;
  --bg:#F9FAFB;--surface:#FFFFFF;--surface2:#F3F4F6;
  --radius:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.06);
  --shadow:0 4px 16px rgba(0,0,0,.08),0 2px 6px rgba(0,0,0,.05);
  --shadow-lg:0 10px 40px rgba(0,0,0,.1),0 4px 12px rgba(0,0,0,.06);
}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--ink);font-size:14px;min-height:100vh;overflow-x:hidden}

.toast-container{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:9999}
.toast{background:var(--surface);border:1px solid var(--border);color:var(--ink);padding:12px 16px;border-radius:var(--radius-lg);font-size:13px;font-weight:600;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-lg);min-width:240px;animation:tIn .2s ease}
.toast.success{border-left:3px solid var(--success)}
.toast.error{border-left:3px solid var(--danger)}
.toast.info{border-left:3px solid var(--primary)}
.toast.out{animation:tOut .2s forwards}
@keyframes tIn{from{transform:translateX(16px);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes tOut{to{transform:translateX(16px);opacity:0}}

.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:800;align-items:center;justify-content:center;backdrop-filter:blur(2px)}
.overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-2xl);max-width:500px;width:94%;box-shadow:var(--shadow-lg);animation:mIn .22s ease;max-height:90vh;overflow-y:auto}
@keyframes mIn{from{transform:scale(.96) translateY(8px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}
.modal-head{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--surface);z-index:1}
.modal-head h3{font-size:16px;font-weight:700}
.modal-close{background:var(--surface2);border:none;color:var(--muted);cursor:pointer;font-size:15px;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .15s}
.modal-close:hover{background:var(--danger-light);color:var(--danger)}
.modal-body{padding:20px 24px}

.btn{padding:9px 18px;border-radius:var(--radius-lg);border:none;cursor:pointer;font-weight:600;font-size:13px;font-family:inherit;transition:all .15s;display:inline-flex;align-items:center;gap:6px}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:#1D4ED8}
.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#15803D}
.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#B91C1C}
.btn-ghost{background:transparent;border:1.5px solid var(--border2);color:var(--ink2)}.btn-ghost:hover:not(:disabled){background:var(--surface2);border-color:var(--primary);color:var(--primary)}
.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover:not(:disabled){background:#B45309}
.btn-sm{padding:6px 12px;font-size:12px;border-radius:var(--radius)}
.btn-xs{padding:4px 8px;font-size:11px;border-radius:6px}
.btn-icon{width:32px;height:32px;padding:0;justify-content:center;border-radius:var(--radius)}

.fg{margin-bottom:14px}
.fg label{display:block;font-size:11px;font-weight:700;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.6px}
.fc{width:100%;padding:9px 12px;background:var(--surface);border:1.5px solid var(--border2);border-radius:var(--radius);font-family:inherit;font-size:13px;color:var(--ink);outline:none;transition:border-color .15s}
.fc:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.fc::placeholder{color:var(--faint)}
textarea.fc{resize:vertical;min-height:70px}
.fc-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.header{background:var(--surface);border-bottom:1.5px solid var(--border);padding:0 28px;height:62px;display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-sm)}
.logo-mark{width:34px;height:34px;background:linear-gradient(135deg,#2563EB,#7C3AED);border-radius:9px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;font-weight:800;flex-shrink:0}
.logo-text{font-size:15px;font-weight:800;color:var(--ink);letter-spacing:-.3px}
.logo-sub{font-size:11px;color:var(--muted);font-weight:500}
.header-right{margin-left:auto;display:flex;align-items:center;gap:10px}

.dash-container{max-width:2000px;margin:0 auto;padding:2px 24px}
.dash-top{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:2px;margin-top:0;flex-wrap:wrap}
.dash-title{font-size:24px;font-weight:800;color:var(--ink);letter-spacing:-.4px}
.dash-subtitle{font-size:14px;color:var(--muted);margin-top:3px;font-weight:500}
.dash-controls{display:flex;align-items:center;gap:10px}

.filter-tabs{display:flex;background:var(--surface2);border-radius:var(--radius-lg);padding:3px;gap:2px;}
.filter-tab{padding:7px 18px;border-radius:var(--radius);border-color:  rgba(30, 30, 30, 0.258);background:transparent;cursor:pointer;font-size:13px;font-weight:600;color:var(--muted);font-family:inherit;transition:all .15s}
.filter-tab.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm);border-color: blue}

.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:28px}
.stat-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px}
.stat-num{font-size:26px;font-weight:800;color:var(--ink);letter-spacing:-.5px}
.stat-label{font-size:12px;color:var(--muted);font-weight:600;margin-top:2px}
.stat-icon{font-size:20px;margin-bottom:6px}

.forms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:18px}
.form-card{background:var(--surface);;border-radius:var(--radius-xl);padding:20px;transition:all .2s;position:relative}
.form-card:hover{box-shadow:var(--shadow);border-color:var(--primary-mid)}
.form-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px;gap:10px}
.form-card-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.form-card-icon.published{background:var(--success-light)}
.form-card-icon.draft{background:var(--warning-light)}
.form-card-title{font-size:15px;font-weight:700;color:var(--ink);line-height:1.3;margin-bottom:3px}
.form-card-code{font-size:11px;color:var(--muted);font-family:'JetBrains Mono',monospace;font-weight:500}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700}
.badge-published{background:var(--success-light);color:var(--success)}
.badge-draft{background:var(--warning-light);color:var(--warning)}
.form-card-meta{display:flex;gap:14px;flex-wrap:wrap;margin:8px 0;font-size:12px;color:var(--muted)}
.form-meta-item{display:flex;align-items:center;gap:4px;font-weight:500}
.form-card-desc{font-size:12px;color:var(--muted);line-height:1.5;margin-bottom:10px;font-weight:500}
.form-card-video{display:flex;align-items:center;gap:8px;background:var(--primary-light);border:1px solid var(--primary-mid);border-radius:var(--radius);padding:8px 12px;margin-bottom:12px;text-decoration:none;transition:all .15s}
.form-card-video:hover{background:var(--primary-mid)}
.form-card-video-play{width:26px;height:26px;background:var(--primary);border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#fff;font-size:10px;font-weight:700}
.form-card-video span{font-size:12px;font-weight:600;color:var(--primary)}
.form-card-actions{display:flex;gap:8px;border-top:1px solid var(--border);padding-top:12px;margin-top:4px}
.empty-state-home{text-align:center;padding:60px 20px;color:var(--muted);grid-column:1/-1}
.esi{font-size:48px;margin-bottom:12px}
.empty-state-home h3{font-size:18px;font-weight:700;color:var(--ink2);margin-bottom:6px}
.empty-state-home p{font-size:14px;line-height:1.6;max-width:300px;margin:0 auto}

#page-editor{height:100vh;display:flex;flex-direction:column}
.editor-header{background:var(--surface);border-bottom:1.5px solid var(--border);padding:0 20px;height:56px;display:flex;align-items:center;gap:12px;flex-shrink:0;box-shadow:var(--shadow-sm)}
.editor-title{font-size:14px;font-weight:700;color:var(--ink);max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.editor-actions{margin-left:auto;display:flex;align-items:center;gap:8px}
.editor-body{display:flex;flex:1;overflow:hidden}

.sidebarforms{width:278px;background:var(--surface);border-right:1.5px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}
.sidebarforms::-webkit-scrollbar{width:4px}
.sidebarforms::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
.sidebarforms-sec{padding:14px 16px;border-bottom:1px solid var(--border)}
.sidebarforms-sec:last-child{border-bottom:none;flex:1}
.sec-title{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:10px}

.upload-zone{border:2px dashed var(--border2);border-radius:var(--radius-lg);padding:20px 12px;text-align:center;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.upload-zone:hover,.upload-zone.drag-over{border-color:var(--primary);background:var(--primary-light)}
.upload-zone p{font-size:12px;color:var(--muted);font-weight:500;line-height:1.5}
.upload-zone strong{color:var(--primary)}

.tools-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.tool-btn{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius);padding:9px 8px;cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;color:var(--ink2);transition:all .15s;display:flex;align-items:center;gap:6px}
.tool-btn:hover{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}
.tool-btn.active-tool{border-color:var(--primary);background:var(--primary-light);color:var(--primary)}
.tool-icon{font-size:15px;flex-shrink:0}

.prop-panel{background:var(--surface2);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:14px}
.prop-empty{text-align:center;padding:16px;color:var(--muted)}
.prop-empty-icon{font-size:24px;display:block;margin-bottom:6px;opacity:.4}

.field-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:8px 10px;display:flex;align-items:center;gap:8px;cursor:pointer;transition:all .15s;margin-bottom:4px}
.field-item:hover,.field-item.sel{border-color:var(--primary);background:var(--primary-light)}
.field-item-icon{font-size:13px;flex-shrink:0}
.field-item-info{flex:1;min-width:0}
.field-item-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.field-item-type{font-size:10px;color:var(--muted);font-weight:500}
.field-item-del{width:20px;height:20px;background:none;border:none;cursor:pointer;color:var(--faint);font-size:12px;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.field-item-del:hover{background:var(--danger-light);color:var(--danger)}

.canvas-area{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#E8ECF0}
.canvas-toolbar{background:var(--surface);border-bottom:1px solid var(--border);padding:8px 16px;display:flex;align-items:center;gap:10px;flex-shrink:0}
.canvas-info{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:12px;font-weight:500}
.page-nav{display:flex;align-items:center;gap:6px;margin-left:auto}
.page-nav-btn{background:var(--surface2);border:1px solid var(--border);border-radius:6px;width:28px;height:28px;cursor:pointer;color:var(--ink2);font-size:13px;display:flex;align-items:center;justify-content:center;transition:all .15s}
.page-nav-btn:hover:not(:disabled){border-color:var(--primary);color:var(--primary)}
.page-nav-btn:disabled{opacity:.35;cursor:not-allowed}
.canvas-wrapper{flex:1;overflow:auto;display:flex;justify-content:center;padding:24px}
.canvas-wrapper::-webkit-scrollbar{width:6px;height:6px}
.canvas-wrapper::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}

#pdf-container{position:relative;flex-shrink:0;box-shadow:0 8px 40px rgba(0,0,0,.2);border-radius:4px}
#pdf-canvas{display:block}
#fields-layer{position:absolute;inset:0;pointer-events:auto}

.pdf-field{position:absolute;background:rgba(37,99,235,.08);border:2px dashed #2563EB;border-radius:4px;cursor:move;user-select:none;min-width:40px;min-height:20px;transition:border-color .15s}
.pdf-field:hover{border-color:#7C3AED;background:rgba(124,58,237,.08)}
.pdf-field.selected{border-color:#7C3AED;border-style:solid;background:rgba(124,58,237,.1)}
.pdf-field-label{position:absolute;top:-21px;left:-1px;background:#2563EB;color:#fff;font-size:9px;font-weight:700;padding:2px 7px;border-radius:3px 3px 0 0;white-space:nowrap;max-width:180px;overflow:hidden;text-overflow:ellipsis;font-family:'JetBrains Mono',monospace}
.pdf-field.selected .pdf-field-label{background:#7C3AED}
.pdf-field-resize{position:absolute;bottom:-5px;right:-5px;width:12px;height:12px;background:#2563EB;border:2px solid #fff;border-radius:2px;cursor:se-resize}
.pdf-field.selected .pdf-field-resize{background:#7C3AED}
.pdf-field-type{position:absolute;bottom:2px;right:4px;font-size:9px;opacity:.5}
.pdf-field-del{position:absolute;top:-10px;right:-10px;width:18px;height:18px;background:#DC2626;border:2px solid #fff;border-radius:50%;cursor:pointer;font-size:9px;display:flex;align-items:center;justify-content:center;color:#fff;z-index:10;font-weight:700;opacity:0;transition:opacity .15s;pointer-events:auto;line-height:1}
.pdf-field:hover .pdf-field-del,.pdf-field.selected .pdf-field-del{opacity:1}

.canvas-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--muted);text-align:center;padding:40px;gap:10px}
.canvas-empty-icon{font-size:48px;opacity:.25}
.canvas-empty h3{font-size:16px;font-weight:700;color:var(--ink2)}
.canvas-empty p{font-size:13px;line-height:1.6;max-width:280px;font-weight:500}

.status-bar{background:var(--surface);border-top:1px solid var(--border);padding:5px 16px;font-size:11px;color:var(--muted);display:flex;align-items:center;gap:16px;flex-shrink:0;font-weight:500}
.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}

.option-item{display:flex;gap:6px;align-items:center;margin-bottom:5px}
.option-item input{flex:1;padding:6px 8px;font-size:12px}
.option-del-btn{background:none;border:none;cursor:pointer;color:var(--faint);padding:4px;border-radius:4px;font-size:12px;transition:color .15s}
.option-del-btn:hover{color:var(--danger)}
.add-option-btn{background:none;border:1.5px dashed var(--border2);border-radius:var(--radius);padding:6px;cursor:pointer;font-size:11px;font-family:inherit;color:var(--muted);width:100%;margin-top:4px;transition:all .15s;font-weight:600}
.add-option-btn:hover{border-color:var(--primary);color:var(--primary)}
.prop-divider{border:none;border-top:1px solid var(--border);margin:12px 0}
.loading-spinner{display:inline-block;width:13px;height:13px;border:2px solid var(--border2);border-top-color:var(--primary);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

