:root{--color-primary: #0064ff;--color-primary-hover: #0055d9;--color-primary-active: #004ab8;--color-primary-soft: rgba(0, 100, 255, .1);--color-primary-subtle: rgba(0, 100, 255, .06);--color-dark: #080c25;--color-dark-80: rgba(8, 12, 37, .8);--color-dark-60: rgba(8, 12, 37, .6);--color-dark-40: rgba(8, 12, 37, .4);--color-dark-20: rgba(8, 12, 37, .2);--color-dark-10: rgba(8, 12, 37, .1);--color-muted: #e4e8ef;--color-muted-dark: #cdd3de;--color-muted-light: #f0f3f7;--color-light: #f8f8f8;--color-white: #ffffff;--color-bg: var(--color-light);--color-bg-card: var(--color-white);--color-bg-sidebar: var(--color-dark);--color-bg-header: var(--color-white);--color-bg-input: var(--color-white);--color-bg-hover: var(--color-muted-light);--color-bg-selected: var(--color-primary-subtle);--color-border: var(--color-muted);--color-border-focus: var(--color-primary);--color-border-input: var(--color-muted-dark);--color-text: var(--color-dark);--color-text-soft: var(--color-dark-60);--color-text-muted: var(--color-dark-40);--color-text-inverse: var(--color-white);--color-text-link: var(--color-primary);--color-accent: var(--color-primary);--color-accent-soft: var(--color-primary-soft);--color-success: #0a8a4a;--color-success-soft: rgba(10, 138, 74, .1);--color-danger: #d92b3a;--color-danger-soft: rgba(217, 43, 58, .1);--color-warning: #b45309;--color-warning-soft: rgba(180, 83, 9, .1);--color-info: var(--color-primary);--color-info-soft: var(--color-primary-soft);--color-sms: var(--color-primary);--color-sms-soft: var(--color-primary-soft);--color-voice: var(--color-primary);--color-voice-soft: var(--color-primary-soft);--color-email: var(--color-primary);--color-email-soft: var(--color-primary-soft);--sidebar-bg: var(--color-dark);--sidebar-text: rgba(255, 255, 255, .7);--sidebar-text-active: #ffffff;--sidebar-item-hover: rgba(255, 255, 255, .06);--sidebar-item-active: rgba(0, 100, 255, .2);--sidebar-border: rgba(255, 255, 255, .08);--sidebar-accent: var(--color-primary);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--font-display: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "JetBrains Mono", monospace;--text-xs: 11px;--text-sm: 13px;--text-base: 14px;--text-md: 16px;--text-lg: 18px;--text-xl: 22px;--text-2xl: 28px;--text-3xl: 36px;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full:9999px;--shadow-sm: 0 1px 3px rgba(8, 12, 37, .16);--shadow-md: 0 4px 12px rgba(8, 12, 37, .18);--shadow-lg: 0 8px 32px rgba(8, 12, 37, .22);--shadow-accent: 0 0 20px rgba(0, 100, 255, .25);--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .35s ease;--sidebar-width: 240px;--topbar-height: 60px;--content-max-width: 1280px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:14px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.5;min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}img{max-width:100%;display:block}ul,ol{list-style:none}.font-display{font-family:var(--font-display)}.font-mono{font-family:var(--font-mono)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-md{font-size:var(--text-md)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-primary{color:var(--color-text)}.text-soft{color:var(--color-text-soft)}.text-muted{color:var(--color-text-muted)}.text-accent{color:var(--color-primary)}.font-300{font-weight:300}.font-400{font-weight:400}.font-500{font-weight:500}.font-600{font-weight:600}.font-700{font-weight:700}.font-800{font-weight:800}html,body,#app{height:100%}body{background:var(--color-bg)}.app-root{min-height:100vh}.app-layout{display:flex;min-height:100vh;background:var(--color-bg)}.app-main{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh}.app-content{flex:1;padding:var(--space-8) var(--space-8);max-width:var(--content-max-width);width:100%}.page-bg{background:var(--color-bg)}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-6);gap:var(--space-4)}.page-title{font-family:var(--font-display);font-size:var(--text-xl);font-weight:700;color:var(--color-text)}.page-subtitle{font-size:var(--text-sm);color:var(--color-text-soft);margin-top:var(--space-1)}.page-header-actions{display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.page-filters{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-5);flex-wrap:wrap}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-5{margin-top:var(--space-5)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.w-full{width:100%}.grid{display:grid;gap:var(--space-6)}.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}.justify-center{justify-content:center}.min-h-screen{min-height:100vh}.sidebar{width:var(--sidebar-width);height:100vh;position:fixed;top:0;left:0;background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;z-index:100}.sidebar-logo{height:var(--topbar-height);padding:0 var(--space-5);border-bottom:1px solid var(--sidebar-border);display:flex;align-items:center;gap:var(--space-3);flex-shrink:0}.sidebar-logo-icon{width:32px;height:32px;background:var(--color-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--color-white)}.sidebar-logo-image{width:32px;height:32px;background:var(--color-bg-input);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;overflow:hidden}.sidebar-logo-image img{width:100%;height:100%;object-fit:contain}.sidebar-logo-text{font-family:var(--font-display);font-weight:800;font-size:var(--text-md);color:var(--color-white)}.sidebar-nav{flex:1;padding:var(--space-4) var(--space-3);overflow-y:auto}.sidebar-section-label{font-size:var(--text-xs);font-weight:600;letter-spacing:1px;text-transform:uppercase;color:#ffffff8c;padding:var(--space-3) var(--space-2) var(--space-2)}.sidebar-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);font-size:var(--text-sm);color:var(--sidebar-text);text-decoration:none;margin-bottom:2px;border:1px solid transparent}.sidebar-item:hover{background:var(--sidebar-item-hover);color:var(--sidebar-text-active)}.sidebar-item.active{background:var(--sidebar-item-active);color:var(--sidebar-text-active);box-shadow:inset 3px 0 0 var(--sidebar-accent)}.sidebar-item-icon{width:18px;height:18px;flex-shrink:0;opacity:.7}.sidebar-item.active .sidebar-item-icon{opacity:1}.sidebar-badge{margin-left:auto;background:var(--color-primary);color:var(--color-white);font-size:10px;font-weight:700;padding:2px 6px;border-radius:var(--radius-full);min-width:18px;text-align:center}.sidebar-footer{padding:var(--space-4);border-top:1px solid var(--sidebar-border)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.sidebar-user:hover{background:var(--sidebar-item-hover)}.sidebar-avatar{width:30px;height:30px;border-radius:var(--radius-full);background:var(--color-primary);display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;color:var(--color-white);flex-shrink:0}.sidebar-user-name{font-size:var(--text-sm);font-weight:500;color:var(--color-white)}.sidebar-user-plan{font-size:var(--text-xs);color:#ffffff8c}.topbar{height:var(--topbar-height);background:var(--color-bg-header);border-bottom:1px solid var(--color-border);padding:0 var(--space-8);display:flex;align-items:center;gap:var(--space-4);position:sticky;top:0;z-index:50;box-shadow:var(--shadow-sm)}.topbar-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700;color:var(--color-text)}.topbar-actions{margin-left:auto;display:flex;align-items:center;gap:var(--space-3)}.topbar-credits{background:var(--color-primary-soft);color:var(--color-primary);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--space-1) var(--space-3);font-size:var(--text-sm);font-weight:600}.fade-150-enter-active,.fade-150-leave-active{transition:opacity .15s ease}.fade-150-enter-from,.fade-150-leave-to{opacity:0}.fade-enter-active,.fade-leave-active{transition:opacity .15s ease}.fade-enter-from,.fade-leave-to{opacity:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:0 var(--space-4);height:36px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);font-weight:500;cursor:pointer;border:none;outline:none;transition:all var(--transition-fast);white-space:nowrap;text-decoration:none}.btn:disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--color-primary);color:var(--color-white);border:none}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:active{background:var(--color-primary-active)}.btn-secondary{background:var(--color-muted-light);color:var(--color-dark);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-muted)}.btn-ghost{background:transparent;color:var(--color-text);border:1px solid var(--color-border)}.btn-ghost:hover{background:var(--color-bg-hover)}.btn-danger{background:var(--color-danger);color:var(--color-white);border:none}.btn-danger:hover{background:#d92b3ad9}.btn-sm{height:30px;padding:0 var(--space-3);font-size:var(--text-xs)}.btn-lg{height:44px;padding:0 var(--space-6);font-size:var(--text-base)}.btn-loading{position:relative;color:transparent!important}.btn-loading:after{content:"";position:absolute;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.card-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4)}.card-title{font-family:var(--font-display);font-size:var(--text-base);font-weight:700;color:var(--color-text)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);background:var(--color-muted-light)}.card-metric{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);position:relative;overflow:hidden;transition:border-color var(--transition-base)}.card-metric:hover{border-color:var(--color-border-input)}.card-metric:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--metric-color, var(--color-primary))}.card-metric-value{font-family:var(--font-display);font-size:var(--text-2xl);font-weight:800;color:var(--color-text);margin-bottom:var(--space-1)}.card-metric-label{font-size:var(--text-sm);color:var(--color-text-soft)}.card-metric-change{font-size:var(--text-xs);margin-top:var(--space-3);display:flex;align-items:center;gap:var(--space-1)}.change-up{color:var(--color-success)}.change-down{color:var(--color-danger)}.change-flat{color:var(--color-text-muted)}.form-field{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:var(--text-sm);font-weight:500;color:var(--color-text)}.form-label-required:after{content:" *";color:var(--color-danger)}.form-input,.form-textarea,.form-select{width:100%;background:var(--color-bg-input);border:1px solid var(--color-border-input);border-radius:var(--radius-md);color:var(--color-text);font-family:var(--font-body);font-size:var(--text-sm);padding:0 var(--space-4);height:38px;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);appearance:none}.form-textarea{height:auto;padding:var(--space-3) var(--space-4);resize:vertical;min-height:100px}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-input:hover,.form-textarea:hover,.form-select:hover{border-color:var(--color-border)}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--color-border-focus);box-shadow:0 0 0 3px var(--color-primary-soft)}.form-input.error,.form-textarea.error{border-color:var(--color-danger);box-shadow:0 0 0 3px var(--color-danger-soft)}.form-hint{font-size:var(--text-xs);color:var(--color-text-soft)}.form-error{font-size:var(--text-xs);color:var(--color-danger)}.form-grid{display:grid;gap:var(--space-5)}.form-grid-2{grid-template-columns:1fr 1fr}.form-grid-3{grid-template-columns:1fr 1fr 1fr}.form-actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-5);border-top:1px solid var(--color-border);margin-top:var(--space-5)}.table-wrapper{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table thead th{padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:600;letter-spacing:.6px;text-transform:uppercase;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap}.table tbody td{padding:var(--space-4);font-size:var(--text-sm);color:var(--color-text);border-bottom:1px solid var(--color-muted-light)}.table tbody tr:last-child td{border-bottom:none}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover td{background:var(--color-bg-hover)}.td-primary{font-weight:500}.td-secondary{font-size:var(--text-xs);color:var(--color-text-soft);margin-top:2px}.td-mono{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-text-soft)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:3px var(--space-2);border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;white-space:nowrap}.badge-primary,.badge-accent{background:var(--color-primary-soft);color:var(--color-primary);border:1px solid rgba(0,100,255,.2)}.badge-success{background:var(--color-success-soft);color:var(--color-success);border:1px solid rgba(10,138,74,.2)}.badge-warning{background:var(--color-warning-soft);color:var(--color-warning);border:1px solid rgba(180,83,9,.2)}.badge-danger{background:var(--color-danger-soft);color:var(--color-danger);border:1px solid rgba(217,43,58,.2)}.badge-info{background:var(--color-info-soft);color:var(--color-info);border:1px solid rgba(0,100,255,.2)}.badge-neutral{background:var(--color-muted-light);color:var(--color-dark-60);border:1px solid var(--color-border)}.badge-sms,.badge-voice,.badge-email{background:var(--color-primary-soft);color:var(--color-primary);border:1px solid rgba(0,100,255,.2)}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:badge-pulse 2s infinite}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.4}}.pagination{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border)}.pagination-info{font-size:var(--text-xs);color:var(--color-text-muted)}.pagination-controls{display:flex;align-items:center;gap:var(--space-1)}.pagination-btn{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);cursor:pointer;border:1px solid transparent;background:transparent;color:var(--color-text-soft);transition:all var(--transition-fast)}.pagination-btn:hover{background:var(--color-bg-hover);color:var(--color-text)}.pagination-btn.active{background:var(--color-primary-soft);color:var(--color-primary);border-color:#0064ff33}.pagination-btn:disabled{opacity:.3;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-6)}.modal{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.modal-sm{max-width:400px}.modal-md{max-width:560px}.modal-lg{max-width:720px}.modal-xl{max-width:960px}.modal-header{padding:var(--space-6);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.modal-title{font-family:var(--font-display);font-size:var(--text-lg);font-weight:700}.modal-close{width:32px;height:32px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;background:transparent;border:none;color:var(--color-text-muted);font-size:18px;transition:all var(--transition-fast)}.modal-close:hover{background:var(--color-bg-hover);color:var(--color-text)}.modal-body{padding:var(--space-6)}.modal-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border);display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3)}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-radius:var(--radius-md);font-size:var(--text-sm);border:1px solid transparent}.alert-success{background:var(--color-success-soft);color:var(--color-success);border-color:#0a8a4a33}.alert-warning{background:var(--color-warning-soft);color:var(--color-warning);border-color:#b4530933}.alert-danger{background:var(--color-danger-soft);color:var(--color-danger);border-color:#d92b3a33}.alert-info{background:var(--color-info-soft);color:var(--color-info);border-color:#0064ff33}.toast{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:9999;display:flex;flex-direction:column;gap:var(--space-2)}.toast-item{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4) var(--space-5);font-size:var(--text-sm);min-width:280px;max-width:380px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--space-3);animation:toast-in .2s ease}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.skeleton{background:linear-gradient(90deg,var(--color-muted-light) 25%,var(--color-muted) 50%,var(--color-muted-light) 75%);background-size:200% 100%;animation:skeleton-wave 1.4s ease infinite;border-radius:var(--radius-md)}@keyframes skeleton-wave{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-12) var(--space-6);text-align:center;gap:var(--space-4)}.empty-state-icon{font-size:40px;opacity:.3}.empty-state-title{font-family:var(--font-display);font-size:var(--text-md);font-weight:700;color:var(--color-text)}.empty-state-description{font-size:var(--text-sm);color:var(--color-text-soft);max-width:340px;line-height:1.6}.progress{height:6px;background:var(--color-muted-light);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--color-primary),var(--color-primary-hover));transition:width .4s ease}.progress-sm{height:4px}.progress-lg{height:8px}.progress-fill.success{background:var(--color-success)}.progress-fill.warning{background:var(--color-warning)}.progress-fill.danger{background:var(--color-danger)}body{background-color:var(--color-bg)}
