@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap);:root{--primary:#4f46e5;--primary-dark:#4338ca;--primary-darker:#3730a3;--primary-light:#a5b4fc;--primary-bg:#eef2ff;--primary-soft:#e0e7ff;--secondary:#0ea5e9;--secondary-bg:#e0f2fe;--success:#059669;--success-bg:#d1fae5;--warning:#d97706;--warning-bg:#fef3c7;--danger:#dc2626;--danger-bg:#fee2e2;--info:#2563eb;--info-bg:#dbeafe;--purple:#7c3aed;--purple-bg:#ede9fe;--grad-brand:linear-gradient(135deg,#6366f1,#8b5cf6);--grad-blue:linear-gradient(135deg,#0ea5e9,#3b82f6);--grad-green:linear-gradient(135deg,#10b981,#059669);--bg:#f6f7fb;--bg-subtle:#f1f5f9;--sidebar-bg:#fff;--card-bg:#fff;--header-bg:#ffffffd9;--border:#e6e8ef;--border-light:#eef0f5;--border-focus:#4f46e5;--text:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-dim:#cbd5e1;--shadow-xs:0 1px 2px #0f172a0a,0 1px 3px #0f172a08;--shadow-sm:0 2px 4px #0f172a0a,0 4px 12px #0f172a0d;--shadow-md:0 4px 8px #0f172a0a,0 12px 28px #0f172a14;--shadow-lg:0 8px 16px #0f172a0f,0 24px 60px #0f172a24;--shadow-primary:0 4px 14px #4f46e54d;--sidebar-width:264px;--header-height:66px;--radius-lg:18px;--radius:14px;--radius-sm:10px;--radius-xs:7px;--ease:cubic-bezier(0.4,0,0.2,1);--ease-out:cubic-bezier(0.16,1,0.3,1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;font-size:16px;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv11","ss01";background:#f6f7fb;background:var(--bg);color:#0f172a;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6;min-height:100vh}a{color:inherit;text-decoration:none}button{font-family:inherit}svg{flex-shrink:0}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{to{transform:translateX(100%)}}.loading-screen{align-items:center;background:#f6f7fb;background:var(--bg);color:#94a3b8;color:var(--text-muted);display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh;padding:24px;text-align:center}.spinner{animation:spin .7s linear infinite;border:3px solid #e6e8ef;border-top-color:#4f46e5;border:3px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:38px;width:38px}.layout{background:#f6f7fb;background:var(--bg);display:flex;min-height:100vh}.sidebar{background:#fff;background:var(--sidebar-bg);border-right:1px solid #e6e8ef;border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;left:0;overflow-y:auto;position:fixed;top:0;transition:transform .3s cubic-bezier(.16,1,.3,1);transition:transform .3s var(--ease-out);width:264px;width:var(--sidebar-width);z-index:100}.sidebar-logo{border-bottom:1px solid #eef0f5;border-bottom:1px solid var(--border-light);padding:20px 20px 18px}.sidebar-logo-mark{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--grad-brand);border-radius:11px;box-shadow:0 4px 14px #4f46e54d;box-shadow:var(--shadow-primary);color:#fff;display:flex;flex-shrink:0;height:38px;justify-content:center;width:38px}.sidebar-logo h2{color:#0f172a;color:var(--text);font-size:1.12rem;font-weight:800;letter-spacing:-.025em}.sidebar-logo p{color:#94a3b8;color:var(--text-muted);font-size:.68rem;font-weight:600;letter-spacing:.07em;margin-top:2px;text-transform:uppercase}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:4px;padding:16px 14px}.nav-section-label{color:#94a3b8;color:var(--text-muted);font-size:.66rem;font-weight:700;letter-spacing:.09em;padding:8px 14px 6px;text-transform:uppercase}.nav-item{align-items:center;background:none;border:none;border-radius:10px;border-radius:var(--radius-sm);color:#475569;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:12px;padding:10px 14px;position:relative;text-align:left;transition:all .16s cubic-bezier(.4,0,.2,1);transition:all .16s var(--ease);width:100%}.nav-item:hover{background:#f1f5f9;background:var(--bg-subtle);color:#0f172a;color:var(--text)}.nav-item.active{background:#eef2ff;background:var(--primary-bg);color:#4f46e5;color:var(--primary);font-weight:600}.nav-item.active:before{background:#4f46e5;background:var(--primary);border-radius:0 3px 3px 0;content:"";height:18px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:3px}.nav-item .icon{align-items:center;display:inline-flex;flex-shrink:0;font-size:1.15rem;justify-content:center;width:20px}.sidebar-footer{border-top:1px solid #eef0f5;border-top:1px solid var(--border-light);padding:14px 14px 18px}.user-info{background:#f1f5f9;background:var(--bg-subtle);border-radius:10px;border-radius:var(--radius-sm);gap:11px;margin-bottom:10px;padding:10px 12px}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--grad-brand);border-radius:11px;color:#fff;flex-shrink:0;font-size:.8rem;font-weight:700;height:38px;justify-content:center;width:38px}.user-name{color:#0f172a;color:var(--text);font-size:.875rem;font-weight:600}.user-role{color:#94a3b8;color:var(--text-muted);font-size:.7rem;font-weight:500;text-transform:capitalize}.sidebar-backdrop{animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a73;display:none;inset:0;position:fixed;z-index:99}.main-content{background:#f6f7fb;background:var(--bg);display:flex;flex:1 1;flex-direction:column;margin-left:264px;margin-left:var(--sidebar-width);min-height:100vh;min-width:0}.header{backdrop-filter:saturate(180%) blur(12px);-webkit-backdrop-filter:saturate(180%) blur(12px);background:#ffffffd9;background:var(--header-bg);border-bottom:1px solid #e6e8ef;border-bottom:1px solid var(--border);gap:12px;height:66px;height:var(--header-height);justify-content:space-between;padding:0 28px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.header,.header-title{align-items:center;display:flex}.header-title{color:#0f172a;color:var(--text);font-size:1rem;font-weight:700;gap:9px;letter-spacing:-.01em}.header-title .icon{color:#4f46e5;color:var(--primary);display:inline-flex;font-size:1.1rem}.header-left{min-width:0}.header-left,.header-right{align-items:center;display:flex;gap:12px}.menu-toggle{align-items:center;background:#fff;border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);color:#475569;color:var(--text-secondary);cursor:pointer;display:none;font-size:1.2rem;height:38px;justify-content:center;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all .15s var(--ease);width:38px}.menu-toggle:hover{background:#f1f5f9;background:var(--bg-subtle);border-color:#a5b4fc;border-color:var(--primary-light);color:#4f46e5;color:var(--primary)}.role-pill{align-items:center;border-radius:999px;display:inline-flex;font-size:.72rem;font-weight:700;gap:6px;letter-spacing:.01em;padding:5px 12px}.role-pill.admin{background:#ede9fe;background:var(--purple-bg);color:#7c3aed;color:var(--purple)}.role-pill.calling{background:#e0f2fe;background:var(--secondary-bg);color:#0ea5e9;color:var(--secondary)}.role-pill.demo{background:#d1fae5;background:var(--success-bg);color:#059669;color:var(--success)}.page-content{animation:fadeIn .35s cubic-bezier(.4,0,.2,1);animation:fadeIn .35s var(--ease);flex:1 1;margin:0 auto;max-width:1500px;padding:28px;width:100%}.page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:14px;justify-content:space-between;margin-bottom:24px}.page-title{color:#0f172a;color:var(--text);font-size:1.5rem;font-weight:800;letter-spacing:-.03em;line-height:1.2}.page-subtitle{font-size:.875rem;font-weight:400;margin-top:4px}.page-subtitle,.section-label{color:#94a3b8;color:var(--text-muted)}.section-label{font-size:.72rem;font-weight:700;letter-spacing:.08em;margin-bottom:14px;text-transform:uppercase}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(212px,1fr));margin-bottom:28px}.stat-card{align-items:center;background:#fff;background:var(--card-bg);border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 1px 2px #0f172a0a,0 1px 3px #0f172a08;box-shadow:var(--shadow-xs);display:flex;gap:16px;overflow:hidden;padding:20px;position:relative;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1),border-color .2s cubic-bezier(.4,0,.2,1);transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease)}.stat-card:hover{border-color:#a5b4fc;border-color:var(--primary-light);box-shadow:0 4px 8px #0f172a0a,0 12px 28px #0f172a14;box-shadow:var(--shadow-md);transform:translateY(-3px)}.stat-icon{align-items:center;border-radius:14px;display:flex;flex-shrink:0;font-size:1.45rem;height:52px;justify-content:center;width:52px}.stat-icon.purple{background:#ede9fe;background:var(--purple-bg);color:#7c3aed;color:var(--purple)}.stat-icon.blue{background:#dbeafe;background:var(--info-bg);color:#2563eb;color:var(--info)}.stat-icon.green{background:#d1fae5;background:var(--success-bg);color:#059669;color:var(--success)}.stat-icon.yellow{background:#fef3c7;background:var(--warning-bg);color:#d97706;color:var(--warning)}.stat-icon.red{background:#fee2e2;background:var(--danger-bg);color:#dc2626;color:var(--danger)}.stat-value{color:#0f172a;color:var(--text);font-size:1.9rem;font-weight:800;letter-spacing:-.03em;line-height:1}.stat-label{color:#94a3b8;color:var(--text-muted);font-size:.8rem;font-weight:500;margin-top:5px}.card{background:#fff;background:var(--card-bg);border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 1px 2px #0f172a0a,0 1px 3px #0f172a08;box-shadow:var(--shadow-xs);padding:24px;transition:box-shadow .2s cubic-bezier(.4,0,.2,1);transition:box-shadow .2s var(--ease)}.card:hover{box-shadow:0 2px 4px #0f172a0a,0 4px 12px #0f172a0d;box-shadow:var(--shadow-sm)}.card-title{align-items:center;color:#0f172a;color:var(--text);display:flex;font-size:1rem;font-weight:700;gap:9px;letter-spacing:-.01em;margin-bottom:18px}.card-title .icon{color:#4f46e5;color:var(--primary);display:inline-flex;font-size:1.05rem}.quick-card{background:#fff;background:var(--card-bg);border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 1px 2px #0f172a0a,0 1px 3px #0f172a08;box-shadow:var(--shadow-xs);cursor:pointer;display:flex;flex-direction:column;gap:12px;padding:22px;transition:all .18s cubic-bezier(.4,0,.2,1);transition:all .18s var(--ease)}.quick-card:hover{border-color:#a5b4fc;border-color:var(--primary-light);box-shadow:0 4px 8px #0f172a0a,0 12px 28px #0f172a14;box-shadow:var(--shadow-md);transform:translateY(-3px)}.quick-card-icon{align-items:center;border-radius:13px;display:flex;font-size:1.3rem;height:46px;justify-content:center;width:46px}.quick-card-link{align-items:center;display:inline-flex;font-size:.82rem;font-weight:600;gap:5px;transition:gap .18s cubic-bezier(.4,0,.2,1);transition:gap .18s var(--ease)}.quick-card:hover .quick-card-link{gap:9px}.table-wrapper{background:#fff;background:var(--card-bg);border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:14px 14px 0 0;border-radius:var(--radius) var(--radius) 0 0;box-shadow:0 1px 2px #0f172a0a,0 1px 3px #0f172a08;box-shadow:var(--shadow-xs);overflow-x:auto}.table-wrapper:last-child{border-radius:14px;border-radius:var(--radius)}table{border-collapse:collapse;font-size:.875rem;width:100%}thead{background:#f1f5f9;background:var(--bg-subtle);border-bottom:1px solid #e6e8ef;border-bottom:1px solid var(--border)}th{color:#475569;color:var(--text-secondary);font-size:.72rem;font-weight:700;letter-spacing:.06em;padding:13px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}td{border-bottom:1px solid #eef0f5;border-bottom:1px solid var(--border-light);color:#0f172a;color:var(--text);padding:14px 16px;vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background .13s cubic-bezier(.4,0,.2,1);transition:background .13s var(--ease)}tbody tr:hover td{background:#f9fafe}.empty-row td{color:#94a3b8;color:var(--text-muted);font-size:.875rem;padding:56px 20px;text-align:center}.cell-avatar{border-radius:10px;color:#fff;display:flex;flex-shrink:0;font-size:.72rem;height:32px;justify-content:center;width:32px}.badge,.cell-avatar{align-items:center;font-weight:700}.badge{border-radius:999px;display:inline-flex;font-size:.7rem;gap:5px;letter-spacing:.01em;line-height:1.4;padding:4px 11px;text-transform:capitalize;white-space:nowrap}.badge .icon{display:inline-flex;font-size:.85em}.badge-new{background:#f1f5f9;color:#64748b}.badge-calling{background:#dbeafe;background:var(--info-bg);color:#2563eb;color:var(--info)}.badge-interested{background:#d1fae5;background:var(--success-bg);color:#059669;color:var(--success)}.badge-not-interested{background:#fee2e2;background:var(--danger-bg);color:#dc2626;color:var(--danger)}.badge-follow-up{background:#fef3c7;background:var(--warning-bg);color:#b45309}.badge-demo{background:#eef2ff;background:var(--primary-bg);color:#4f46e5;color:var(--primary)}.badge-sale{background:#d1fae5;background:var(--success-bg);color:#065f46}.badge-admin{background:#ede9fe;background:var(--purple-bg);color:#7c3aed;color:var(--purple)}.badge-agent{background:#e0f2fe;background:var(--secondary-bg);color:#0ea5e9;color:var(--secondary)}.badge-active{background:#d1fae5;background:var(--success-bg);color:#059669;color:var(--success)}.badge-inactive{background:#fee2e2;background:var(--danger-bg);color:#dc2626;color:var(--danger)}.badge-dot{background:currentColor;border-radius:50%;height:6px;width:6px}.btn{align-items:center;border:none;border-radius:10px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:7px;justify-content:center;letter-spacing:.01em;padding:9px 18px;transition:all .16s cubic-bezier(.4,0,.2,1);transition:all .16s var(--ease);white-space:nowrap}.btn .icon,.btn svg{display:inline-flex;font-size:1.05em}.btn:disabled{cursor:not-allowed;opacity:.55}.btn:active:not(:disabled){transform:translateY(0) scale(.98)}.btn-primary{background:#4f46e5;background:var(--primary);box-shadow:0 4px 14px #4f46e54d;box-shadow:var(--shadow-primary);color:#fff}.btn-primary:hover:not(:disabled){background:#4338ca;background:var(--primary-dark);box-shadow:0 6px 20px #4f46e56b;transform:translateY(-1px)}.btn-secondary{background:#fff;border:1.5px solid #e6e8ef;border:1.5px solid var(--border);color:#475569;color:var(--text-secondary)}.btn-secondary:hover:not(:disabled){background:#eef2ff;background:var(--primary-bg);border-color:#a5b4fc;border-color:var(--primary-light);color:#4f46e5;color:var(--primary)}.btn-success{background:#059669;background:var(--success);box-shadow:0 4px 14px #05966947;color:#fff}.btn-success:hover:not(:disabled){background:#047857;transform:translateY(-1px)}.btn-danger{background:#fff;border:1.5px solid #e6e8ef;border:1.5px solid var(--border);color:#dc2626;color:var(--danger)}.btn-danger:hover:not(:disabled){background:#fee2e2;background:var(--danger-bg);border-color:#fca5a5}.btn-sm{border-radius:7px;border-radius:var(--radius-xs);font-size:.8rem;padding:6px 12px}.btn-lg{font-size:1rem;padding:13px 28px}.btn-icon{height:32px;padding:6px;width:32px}.form-group{margin-bottom:18px}.form-label{color:#475569;color:var(--text-secondary);display:block;font-size:.76rem;font-weight:700;letter-spacing:.05em;margin-bottom:7px;text-transform:uppercase}.form-input,.form-select,.form-textarea{background:#fff;border:1.5px solid #e6e8ef;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);color:#0f172a;color:var(--text);font-family:inherit;font-size:.875rem;outline:none;padding:10px 14px;transition:border-color .15s cubic-bezier(.4,0,.2,1),box-shadow .15s cubic-bezier(.4,0,.2,1);transition:border-color .15s var(--ease),box-shadow .15s var(--ease);width:100%}.form-input::placeholder,.form-textarea::placeholder{color:#cbd5e1;color:var(--text-dim)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#4f46e5;border-color:var(--primary);box-shadow:0 0 0 3.5px #4f46e521}.form-input:hover:not(:focus),.form-select:hover:not(:focus),.form-textarea:hover:not(:focus){border-color:#cbd5e1;border-color:var(--text-dim)}.form-select{cursor:pointer}.form-textarea{line-height:1.6;min-height:90px;resize:vertical}.form-grid-2{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}@media (max-width:640px){.form-grid-2{grid-template-columns:1fr}}.form-hint{color:#94a3b8;color:var(--text-muted);font-size:.75rem;margin-top:6px}.modal-overlay{align-items:center;animation:fadeIn .2s ease;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:#0f172a6b;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}.modal{animation:slideUp .26s cubic-bezier(.16,1,.3,1);animation:slideUp .26s var(--ease-out);background:#fff;border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:18px;border-radius:var(--radius-lg);box-shadow:0 8px 16px #0f172a0f,0 24px 60px #0f172a24;box-shadow:var(--shadow-lg);max-height:92vh;max-width:520px;overflow-y:auto;padding:28px;width:100%}.modal-header{align-items:flex-start;border-bottom:1px solid #eef0f5;border-bottom:1px solid var(--border-light);display:flex;gap:12px;justify-content:space-between;margin-bottom:22px;padding-bottom:16px}.modal-title{align-items:center;color:#0f172a;color:var(--text);display:flex;font-size:1.08rem;font-weight:800;gap:9px;letter-spacing:-.02em}.modal-title .icon{color:#4f46e5;color:var(--primary);display:inline-flex;font-size:1.05rem}.modal-close{align-items:center;background:#f1f5f9;background:var(--bg-subtle);border:none;border-radius:9px;color:#94a3b8;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;font-size:1.05rem;height:32px;justify-content:center;line-height:1;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all .15s var(--ease);width:32px}.modal-close:hover{background:#fee2e2;background:var(--danger-bg);color:#dc2626;color:var(--danger)}.modal-footer{border-top:1px solid #eef0f5;border-top:1px solid var(--border-light);display:flex;gap:10px;justify-content:flex-end;margin-top:24px;padding-top:18px}.info-banner{align-items:flex-start;background:#eef2ff;background:var(--primary-bg);border:1px solid #e0e7ff;border:1px solid var(--primary-soft);border-radius:10px;border-radius:var(--radius-sm);color:#3730a3;color:var(--primary-darker);display:flex;font-size:.82rem;gap:9px;line-height:1.6;padding:11px 14px}.info-banner .icon{color:#4f46e5;color:var(--primary);display:inline-flex;flex-shrink:0;margin-top:1px}.filter-bar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.search-input{flex:1 1;min-width:220px;position:relative}.search-input input{background:#fff;border:1.5px solid #e6e8ef;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);color:#0f172a;color:var(--text);font-family:inherit;font-size:.875rem;outline:none;padding:10px 14px 10px 40px;transition:border-color .15s cubic-bezier(.4,0,.2,1),box-shadow .15s cubic-bezier(.4,0,.2,1);transition:border-color .15s var(--ease),box-shadow .15s var(--ease);width:100%}.search-input input::placeholder{color:#cbd5e1;color:var(--text-dim)}.search-input input:focus{border-color:#4f46e5;border-color:var(--primary);box-shadow:0 0 0 3.5px #4f46e51f}.search-icon{display:inline-flex;font-size:1rem;left:13px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.filter-count,.search-icon{color:#94a3b8;color:var(--text-muted)}.filter-count{font-size:.8rem;font-weight:500;white-space:nowrap}.login-page{align-items:center;background:radial-gradient(1100px 600px at 85% -10%,#6366f124,#0000 60%),radial-gradient(900px 600px at -10% 110%,#10b9811f,#0000 55%),linear-gradient(135deg,#f8faff,#eef2ff);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.login-card{animation:popIn .4s cubic-bezier(.16,1,.3,1);animation:popIn .4s var(--ease-out);background:#fff;border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:22px;box-shadow:0 8px 16px #0f172a0f,0 24px 60px #0f172a24;box-shadow:var(--shadow-lg);max-width:426px;padding:42px 40px;position:relative;width:100%;z-index:1}.login-logo{margin-bottom:32px;text-align:center}.login-logo-icon{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--grad-brand);border-radius:18px;box-shadow:0 4px 14px #4f46e54d;box-shadow:var(--shadow-primary);color:#fff;display:flex;font-size:1.7rem;height:62px;justify-content:center;margin:0 auto 18px;width:62px}.login-logo h1{color:#0f172a;color:var(--text);font-size:1.6rem;font-weight:800;letter-spacing:-.03em}.login-logo p{color:#94a3b8;color:var(--text-muted);font-size:.875rem;font-weight:400;margin-top:7px}.login-btn{font-weight:700;justify-content:center;margin-top:8px;width:100%}.error-msg{align-items:center;background:#fee2e2;background:var(--danger-bg);border:1px solid #fecaca;border-radius:10px;border-radius:var(--radius-sm);color:#dc2626;color:var(--danger);display:flex;font-size:.85rem;font-weight:500;gap:8px;margin-bottom:18px;padding:11px 14px}.error-msg .icon{display:inline-flex;flex-shrink:0}.credentials-hint{background:#f6f7fb;background:var(--bg);border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);margin-top:24px;padding:13px 15px}.input-affix{position:relative}.input-affix .form-input{padding-right:42px}.input-affix-btn{align-items:center;background:none;border:none;border-radius:8px;color:#94a3b8;color:var(--text-muted);cursor:pointer;display:flex;font-size:1rem;height:30px;justify-content:center;position:absolute;right:6px;top:50%;transform:translateY(-50%);transition:all .15s cubic-bezier(.4,0,.2,1);transition:all .15s var(--ease);width:30px}.input-affix-btn:hover{background:#eef2ff;background:var(--primary-bg);color:#4f46e5;color:var(--primary)}.dropzone{background:#f6f7fb;background:var(--bg);border:2px dashed #e6e8ef;border:2px dashed var(--border);border-radius:14px;border-radius:var(--radius);cursor:pointer;padding:30px 20px;text-align:center;transition:all .2s cubic-bezier(.4,0,.2,1);transition:all .2s var(--ease)}.dropzone:hover{border-color:#a5b4fc;border-color:var(--primary-light)}.dropzone.has-file,.dropzone:hover{background:#eef2ff;background:var(--primary-bg)}.dropzone.has-file{border-color:#4f46e5;border-color:var(--primary);border-style:solid}.dropzone-icon{align-items:center;background:#eef2ff;background:var(--primary-bg);border-radius:14px;color:#4f46e5;color:var(--primary);display:flex;font-size:1.5rem;height:54px;justify-content:center;margin:0 auto 12px;width:54px}.timeline-card{background:#f6f7fb;background:var(--bg);border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);flex:1 1;min-width:0;padding:14px 16px}.timeline-note{align-items:flex-start;background:#fff;border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:7px;border-radius:var(--radius-xs);color:#475569;color:var(--text-secondary);display:flex;font-size:.8rem;gap:8px;line-height:1.55;margin-top:8px;padding:8px 12px}.timeline-note .icon{color:#94a3b8;color:var(--text-muted);display:inline-flex;flex-shrink:0;margin-top:2px}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#d8dce6;background-clip:padding-box;border:2px solid #0000;border-radius:99px}::-webkit-scrollbar-thumb:hover{background:#cbd5e1;background:var(--text-dim);background-clip:padding-box}.text-muted{color:#94a3b8;color:var(--text-muted)}.text-sm{font-size:.8rem}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:8px}.pagination-bar{align-items:center;background:#fff;background:var(--card-bg);border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:0 0 14px 14px;border-radius:0 0 var(--radius) var(--radius);border-top:none;box-shadow:0 1px 2px #0f172a0a,0 1px 3px #0f172a08;box-shadow:var(--shadow-xs);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;padding:14px 20px}.pagination-info{color:#94a3b8;color:var(--text-muted);font-size:.8rem;font-weight:500;min-width:90px}.pagination-controls{align-items:center;display:flex;gap:4px}.pg-btn{align-items:center;background:#fff;border:1.5px solid #e6e8ef;border:1.5px solid var(--border);border-radius:9px;color:#475569;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.85rem;font-weight:600;height:34px;justify-content:center;line-height:1;min-width:34px;padding:0 6px;transition:all .14s cubic-bezier(.4,0,.2,1);transition:all .14s var(--ease)}.pg-btn:hover:not(:disabled):not(.pg-active){background:#eef2ff;background:var(--primary-bg);border-color:#a5b4fc;border-color:var(--primary-light);color:#4f46e5;color:var(--primary)}.pg-btn:disabled{cursor:not-allowed;opacity:.4}.pg-btn.pg-active{background:#4f46e5;background:var(--primary);border-color:#4f46e5;border-color:var(--primary);box-shadow:0 4px 14px #4f46e54d;box-shadow:var(--shadow-primary);color:#fff;cursor:default}.pg-dots{color:#94a3b8;color:var(--text-muted);font-size:.9rem;line-height:1;padding:0 2px;-webkit-user-select:none;user-select:none}.pagination-size{align-items:center;display:flex;gap:8px}.pg-size-select{background:#fff;border:1.5px solid #e6e8ef;border:1.5px solid var(--border);border-radius:9px;color:#0f172a;color:var(--text);cursor:pointer;font-family:inherit;font-size:.8rem;font-weight:600;outline:none;padding:6px 10px;transition:border-color .14s cubic-bezier(.4,0,.2,1);transition:border-color .14s var(--ease)}.pg-size-select:focus{border-color:#4f46e5;border-color:var(--primary)}.metrics-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));margin-bottom:22px}.metric-card{background:#fff;background:var(--card-bg);border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 1px 2px #0f172a0a,0 1px 3px #0f172a08;box-shadow:var(--shadow-xs);padding:18px 20px;transition:transform .2s cubic-bezier(.4,0,.2,1),box-shadow .2s cubic-bezier(.4,0,.2,1);transition:transform .2s var(--ease),box-shadow .2s var(--ease)}.metric-card:hover{box-shadow:0 2px 4px #0f172a0a,0 4px 12px #0f172a0d;box-shadow:var(--shadow-sm);transform:translateY(-2px)}.metric-top{align-items:center;display:flex;gap:10px;justify-content:space-between}.metric-label{color:#94a3b8;color:var(--text-muted);font-size:.78rem;font-weight:600}.metric-icon{align-items:center;border-radius:10px;display:inline-flex;flex-shrink:0;font-size:1rem;height:34px;justify-content:center;width:34px}.metric-icon.purple{background:#ede9fe;background:var(--purple-bg);color:#7c3aed;color:var(--purple)}.metric-icon.blue{background:#dbeafe;background:var(--info-bg);color:#2563eb;color:var(--info)}.metric-icon.green{background:#d1fae5;background:var(--success-bg);color:#059669;color:var(--success)}.metric-icon.yellow{background:#fef3c7;background:var(--warning-bg);color:#d97706;color:var(--warning)}.metric-icon.red{background:#fee2e2;background:var(--danger-bg);color:#dc2626;color:var(--danger)}.metric-value{color:#0f172a;color:var(--text);font-size:1.85rem;font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-top:12px}.metric-sub{color:#94a3b8;color:var(--text-muted);font-size:.76rem;font-weight:500;margin-top:5px}.analytics-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));margin-bottom:18px}.analytics-grid.cols-2{grid-template-columns:1.4fr 1fr}@media (max-width:900px){.analytics-grid.cols-2{grid-template-columns:1fr}}.bar-list{display:flex;flex-direction:column;gap:13px}.bar-row-head{align-items:center;display:flex;gap:10px;justify-content:space-between;margin-bottom:6px}.bar-row-label{color:#475569;color:var(--text-secondary);font-size:.82rem;font-weight:500}.bar-row-value{color:#0f172a;color:var(--text);font-size:.82rem;font-weight:700}.bar-track{background:#f1f5f9;background:var(--bg-subtle);border-radius:99px;height:8px;overflow:hidden}.bar-fill{border-radius:99px;height:100%;min-width:4px;transition:width .6s cubic-bezier(.16,1,.3,1);transition:width .6s var(--ease-out)}.funnel{display:flex;flex-direction:column;gap:16px}.funnel-meta{align-items:baseline;display:flex;justify-content:space-between;margin-bottom:7px}.funnel-label{color:#475569;color:var(--text-secondary);font-size:.84rem;font-weight:600}.funnel-value{align-items:baseline;color:#0f172a;color:var(--text);display:inline-flex;font-size:1.05rem;font-weight:800;gap:8px;letter-spacing:-.02em}.funnel-conv{background:#d1fae5;background:var(--success-bg);border-radius:999px;color:#059669;color:var(--success);font-size:.72rem;font-weight:700;padding:2px 8px}.funnel-track{background:#f1f5f9;background:var(--bg-subtle);border-radius:8px;height:26px;overflow:hidden}.funnel-fill{border-radius:8px;height:100%;min-width:6px;transition:width .6s cubic-bezier(.16,1,.3,1);transition:width .6s var(--ease-out)}.donut-wrap{align-items:center;display:flex;flex-wrap:wrap;gap:24px}.donut{flex-shrink:0;position:relative}.donut-center{align-items:center;display:flex;flex-direction:column;inset:0;justify-content:center;position:absolute;text-align:center}.donut-center-value{color:#0f172a;color:var(--text);font-size:1.5rem;font-weight:800;letter-spacing:-.03em}.donut-center-sub{color:#94a3b8;color:var(--text-muted);font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.donut-legend{display:flex;flex:1 1;flex-direction:column;gap:10px;min-width:140px}.legend-item{align-items:center;display:flex;font-size:.82rem;gap:9px}.legend-dot{border-radius:3px;flex-shrink:0;height:10px;width:10px}.legend-label{color:#475569;color:var(--text-secondary);flex:1 1}.legend-value{color:#0f172a;color:var(--text);font-weight:700}.chart-empty{color:#94a3b8;color:var(--text-muted);font-size:.85rem;padding:28px 12px;text-align:center}.num-strong{color:#0f172a;color:var(--text);font-weight:700}.num-pill{align-items:center;border-radius:999px;display:inline-flex;font-size:.72rem;font-weight:700;justify-content:center;min-width:30px;padding:2px 8px}.num-pill.win{background:#d1fae5;background:var(--success-bg);color:#059669;color:var(--success)}.num-pill.zero{color:#94a3b8;color:var(--text-muted)}.num-pill.zero,.segmented{background:#f1f5f9;background:var(--bg-subtle)}.segmented{border:1px solid #e6e8ef;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);display:inline-flex;flex-wrap:wrap;gap:4px;margin-bottom:22px;padding:5px}.segmented-btn{align-items:center;background:none;border:none;border-radius:10px;border-radius:var(--radius-sm);color:#475569;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:inherit;font-size:.83rem;font-weight:600;gap:7px;padding:8px 16px;transition:all .16s cubic-bezier(.4,0,.2,1);transition:all .16s var(--ease);white-space:nowrap}.segmented-btn:hover{color:#0f172a;color:var(--text)}.segmented-btn.active{background:#fff;box-shadow:0 1px 2px #0f172a0a,0 1px 3px #0f172a08;box-shadow:var(--shadow-xs);color:#4f46e5;color:var(--primary)}.segmented-btn .icon{display:inline-flex}.picker-bar{align-items:flex-end;display:flex;flex-wrap:wrap;gap:14px;margin-bottom:22px}.picker-field{display:flex;flex:1 1;flex-direction:column;gap:6px;min-width:200px}.picker-field>label{color:#475569;color:var(--text-secondary);font-size:.72rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.slot-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(176px,1fr))}.slot-chip{background:#fff;border:1.5px solid #e6e8ef;border:1.5px solid var(--border);border-radius:10px;border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:8px;padding:13px 15px;position:relative;transition:all .16s cubic-bezier(.4,0,.2,1);transition:all .16s var(--ease)}.slot-chip.selectable{cursor:pointer}.slot-chip.selectable:hover:not(.disabled){border-color:#a5b4fc;border-color:var(--primary-light);box-shadow:0 2px 4px #0f172a0a,0 4px 12px #0f172a0d;box-shadow:var(--shadow-sm);transform:translateY(-2px)}.slot-chip.selected{background:#eef2ff;background:var(--primary-bg);border-color:#4f46e5;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51f}.slot-chip.disabled{background:#f1f5f9;background:var(--bg-subtle);cursor:not-allowed;opacity:.6}.slot-time{align-items:center;color:#0f172a;color:var(--text);display:flex;font-size:.82rem;font-weight:700;gap:6px;letter-spacing:-.01em}.slot-time .icon{color:#94a3b8;color:var(--text-muted);display:inline-flex}.slot-status{align-items:center;display:inline-flex;font-size:.72rem;font-weight:700;gap:6px}.slot-status .dot{border-radius:50%;height:8px;width:8px}.slot-status.available{color:#059669;color:var(--success)}.slot-status.available .dot{background:#059669;background:var(--success)}.slot-status.partial{color:#d97706;color:var(--warning)}.slot-status.partial .dot{background:#d97706;background:var(--warning)}.slot-status.full{color:#dc2626;color:var(--danger)}.slot-status.full .dot{background:#dc2626;background:var(--danger)}.slot-chip.available{border-left:3px solid #059669;border-left:3px solid var(--success)}.slot-chip.partial{border-left:3px solid #d97706;border-left:3px solid var(--warning)}.slot-chip.full{border-left:3px solid #dc2626;border-left:3px solid var(--danger)}.capacity-meter{background:#f1f5f9;background:var(--bg-subtle);border-radius:99px;height:6px;overflow:hidden}.capacity-meter-fill{border-radius:99px;height:100%;transition:width .5s cubic-bezier(.16,1,.3,1);transition:width .5s var(--ease-out)}.capacity-meter-fill.available{background:#059669;background:var(--success)}.capacity-meter-fill.partial{background:#d97706;background:var(--warning)}.capacity-meter-fill.full{background:#dc2626;background:var(--danger)}.slot-capacity-row{align-items:center;color:#94a3b8;color:var(--text-muted);display:flex;font-size:.72rem;font-weight:500;justify-content:space-between}.slot-cap-input{border:1.5px solid #e6e8ef;border:1.5px solid var(--border);border-radius:7px;border-radius:var(--radius-xs);color:#0f172a;color:var(--text);font-family:inherit;font-size:.82rem;font-weight:600;outline:none;padding:5px 8px;text-align:center;transition:border-color .15s cubic-bezier(.4,0,.2,1);transition:border-color .15s var(--ease);width:56px}.slot-cap-input:focus{border-color:#4f46e5;border-color:var(--primary)}.slot-check{align-items:center;background:#fff;border:1.5px solid #e6e8ef;border:1.5px solid var(--border);border-radius:6px;color:#fff;display:flex;height:20px;justify-content:center;position:absolute;right:10px;top:10px;transition:all .15s cubic-bezier(.4,0,.2,1);transition:all .15s var(--ease);width:20px}.slot-chip.selected .slot-check{background:#4f46e5;background:var(--primary);border-color:#4f46e5;border-color:var(--primary)}.empty-state{padding:48px 24px;text-align:center}.empty-state,.empty-state-icon{color:#94a3b8;color:var(--text-muted)}.empty-state-icon{align-items:center;background:#f1f5f9;background:var(--bg-subtle);border-radius:16px;display:flex;height:56px;justify-content:center;margin:0 auto 14px;width:56px}.empty-state-title{color:#475569;color:var(--text-secondary);font-size:.95rem;font-weight:700;margin-bottom:4px}@media (max-width:1024px){.page-content{padding:24px}}@media (max-width:768px){.sidebar{box-shadow:0 8px 16px #0f172a0f,0 24px 60px #0f172a24;box-shadow:var(--shadow-lg);transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.sidebar.open~.sidebar-backdrop{display:block}.main-content{margin-left:0}.header{padding:0 16px}.menu-toggle{display:inline-flex}.page-content{padding:16px}.stats-grid{gap:12px;grid-template-columns:1fr 1fr}.page-title{font-size:1.3rem}.modal{padding:22px}}@media (max-width:600px){.pagination-bar{justify-content:center}.pagination-info{display:none}.header-title{font-size:.92rem}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.7e45ef5c.css.map*/