*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #2563eb;--primary-light: #3b82f6;--primary-dark: #1d4ed8;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg-page: #f8fafc;--bg-card: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--border: #e2e8f0;--border-light: #f1f5f9}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,sans-serif;font-size:14px;color:var(--text-primary);background:var(--bg-page);line-height:1.6}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;box-shadow:2px 0 8px #00000005}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:24px 20px;border-bottom:1px solid var(--border)}.brand-icon{width:40px;height:40px;background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:18px;box-shadow:0 4px 12px #2563eb4d}.brand-name{font-size:16px;font-weight:600;color:var(--text-primary)}.brand-tenant{font-size:12px;color:var(--text-muted)}.sidebar-nav{padding:16px 12px;flex:1}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;color:var(--text-secondary);font-size:14px;text-decoration:none;margin-bottom:4px;transition:all .2s}.nav-item:hover{background:#f1f5f9;color:var(--text-primary)}.nav-item.active{background:#eff6ff;color:var(--primary);font-weight:500}.user-card{display:flex;align-items:center;gap:12px;padding:16px 20px;border-top:1px solid var(--border);background:#f8fafc}.user-avatar{width:36px;height:36px;background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px}.user-name{font-size:14px;font-weight:500;color:var(--text-primary)}.logout-btn{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:8px;border-radius:6px;transition:all .2s}.logout-btn:hover{color:var(--danger);background:#fee2e2}.main{flex:1;background:var(--bg-page);overflow-y:auto}.page-container{padding:24px;max-width:1400px;margin:0 auto}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:20px}.login-card{width:100%;max-width:400px;padding:40px;background:#fff;border-radius:20px;box-shadow:0 10px 40px #00000014}.login-logo{width:64px;height:64px;background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-size:28px;color:#fff;box-shadow:0 8px 20px #2563eb4d}.login-title{font-size:22px;font-weight:600;text-align:center;margin-bottom:8px;color:var(--text-primary)}.login-desc{font-size:14px;color:var(--text-muted);text-align:center;margin-bottom:32px}.form-group{margin-bottom:20px}.form-label{display:block;font-size:13px;font-weight:500;margin-bottom:8px;color:var(--text-primary)}.form-input,.input{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:10px;font-size:14px;transition:all .2s;background:#f8fafc}.form-input:focus,.input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 4px #2563eb1a}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:10px;font-size:14px;font-weight:500;border:none;cursor:pointer;text-decoration:none;transition:all .2s}.btn-primary{background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#1d4ed8,#2563eb);box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}.btn-success{background:linear-gradient(135deg,#10b981,#34d399);color:#fff}.btn-success:hover{box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.btn-danger{background:linear-gradient(135deg,#ef4444,#f87171);color:#fff}.btn-danger:hover{box-shadow:0 4px 12px #ef44444d;transform:translateY(-1px)}.btn-secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:#f8fafc;border-color:var(--text-muted)}.btn-ghost{background:transparent;border:none;color:var(--text-secondary);padding:8px}.btn-ghost:hover{background:#f1f5f9;color:var(--text-primary)}.btn-full{width:100%}.btn-sm{padding:8px 16px;font-size:13px}.card{background:#fff;border-radius:16px;border:1px solid var(--border);padding:20px;margin-bottom:16px;box-shadow:0 2px 8px #0000000a;transition:all .2s}.card:hover{box-shadow:0 4px 16px #00000014}.card.cursor-pointer{cursor:pointer}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}.stat{background:#fff;border-radius:16px;border:1px solid var(--border);padding:24px;text-align:center;box-shadow:0 2px 8px #0000000a;transition:all .2s}.stat:hover{transform:translateY(-2px);box-shadow:0 8px 24px #00000014}.stat-num{font-size:32px;font-weight:700;background:linear-gradient(135deg,#2563eb,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stat-text{font-size:13px;color:var(--text-muted);margin-top:8px}.list-item{display:flex;align-items:center;gap:16px;padding:16px 20px;background:#fff;border-radius:14px;border:1px solid var(--border);margin-bottom:12px;box-shadow:0 2px 8px #0000000a;cursor:pointer;transition:all .2s}.list-item:hover{border-color:var(--primary);box-shadow:0 4px 16px #2563eb1a;transform:translate(4px)}.item-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#eff6ff,#dbeafe);color:var(--primary)}.item-content{flex:1;min-width:0}.item-title{font-size:15px;font-weight:500;color:var(--text-primary)}.item-desc{font-size:13px;color:var(--text-muted);margin-top:4px}.tag{display:inline-flex;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500}.tag-green{background:#d1fae5;color:#065f46}.tag-yellow{background:#fef3c7;color:#92400e}.tag-red{background:#fee2e2;color:#991b1b}.tag-blue{background:#dbeafe;color:#1e40af}.tag-gray{background:#f1f5f9;color:#64748b}.modal-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:#fff;border-radius:20px;width:100%;max-width:480px;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #0003}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);font-size:18px;font-weight:600}.modal-body{padding:24px;overflow-y:auto;max-height:60vh}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:12px;background:#f8fafc}.empty{text-align:center;padding:60px 24px}.empty-icon{width:72px;height:72px;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:28px;color:var(--text-muted)}.empty-title{font-size:16px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.empty-text{font-size:14px;color:var(--text-muted)}.divider{height:1px;background:var(--border);margin:16px 0}.flex{display:flex}.flex-col{flex-direction:column}.flex-1{flex:1}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:4px}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.gap-6{gap:24px}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.col-span-2{grid-column:span 2}.col-span-3{grid-column:span 3}.col-span-full{grid-column:1 / -1}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh}.min-w-0{min-width:0}.p-1{padding:4px}.p-2{padding:8px}.p-3{padding:12px}.p-4{padding:16px}.p-6{padding:24px}.px-2{padding-left:8px;padding-right:8px}.px-3{padding-left:12px;padding-right:12px}.px-4{padding-left:16px;padding-right:16px}.py-1{padding-top:4px;padding-bottom:4px}.py-2{padding-top:8px;padding-bottom:8px}.py-3{padding-top:12px;padding-bottom:12px}.py-4{padding-top:16px;padding-bottom:16px}.py-12{padding-top:48px;padding-bottom:48px}.m-0{margin:0}.m-auto{margin:auto}.mb-1{margin-bottom:4px}.mb-2{margin-bottom:8px}.mb-3{margin-bottom:12px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.ml-1{margin-left:4px}.ml-2{margin-left:8px}.mr-1{margin-right:4px}.mr-2{margin-right:8px}.mx-auto{margin-left:auto;margin-right:auto}.text-xs{font-size:11px}.text-sm{font-size:13px}.text-base{font-size:14px}.text-lg{font-size:16px}.text-xl{font-size:18px}.text-2xl{font-size:20px}.text-3xl{font-size:24px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-center{text-align:center}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.text-white{color:#fff}.text-slate-500{color:#64748b}.text-slate-600{color:#475569}.text-red-400{color:#f87171}.text-red-500{color:#ef4444}.text-red-600{color:#dc2626}.text-green-500{color:#22c55e}.text-green-600{color:#16a34a}.text-blue-500{color:#3b82f6}.text-blue-600{color:#2563eb}.text-cyan-500{color:#06b6d4}.text-amber-500{color:#f59e0b}.text-purple-500{color:#a855f7}.bg-white{background:#fff}.bg-slate-50{background:#f8fafc}.bg-slate-100{background:#f1f5f9}.bg-blue-500{background:#3b82f6}.bg-green-500{background:#22c55e}.bg-red-500{background:#ef4444}.bg-blue-100{background:#dbeafe}.bg-green-100{background:#dcfce7}.bg-red-100{background:#fee2e2}.bg-amber-100{background:#fef3c7}.rounded{border-radius:6px}.rounded-lg{border-radius:10px}.rounded-xl{border-radius:12px}.rounded-2xl{border-radius:16px}.rounded-full{border-radius:9999px}.border{border:1px solid var(--border)}.border-b{border-bottom:1px solid var(--border)}.border-t{border-top:1px solid var(--border)}.w-4{width:16px}.w-5{width:20px}.w-6{width:24px}.w-8{width:32px}.w-10{width:40px}.w-12{width:48px}.w-16{width:64px}.h-4{height:16px}.h-5{height:20px}.h-6{height:24px}.h-8{height:32px}.h-10{height:40px}.h-12{height:48px}.h-16{height:64px}.h-64{height:256px}.cursor-pointer{cursor:pointer}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.opacity-50{opacity:.5}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.transition-all{transition:all .2s}.space-y-2>*+*{margin-top:8px}.space-y-3>*+*{margin-top:12px}.space-y-4>*+*{margin-top:16px}.space-y-6>*+*{margin-top:24px}@media (max-width: 768px){.sidebar{display:none}.page-container{padding:16px}.stats{grid-template-columns:repeat(2,1fr);gap:12px}.main{padding-bottom:80px}.login-card{padding:24px}.mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);padding:12px 0;z-index:100;box-shadow:0 -4px 12px #0000000d}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;font-size:11px;color:var(--text-muted);text-decoration:none;padding:4px}.mobile-nav-item.active{color:var(--primary)}.action-btns{position:fixed;bottom:80px;left:16px;right:16px;display:flex;gap:12px}.action-btns .btn{flex:1;padding:16px;font-size:15px}}@media (min-width: 769px){.mobile-nav{display:none}.action-btns{display:flex;gap:12px;margin-top:20px}}.hover\:bg-slate-200:hover{background:#e2e8f0}.hover\:bg-slate-100:hover{background:#f1f5f9}.page-content{padding:24px}.welcome-section{margin-bottom:24px}.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.quick-action-item{display:flex;align-items:center;gap:12px;padding:16px;background:#f8fafc;border-radius:12px;text-decoration:none;color:var(--text-primary);transition:all .2s}.quick-action-item:hover{background:#f1f5f9;transform:translateY(-2px)}.quick-action-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.quick-action-label{flex:1;font-size:14px;font-weight:500}.stat-icon{background:linear-gradient(135deg,#3b82f6,#2563eb)}.recent-list{display:flex;flex-direction:column;gap:12px}.recent-item{display:flex;align-items:center;gap:12px;padding:12px;background:#f8fafc;border-radius:10px}.recent-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center}.recent-content{flex:1}.recent-title{font-size:14px;font-weight:500;color:var(--text-primary)}.recent-meta{font-size:12px;color:var(--text-muted);margin-top:2px}@media (max-width: 768px){.quick-actions{grid-template-columns:repeat(2,1fr)}}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.loading-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:var(--primary);border-radius:50%;animation:spin 1s linear infinite}.approval-list{display:flex;flex-direction:column;gap:12px}.approval-item{display:flex;align-items:center;gap:16px;padding:16px 20px;background:#fff;border-radius:14px;border:1px solid var(--border);cursor:pointer;transition:all .2s}.approval-item:hover{border-color:var(--primary);box-shadow:0 4px 16px #2563eb1a}.approval-item:hover .arrow-icon{transform:translate(4px);color:var(--primary)}.approval-icon{width:48px;height:48px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--primary)}.approval-content{flex:1}.approval-title{font-size:15px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.approval-meta{font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:6px}.divider-dot{opacity:.5}.arrow-icon{transition:all .2s;color:var(--text-muted)}.message-list{display:flex;flex-direction:column;gap:8px}.message-item{display:flex;align-items:flex-start;gap:14px;padding:16px;background:#fff;border-radius:14px;border:1px solid var(--border);cursor:pointer;transition:all .2s;position:relative}.message-item:hover{border-color:var(--primary)}.message-item.unread{background:#f8fafc}.message-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.message-content{flex:1;min-width:0}.message-title{font-size:15px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.message-desc{font-size:13px;color:var(--text-muted);margin-bottom:6px}.message-time{font-size:12px;color:var(--text-muted)}.unread-dot{width:8px;height:8px;background:var(--primary);border-radius:50%;flex-shrink:0;margin-top:6px}.approval-actions{display:flex;gap:8px;flex-shrink:0}.template-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.template-card{background:#fff;border-radius:14px;border:1px solid var(--border);padding:20px;transition:all .2s}.template-card:hover{border-color:var(--primary);box-shadow:0 4px 16px #2563eb1a}.template-card-header{display:flex;align-items:center;gap:14px;margin-bottom:12px}.template-icon{width:48px;height:48px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--primary)}.template-info h3{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.template-info p{font-size:13px;color:var(--text-muted)}.template-card-actions{display:flex;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-light)}
