*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--c-primary: #4BAED4;--c-primary-dark: #2D7A9A;--c-primary-light: #E8F4FD;--c-bg: #F4F6F9;--c-surface: #FFFFFF;--c-text: #2D3748;--c-text-sec: #718096;--c-text-light: #A0AEC0;--c-success: #38C770;--c-warning: #F6C90E;--c-error: #E53E3E;--c-border: #E2E8F0;--c-divider: #F0F4F8;--c-dark: #1A2535;--c-dark-card: #243048;--sidebar-w: 240px;--header-h: 64px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--shadow-sm: 0 1px 3px rgba(0,0,0,.05), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.08), 0 2px 6px rgba(0,0,0,.05);--shadow-lg: 0 8px 32px rgba(0,0,0,.12), 0 4px 12px rgba(0,0,0,.06);--shadow-primary: 0 4px 14px rgba(75,174,212,.3)}html,body,#root{height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--c-bg);color:var(--c-text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;background:none;font-family:inherit}input,select,textarea{font-family:inherit;font-size:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--c-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--c-text-light)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-shell{display:flex;height:100vh;overflow:hidden}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.page-content{flex:1;overflow-y:auto;padding:24px}.card{background:var(--c-surface);border-radius:var(--radius-xl);padding:20px;box-shadow:var(--shadow-sm);border:1px solid var(--c-divider)}.card-interactive{cursor:pointer;transition:box-shadow .18s,transform .12s,border-color .18s}.card-interactive:hover{box-shadow:var(--shadow-md);border-color:var(--c-border)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:700}.badge-success{background:#e6faf0;color:var(--c-success)}.badge-warning{background:#fffbeb;color:#d97706}.badge-error{background:#fef2f2;color:var(--c-error)}.badge-primary{background:var(--c-primary-light);color:var(--c-primary)}.badge-dark{background:var(--c-dark);color:#fff}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-md);font-size:14px;font-weight:700;transition:opacity .15s,transform .1s,box-shadow .15s;white-space:nowrap}.btn:hover{opacity:.9}.btn:active{transform:scale(.97)}.btn:focus-visible{outline:2px solid var(--c-primary);outline-offset:2px}.btn-primary{background:var(--c-primary);color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover{box-shadow:var(--shadow-lg);opacity:.95}.btn-secondary{background:var(--c-primary-light);color:var(--c-primary)}.btn-secondary:hover{background:#d5eef8}.btn-outline{background:transparent;color:var(--c-primary);border:1.5px solid var(--c-primary)}.btn-outline:hover{background:var(--c-primary-light)}.btn-ghost{background:transparent;color:var(--c-text-sec);border:1.5px solid var(--c-border)}.btn-ghost:hover{background:var(--c-bg);border-color:var(--c-border);opacity:1;color:var(--c-text)}.btn-danger{background:var(--c-error);color:#fff}.btn-danger:hover{box-shadow:0 4px 12px #e53e3e4d;opacity:1}.btn-sm{padding:6px 12px;font-size:12px;border-radius:var(--radius-sm)}.btn-lg{padding:13px 24px;font-size:15px;font-weight:700}.btn-full{width:100%;justify-content:center}.input{width:100%;padding:10px 14px;border:1.5px solid var(--c-border);border-radius:var(--radius-md);background:var(--c-surface);color:var(--c-text);font-size:14px;transition:border-color .15s,box-shadow .15s,background .15s;outline:none}.input:hover{border-color:#c4d2e0}.input:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px #4baed426;background:#fff}.input::placeholder{color:var(--c-text-light)}.select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23A0AEC0' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:600;color:var(--c-text)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.stat-card{background:var(--c-surface);border-radius:var(--radius-xl);padding:20px;box-shadow:var(--shadow-sm);border-top:3px solid var(--c-primary)}.stat-card .stat-value{font-size:28px;font-weight:900;line-height:1.1;color:var(--c-dark);letter-spacing:-.5px}.stat-card .stat-label{font-size:12px;color:var(--c-text-light);margin-top:4px}.stat-card .stat-change{font-size:12px;font-weight:600;margin-top:6px}.stat-card .stat-change.up{color:var(--c-success)}.stat-card .stat-change.down{color:var(--c-error)}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--c-text-light);padding:10px 16px;border-bottom:1px solid var(--c-border)}td{padding:14px 16px;border-bottom:1px solid var(--c-divider);font-size:14px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--c-bg)}.avatar{width:36px;height:36px;border-radius:50%;background:var(--c-primary-light);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:var(--c-primary);flex-shrink:0}.avatar-lg{width:56px;height:56px;font-size:24px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.page-header h1{font-size:24px;font-weight:900;color:var(--c-dark);letter-spacing:-.4px}.page-header p{font-size:14px;color:var(--c-text-sec);margin-top:2px}.section-title{font-size:16px;font-weight:700;color:var(--c-text);margin-bottom:12px}.tabs{display:flex;border-bottom:1px solid var(--c-border);margin-bottom:20px;gap:0}.tab-btn{padding:10px 20px;font-size:14px;font-weight:500;color:var(--c-text-light);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}.tab-btn.active{color:var(--c-primary);border-bottom-color:var(--c-primary);font-weight:700}.tab-btn:hover:not(.active){color:var(--c-text)}.sidebar{width:var(--sidebar-w);background:var(--c-dark);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;z-index:10}.sidebar-logo{padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-logo-text{font-size:18px;font-weight:900;color:var(--c-primary);letter-spacing:-.5px}.sidebar-logo-sub{font-size:11px;color:#fff6;margin-top:2px}.sidebar-section{padding:8px 12px}.sidebar-section-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#ffffff4d;padding:8px 8px 4px}.sidebar-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-md);color:#ffffff8c;font-size:13px;font-weight:500;transition:background .15s,color .15s,padding-left .15s;cursor:pointer;width:100%;text-align:left;position:relative}.sidebar-item:hover{background:#ffffff14;color:#ffffffe6;padding-left:16px}.sidebar-item.active{background:var(--c-primary);color:#fff;font-weight:700;box-shadow:0 2px 8px #4baed459}.sidebar-item .icon{font-size:18px;flex-shrink:0;width:22px;text-align:center}.sidebar-item .badge-dot{margin-left:auto;width:18px;height:18px;background:var(--c-error);border-radius:999px;font-size:10px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center}.sidebar-footer{margin-top:auto;padding:12px;border-top:1px solid rgba(255,255,255,.08)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-md);cursor:pointer}.sidebar-user:hover{background:#ffffff12}.sidebar-user-name{font-size:13px;font-weight:600;color:#fff}.sidebar-user-role{font-size:11px;color:#fff6}.header{height:var(--header-h);background:var(--c-surface);border-bottom:1px solid var(--c-border);display:flex;align-items:center;padding:0 24px;gap:16px;flex-shrink:0;box-shadow:var(--shadow-sm)}.header-search{flex:1;max-width:400px;position:relative}.header-search input{width:100%;padding:8px 12px 8px 36px;border:1.5px solid var(--c-border);border-radius:var(--radius-md);background:var(--c-bg);font-size:14px;outline:none;color:var(--c-text)}.header-search input:focus{border-color:var(--c-primary);background:#fff}.header-search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--c-text-light);font-size:15px}.header-actions{display:flex;align-items:center;gap:8px;margin-left:auto}.icon-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:var(--c-bg);color:var(--c-text-sec);font-size:18px;position:relative;transition:background .15s}.icon-btn:hover{background:var(--c-border)}.notif-badge{position:absolute;top:4px;right:4px;width:16px;height:16px;background:var(--c-error);border-radius:999px;font-size:9px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;border:2px solid var(--c-surface)}.chip{display:inline-flex;align-items:center;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:500;border:1.5px solid var(--c-border);color:var(--c-text-sec);cursor:pointer;transition:all .15s;white-space:nowrap;background:var(--c-surface)}.chip:hover{border-color:var(--c-primary);color:var(--c-primary)}.chip.active{border-color:var(--c-primary);background:var(--c-primary-light);color:var(--c-primary);font-weight:700}.progress-wrap{height:6px;background:var(--c-bg);border-radius:999px;overflow:hidden}.progress-bar{height:100%;background:var(--c-primary);border-radius:999px;transition:width .3s}.stat-card{transition:box-shadow .18s,transform .12s}.stat-card:hover{box-shadow:var(--shadow-md)}tr:hover td{background:#f7fbfd;transition:background .1s}th{position:sticky;top:0;background:var(--c-surface);z-index:1}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton{background:linear-gradient(90deg,#f0f4f8 25%,#e8edf2,#f0f4f8 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius-sm)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .22s ease-out}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.15)}}.status-dot-live{animation:none}.panel-scroll{overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--c-border) transparent}[data-tip]{position:relative}[data-tip]:after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);background:var(--c-dark);color:#fff;font-size:11px;font-weight:600;padding:4px 9px;border-radius:6px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .15s;z-index:999}[data-tip]:hover:after{opacity:1}.page-content>*{animation:fadeIn .18s ease-out}.mobile-menu-btn,.sidebar-overlay{display:none}@media (max-width: 768px){.sidebar{position:fixed;top:0;left:0;bottom:0;transform:translate(-100%);transition:transform .25s ease;z-index:1000;box-shadow:var(--shadow-lg)}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;z-index:999}.mobile-menu-btn{display:inline-flex}.header{padding:0 14px;gap:10px;height:56px}.header-search{display:none}.header h2{font-size:16px!important}html,body{overflow-x:hidden}.main-area{width:100%;min-width:0;overflow-x:hidden}.page-content{padding:14px;overflow-x:auto;-webkit-overflow-scrolling:touch}.page-header{margin-bottom:16px}.page-header h1{font-size:20px}.card{padding:16px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.table-wrap{overflow-x:auto}[style*=grid-template-columns],[style*=gridTemplateColumns]{grid-template-columns:1fr!important}img,video,canvas{max-width:100%}.page-content table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;white-space:nowrap}.page-content [style*="display: flex"]:not([style*=column]){flex-wrap:wrap}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.header-actions{gap:6px}}
