:root{--color-primary-50: #eff6ff;--color-primary-100: #dbeafe;--color-primary-200: #bfdbfe;--color-primary-300: #93c5fd;--color-primary-400: #60a5fa;--color-primary-500: #3b82f6;--color-primary-600: #2563eb;--color-primary-700: #1d4ed8;--color-primary-800: #1e40af;--color-primary-900: #1e3a8a;--color-gray-50: #f8fafc;--color-gray-100: #f1f5f9;--color-gray-200: #e2e8f0;--color-gray-300: #cbd5e1;--color-gray-400: #94a3b8;--color-gray-500: #64748b;--color-gray-600: #475569;--color-gray-700: #334155;--color-gray-800: #1e293b;--color-gray-900: #0f172a;--color-success-light: #dcfce7;--color-success: #16a34a;--color-success-dark: #15803d;--color-warning-light: #fef9c3;--color-warning: #ca8a04;--color-warning-dark: #a16207;--color-danger-light: #fee2e2;--color-danger: #dc2626;--color-danger-dark: #b91c1c;--color-info-light: #dbeafe;--color-info: #2563eb;--color-info-dark: #1d4ed8;--color-orange-light: #ffedd5;--color-orange: #ea580c;--color-cyan-light: #cffafe;--color-cyan: #0891b2;--color-teal-light: #ccfbf1;--color-teal: #0d9488;--bg-app: #f1f5f9;--bg-surface: #ffffff;--bg-sidebar: #0f172a;--bg-sidebar-hover: #1e293b;--bg-topbar: #ffffff;--text-primary: #0f172a;--text-secondary: #475569;--text-muted: #94a3b8;--text-on-dark: #f8fafc;--text-on-brand: #ffffff;--border-color: #e2e8f0;--border-focus: #3b82f6;--border-radius-sm: 4px;--border-radius: 8px;--border-radius-lg: 12px;--border-radius-xl: 16px;--border-radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--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;--space-16: 64px;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: 12px;--text-sm: 14px;--text-base: 16px;--text-lg: 18px;--text-xl: 20px;--text-2xl: 24px;--text-3xl: 30px;--text-4xl: 36px;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--sidebar-width: 240px;--sidebar-collapsed-width: 64px;--topbar-height: 60px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4}body{line-height:1.5;-webkit-font-smoothing:antialiased}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}a{text-decoration:none;color:inherit}ul,ol{list-style:none}button{cursor:pointer;border:none;background:none}table{border-collapse:collapse;width:100%}body{font-family:var(--font-sans);font-size:var(--text-base);color:var(--text-primary);background:var(--bg-app);line-height:1.5;min-height:100vh}h1{font-size:var(--text-3xl);font-weight:var(--font-bold);line-height:1.2}h2{font-size:var(--text-2xl);font-weight:var(--font-semibold);line-height:1.25}h3{font-size:var(--text-xl);font-weight:var(--font-semibold);line-height:1.3}h4{font-size:var(--text-lg);font-weight:var(--font-medium)}h5{font-size:var(--text-base);font-weight:var(--font-medium)}h6{font-size:var(--text-sm);font-weight:var(--font-medium)}a{color:var(--color-primary-600);transition:color var(--transition-fast)}a:hover{color:var(--color-primary-700)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-gray-300);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-400)}::selection{background:var(--color-primary-100);color:var(--color-primary-900)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.app-shell{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100;transition:width var(--transition-normal),transform var(--transition-normal);overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed-width)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-4);border-bottom:1px solid rgba(255,255,255,.08);min-height:var(--topbar-height)}.sidebar-logo-mark{width:36px;height:36px;background:var(--color-primary-500);border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:var(--font-bold);color:#fff;flex-shrink:0;letter-spacing:-.5px}.sidebar-logo-text{display:flex;flex-direction:column;transition:opacity var(--transition-normal)}.sidebar-logo-name{font-size:var(--text-base);font-weight:var(--font-bold);color:#fff;line-height:1.2}.sidebar-logo-sub{font-size:var(--text-xs);color:var(--color-gray-400)}.sidebar.collapsed .sidebar-logo-text{opacity:0;width:0;overflow:hidden}.sidebar-nav{flex:1;padding:var(--space-3) var(--space-2);overflow-y:auto;overflow-x:hidden}.nav-section-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--color-gray-500);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-3) var(--space-2) var(--space-1);white-space:nowrap;transition:opacity var(--transition-normal)}.sidebar.collapsed .nav-section-label{opacity:0}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--border-radius);color:var(--color-gray-400);transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;position:relative;margin-bottom:2px;text-decoration:none}.nav-item:hover{background:var(--bg-sidebar-hover);color:#e2e8f0}.nav-item.active{background:#3b82f626;color:var(--color-primary-400);border-left:3px solid var(--color-primary-500);padding-left:calc(var(--space-3) - 3px)}.nav-item-icon{width:18px;height:18px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.nav-item-label{font-size:var(--text-sm);font-weight:var(--font-medium);transition:opacity var(--transition-normal)}.sidebar.collapsed .nav-item-label{opacity:0;width:0;overflow:hidden}.nav-badge{margin-left:auto;background:var(--color-gray-700);color:var(--color-gray-300);font-size:10px;font-weight:var(--font-semibold);padding:1px 6px;border-radius:var(--border-radius-full);transition:opacity var(--transition-normal)}.nav-badge.danger{background:var(--color-danger);color:#fff}.sidebar.collapsed .nav-badge{opacity:0}.sidebar-footer{padding:var(--space-3) var(--space-2);border-top:1px solid rgba(255,255,255,.08)}.sidebar-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--border-radius);cursor:pointer;transition:background var(--transition-fast)}.sidebar-user:hover{background:var(--bg-sidebar-hover)}.user-avatar{width:32px;height:32px;border-radius:var(--border-radius-full);background:var(--color-primary-600);color:#fff;font-size:var(--text-xs);font-weight:var(--font-semibold);display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-avatar.sm{width:26px;height:26px;font-size:10px}.user-avatar.lg{width:40px;height:40px;font-size:var(--text-sm)}.user-info{transition:opacity var(--transition-normal);overflow:hidden}.sidebar.collapsed .user-info{opacity:0;width:0}.user-name{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-gray-200);white-space:nowrap}.user-role{font-size:var(--text-xs);color:var(--color-gray-500);white-space:nowrap}.main-content{margin-left:var(--sidebar-width);flex:1;display:flex;flex-direction:column;min-height:100vh;transition:margin-left var(--transition-normal)}.main-content.sidebar-collapsed{margin-left:var(--sidebar-collapsed-width)}.topbar{height:var(--topbar-height);background:var(--bg-topbar);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);position:sticky;top:0;z-index:50;gap:var(--space-4)}.topbar-left{display:flex;align-items:center;gap:var(--space-3);flex:1}.topbar-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.topbar-breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted)}.breadcrumb-sep{color:var(--color-gray-300)}.topbar-right{display:flex;align-items:center;gap:var(--space-3)}.page-content{flex:1;padding:var(--space-6);max-width:1400px;width:100%}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-6);flex-wrap:wrap;gap:var(--space-4)}.page-header-left h1{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary)}.page-header-left p{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.page-header-actions{display:flex;align-items:center;gap:var(--space-3)}.hamburger-btn{display:none;width:36px;height:36px;align-items:center;justify-content:center;border-radius:var(--border-radius);color:var(--text-secondary);transition:all var(--transition-fast)}.hamburger-btn:hover{background:var(--color-gray-100);color:var(--text-primary)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}body.portal-theme .sidebar,body.portal-theme .topbar,body.portal-theme .hamburger-btn{display:none}body.portal-theme .main-content{margin-left:0}body.portal-theme .page-content{padding:0}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--border-radius);font-size:var(--text-sm);font-weight:var(--font-medium);line-height:1;transition:all var(--transition-fast);white-space:nowrap;cursor:pointer;border:1px solid transparent;text-decoration:none}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary-600);color:#fff;border-color:var(--color-primary-600)}.btn-primary:hover:not(:disabled){background:var(--color-primary-700);border-color:var(--color-primary-700)}.btn-secondary{background:#fff;color:var(--text-primary);border-color:var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-50);border-color:var(--color-gray-300)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover:not(:disabled){background:var(--color-danger-dark)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--color-gray-100);color:var(--text-primary)}.btn-success{background:var(--color-success);color:#fff;border-color:var(--color-success)}.btn-success:hover:not(:disabled){background:var(--color-success-dark)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-lg{padding:var(--space-3) var(--space-6);font-size:var(--text-base)}.btn-icon{width:36px;height:36px;padding:0;flex-shrink:0}.btn-icon.btn-sm{width:28px;height:28px}.card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-4);padding-bottom:var(--space-4);border-bottom:1px solid var(--border-color)}.card-title{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--text-primary)}.card-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}.form-group{display:flex;flex-direction:column;gap:var(--space-1)}.form-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.form-label.required:after{content:" *";color:var(--color-danger)}.form-input,.form-select,.form-textarea{width:100%;padding:var(--space-2) var(--space-3);background:#fff;border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:var(--text-sm);color:var(--text-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);line-height:1.5}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f61a}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--color-danger)}.form-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='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:var(--space-8);cursor:pointer}.form-textarea{resize:vertical;min-height:90px}.form-hint{font-size:var(--text-xs);color:var(--text-muted)}.form-error{font-size:var(--text-xs);color:var(--color-danger)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-4)}.form-section{margin-bottom:var(--space-6)}.form-section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--space-4);padding-bottom:var(--space-2);border-bottom:1px solid var(--border-color)}.form-col-full{grid-column:1 / -1}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px var(--space-2);border-radius:var(--border-radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);white-space:nowrap;line-height:1.4}.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.badge-gray{background:var(--color-gray-100);color:var(--color-gray-600)}.badge-blue{background:var(--color-primary-100);color:var(--color-primary-700)}.badge-green{background:var(--color-success-light);color:var(--color-success-dark)}.badge-yellow{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-red{background:var(--color-danger-light);color:var(--color-danger-dark)}.badge-orange{background:var(--color-orange-light);color:var(--color-orange)}.badge-cyan{background:var(--color-cyan-light);color:var(--color-cyan)}.badge-teal{background:var(--color-teal-light);color:var(--color-teal)}.data-table-wrap{overflow-x:auto;border-radius:var(--border-radius-lg);border:1px solid var(--border-color);background:#fff}.data-table{width:100%;font-size:var(--text-sm)}.data-table thead th{background:var(--color-gray-50);padding:var(--space-3) var(--space-4);text-align:left;font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-color);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none}.data-table thead th.sortable:hover{background:var(--color-gray-100);color:var(--text-primary)}.data-table thead th .sort-icon{display:inline-block;margin-left:4px;opacity:.4}.data-table thead th.sort-asc .sort-icon,.data-table thead th.sort-desc .sort-icon{opacity:1}.data-table tbody tr{border-bottom:1px solid var(--border-color);transition:background var(--transition-fast)}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background:var(--color-gray-50)}.data-table tbody td{padding:var(--space-3) var(--space-4);color:var(--text-primary);vertical-align:middle}.data-table .td-muted{color:var(--text-muted);font-size:var(--text-xs)}.data-table .td-primary{font-weight:var(--font-medium)}.table-actions{display:flex;align-items:center;gap:var(--space-1)}.table-link{color:var(--color-primary-600);font-weight:var(--font-medium);cursor:pointer}.table-link:hover{color:var(--color-primary-700);text-decoration:underline}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a99;z-index:200;display:flex;align-items:center;justify-content:center;padding:var(--space-4);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn var(--transition-fast)}.modal{background:#fff;border-radius:var(--border-radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp var(--transition-normal)}.modal-lg{max-width:780px}.modal-xl{max-width:960px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color);flex-shrink:0}.modal-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary)}.modal-body{padding:var(--space-5) var(--space-6);overflow-y:auto;flex:1}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);flex-shrink:0}.close-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius);color:var(--text-muted);transition:all var(--transition-fast);font-size:18px;line-height:1}.close-btn:hover{background:var(--color-gray-100);color:var(--text-primary)}#toast-container{position:fixed;bottom:var(--space-6);right:var(--space-6);z-index:300;display:flex;flex-direction:column;gap:var(--space-2);pointer-events:none}.toast{display:flex;align-items:flex-start;gap:var(--space-3);background:#fff;border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-lg);min-width:280px;max-width:400px;pointer-events:all;animation:slideInRight var(--transition-normal);transition:opacity var(--transition-normal),transform var(--transition-normal)}.toast.hiding{opacity:0;transform:translate(20px)}.toast-icon{width:18px;height:18px;flex-shrink:0;margin-top:1px}.toast-content{flex:1}.toast-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.toast-message{font-size:var(--text-xs);color:var(--text-muted);margin-top:2px}.toast-success{border-left:3px solid var(--color-success)}.toast-error{border-left:3px solid var(--color-danger)}.toast-warning{border-left:3px solid var(--color-warning)}.toast-info{border-left:3px solid var(--color-primary-500)}.stat-card{background:#fff;border:1px solid var(--border-color);border-radius:var(--border-radius-lg);padding:var(--space-5);display:flex;align-items:flex-start;gap:var(--space-4);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast)}.stat-card:hover{box-shadow:var(--shadow-md)}.stat-icon{width:44px;height:44px;border-radius:var(--border-radius);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon.blue{background:var(--color-primary-100);color:var(--color-primary-600)}.stat-icon.green{background:var(--color-success-light);color:var(--color-success)}.stat-icon.orange{background:var(--color-orange-light);color:var(--color-orange)}.stat-icon.red{background:var(--color-danger-light);color:var(--color-danger)}.stat-icon.cyan{background:var(--color-cyan-light);color:var(--color-cyan)}.stat-icon.teal{background:var(--color-teal-light);color:var(--color-teal)}.stat-info{flex:1}.stat-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--text-primary);line-height:1.2}.stat-label{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}.stat-change{font-size:var(--text-xs);margin-top:var(--space-1)}.stat-change.up{color:var(--color-success)}.stat-change.down{color:var(--color-danger)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.filter-bar{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-4)}.search-input-wrap{position:relative;flex:1;min-width:200px;max-width:320px}.search-input-wrap svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.search-input{width:100%;padding:var(--space-2) var(--space-3) var(--space-2) var(--space-8);border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:var(--text-sm);color:var(--text-primary);background:#fff;transition:border-color var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f61a}.filter-select{padding:var(--space-2) var(--space-3);border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:var(--text-sm);color:var(--text-primary);background:#fff;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:28px;transition:border-color var(--transition-fast)}.filter-select:focus{outline:none;border-color:var(--border-focus)}.pagination{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-color)}.pagination-info{font-size:var(--text-sm);color:var(--text-muted)}.pagination-controls{display:flex;align-items:center;gap:var(--space-1)}.page-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius);font-size:var(--text-sm);color:var(--text-secondary);transition:all var(--transition-fast);cursor:pointer;border:1px solid transparent}.page-btn:hover{background:var(--color-gray-100)}.page-btn.active{background:var(--color-primary-600);color:#fff;border-color:var(--color-primary-600)}.page-btn:disabled{opacity:.4;cursor:not-allowed}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);text-align:center}.empty-state-icon{width:64px;height:64px;background:var(--color-gray-100);border-radius:var(--border-radius-xl);display:flex;align-items:center;justify-content:center;color:var(--color-gray-400);margin-bottom:var(--space-4)}.empty-state h3{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--text-sm);color:var(--text-muted);max-width:360px;margin-bottom:var(--space-5)}.loading-state{display:flex;align-items:center;justify-content:center;padding:var(--space-12)}.spinner{width:32px;height:32px;border:3px solid var(--color-gray-200);border-top-color:var(--color-primary-500);border-radius:50%;animation:spin .8s linear infinite}.spinner.sm{width:16px;height:16px;border-width:2px}.tabs{display:flex;border-bottom:2px solid var(--border-color);gap:0;margin-bottom:var(--space-6)}.tab-btn{padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-2px;transition:all var(--transition-fast);cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:var(--space-2)}.tab-btn:hover{color:var(--text-primary)}.tab-btn.active{color:var(--color-primary-600);border-bottom-color:var(--color-primary-600)}.tab-count{background:var(--color-gray-200);color:var(--text-secondary);font-size:10px;padding:1px 5px;border-radius:var(--border-radius-full)}.tab-btn.active .tab-count{background:var(--color-primary-100);color:var(--color-primary-700)}.timeline{display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;gap:var(--space-3);position:relative}.timeline-item:not(:last-child):before{content:"";position:absolute;left:15px;top:32px;bottom:-4px;width:1px;background:var(--border-color)}.timeline-icon{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;font-size:14px;border:2px solid white;box-shadow:0 0 0 1px var(--border-color)}.timeline-icon.note{background:var(--color-gray-100);color:var(--color-gray-500)}.timeline-icon.call{background:var(--color-success-light);color:var(--color-success)}.timeline-icon.email{background:var(--color-primary-100);color:var(--color-primary-600)}.timeline-icon.meeting{background:var(--color-cyan-light);color:var(--color-cyan)}.timeline-icon.status_change{background:var(--color-orange-light);color:var(--color-orange)}.timeline-icon.task{background:var(--color-warning-light);color:var(--color-warning)}.timeline-icon.other{background:var(--color-gray-100);color:var(--color-gray-500)}.timeline-content{flex:1;padding-bottom:var(--space-4)}.timeline-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.timeline-title{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--text-primary)}.timeline-time{font-size:var(--text-xs);color:var(--text-muted)}.timeline-body{font-size:var(--text-sm);color:var(--text-secondary);line-height:1.5}.timeline-author{font-size:var(--text-xs);color:var(--text-muted);margin-top:4px}.progress-bar-wrap{background:var(--color-gray-100);border-radius:var(--border-radius-full);height:8px;overflow:hidden}.progress-bar{height:100%;border-radius:var(--border-radius-full);background:var(--color-primary-500);transition:width var(--transition-slow)}.progress-bar.green{background:var(--color-success)}.progress-bar.orange{background:var(--color-orange)}.progress-bar.red{background:var(--color-danger)}.progress-bar-lg .progress-bar-wrap{height:12px}.divider{height:1px;background:var(--border-color);margin:var(--space-4) 0}.tag{display:inline-flex;align-items:center;gap:4px;padding:2px var(--space-2);background:var(--color-gray-100);color:var(--color-gray-600);border-radius:var(--border-radius-full);font-size:var(--text-xs);font-weight:var(--font-medium)}.tag-input-wrap{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-2);border:1px solid var(--border-color);border-radius:var(--border-radius);background:#fff;cursor:text;min-height:42px;align-items:center;transition:border-color var(--transition-fast)}.tag-input-wrap:focus-within{border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f61a}.tag-input{border:none;outline:none;font-size:var(--text-sm);background:transparent;flex:1;min-width:80px;color:var(--text-primary)}.tag-remove{cursor:pointer;opacity:.6;font-size:12px;line-height:1}.tag-remove:hover{opacity:1}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.detail-label{font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.detail-value{font-size:var(--text-sm);color:var(--text-primary);word-break:break-word}.detail-value.large{font-size:var(--text-xl);font-weight:var(--font-bold)}.status-stepper{display:flex;align-items:center;gap:0;overflow-x:auto;padding:var(--space-1)}.step{display:flex;flex-direction:column;align-items:center;gap:4px;position:relative;flex:1;min-width:80px;cursor:pointer;padding:var(--space-2);border-radius:var(--border-radius);transition:background var(--transition-fast)}.step:hover{background:var(--color-gray-50)}.step-circle{width:28px;height:28px;border-radius:50%;border:2px solid var(--color-gray-300);background:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:var(--font-semibold);color:var(--color-gray-400);transition:all var(--transition-fast);z-index:1;position:relative}.step.completed .step-circle{background:var(--color-success);border-color:var(--color-success);color:#fff}.step.active .step-circle{background:var(--color-primary-600);border-color:var(--color-primary-600);color:#fff;box-shadow:0 0 0 3px #3b82f633}.step-label{font-size:10px;font-weight:var(--font-medium);color:var(--text-muted);text-align:center;white-space:nowrap}.step.active .step-label{color:var(--color-primary-600);font-weight:var(--font-semibold)}.step.completed .step-label{color:var(--color-success)}.step-line{flex:1;height:2px;background:var(--color-gray-200);margin-top:-20px;z-index:0}.step-line.completed{background:var(--color-success)}.drawer{position:fixed;top:0;right:0;bottom:0;width:480px;background:#fff;box-shadow:var(--shadow-xl);z-index:200;display:flex;flex-direction:column;transform:translate(100%);transition:transform var(--transition-normal)}.drawer.open{transform:translate(0)}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;z-index:199;display:none}.drawer-overlay.show{display:block}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-color);flex-shrink:0}.drawer-title{font-size:var(--text-lg);font-weight:var(--font-semibold)}.drawer-body{flex:1;overflow-y:auto;padding:var(--space-5) var(--space-6)}.drawer-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-color);display:flex;gap:var(--space-3);justify-content:flex-end}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 1024px){.sidebar{width:var(--sidebar-collapsed-width)}.sidebar .nav-item-label,.sidebar .nav-badge,.sidebar .sidebar-logo-text,.sidebar .nav-section-label,.sidebar .user-info{display:none}.sidebar-logo{justify-content:center;padding:var(--space-4) var(--space-3)}.nav-item{justify-content:center;padding:var(--space-3)}.sidebar-user{justify-content:center;padding:var(--space-2) var(--space-3)}.main-content{margin-left:var(--sidebar-collapsed-width)}.form-grid{grid-template-columns:1fr}.form-grid-3{grid-template-columns:1fr 1fr}.detail-grid{grid-template-columns:1fr}}@media (max-width: 768px){.sidebar{transform:translate(-100%);position:fixed;width:var(--sidebar-width)!important}.sidebar .nav-item-label,.sidebar .nav-badge,.sidebar .sidebar-logo-text,.sidebar .nav-section-label,.sidebar .user-info{display:flex!important;opacity:1!important;width:auto!important}.sidebar .nav-item{justify-content:flex-start!important;padding:var(--space-2) var(--space-3)!important}.sidebar .sidebar-user{justify-content:flex-start!important}.sidebar .sidebar-logo{justify-content:flex-start!important;padding:var(--space-5) var(--space-4)!important}.sidebar.mobile-open{transform:translate(0)}.sidebar-overlay{display:none}.sidebar-overlay.show{display:block}.main-content{margin-left:0!important}.hamburger-btn{display:flex}.stats-grid{grid-template-columns:1fr 1fr}.page-content{padding:var(--space-4)}.topbar{padding:0 var(--space-4)}.form-grid,.form-grid-3{grid-template-columns:1fr}.drawer{width:100%}.modal{max-width:100%;border-radius:var(--border-radius-lg)}.filter-bar{flex-direction:column;align-items:stretch}.search-input-wrap{max-width:100%}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.tabs{overflow-x:auto;flex-wrap:nowrap}}
