@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Inter:wght@400;500;600;700;800&display=swap");:root{--primary:#6366F1;--primary-container:#4F46E5;--primary-fixed-dim:#818CF8;--bg:#F8FAFC;--surface:#F8FAFC;--surface-2:#F1F5F9;--surface-3:#E2E8F0;--surface-4:#CBD5E1;--surface-card:#FFFFFF;--border:rgba(15,23,42,0.08);--border-light:rgba(15,23,42,0.04);--status-open:#3B82F6;--status-progress:#F59E0B;--status-done:#10B981;--status-cancel:#EF4444;--text-1:#0F172A;--text-2:#475569;--text-3:#94A3B8;--text-inv:#FFFFFF;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--radius-round:9999px;--shadow-sm:0 4px 12px rgba(15,23,42,0.04);--shadow-md:0 12px 24px rgba(15,23,42,0.06);--shadow-lg:0 20px 40px rgba(15,23,42,0.08)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text-1);-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-family:Manrope,-apple-system,BlinkMacSystemFont,sans-serif}.admin-layout{display:flex;min-height:100vh}.sidebar{width:260px;background:var(--text-1);color:var(--text-inv);padding:24px 0;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-brand{gap:12px;padding:0 24px 24px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:16px}.sidebar-brand,.sidebar-logo{display:flex;align-items:center}.sidebar-logo{width:40px;height:40px;border-radius:12px;background:var(--primary);justify-content:center;font-size:20px;font-weight:800;color:white}.sidebar-brand-name{font-size:20px;font-weight:700}.sidebar-brand-sub{font-size:11px;color:var(--text-3)}.sidebar-nav{flex:1 1;padding:0 12px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-md);color:rgba(255,255,255,.65);text-decoration:none;font-size:14px;font-weight:500;transition:all .2s;margin-bottom:2px;cursor:pointer}.sidebar-link:hover{background:rgba(255,255,255,.08);color:white}.sidebar-link.active{background:linear-gradient(135deg,var(--primary) 0,var(--primary-container) 100%);color:white;font-weight:600}.sidebar-link-icon{font-size:18px;width:24px;text-align:center}.main-content{margin-left:260px;flex:1 1;padding:32px;min-height:100vh}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.page-title{font-size:28px;font-weight:800;color:var(--text-1)}.page-subtitle{font-size:14px;color:var(--text-2);margin-top:4px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:var(--surface-card);border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card-header{justify-content:space-between;margin-bottom:16px}.stat-card-header,.stat-icon{display:flex;align-items:center}.stat-icon{width:44px;height:44px;border-radius:12px;justify-content:center;font-size:22px}.stat-trend{font-size:12px;font-weight:600;padding:4px 8px;border-radius:var(--radius-round)}.stat-trend.up{background:var(--primary-light);color:var(--primary)}.stat-value{font-size:32px;font-weight:800;color:var(--text-1);margin-bottom:4px}.stat-label{font-size:13px;color:var(--text-2);font-weight:500}.dashboard-grid{display:grid;grid-template-columns:2fr 1fr;gap:24px;margin-bottom:32px}.chart-card{background:var(--surface-card);border-radius:var(--radius-xl);padding:24px;box-shadow:var(--shadow-sm)}.activity-feed{display:flex;flex-direction:column;gap:16px;max-height:400px;overflow-y:auto;padding-right:8px}.activity-item{display:flex;gap:12px;padding:12px;border-radius:var(--radius-md);transition:background .2s}.activity-item:hover{background:var(--surface-2)}.activity-icon{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:white}.activity-icon.bg-blue{background:#3B82F6}.activity-icon.bg-green{background:#10B981}.activity-icon.bg-purple{background:#8B5CF6}.activity-icon.bg-yellow{background:#F59E0B}.activity-content{flex:1 1}.activity-title{font-size:13px;font-weight:600;color:var(--text-1);margin-bottom:2px}.activity-desc{font-size:12px;color:var(--text-2)}.activity-time{font-size:11px;color:var(--text-3);white-space:nowrap}.table-card{background:var(--surface-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);overflow:hidden;border:none}.table-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.table-title{font-size:18px;font-weight:700}.table-search{padding:8px 16px;border:1px solid var(--border);border-radius:var(--radius-round);font-size:14px;width:280px;outline:none;transition:border-color .2s;font-family:inherit}.table-search:focus{border-color:var(--primary)}table{width:100%;border-collapse:collapse}thead th{text-align:left;padding:12px 24px;font-size:12px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--surface-2)}tbody td{padding:16px 24px;font-size:14px;color:var(--text-1);border-bottom:1px solid var(--border-light)}tbody tr{transition:background .15s}tbody tr:hover{background:var(--surface-2)}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:var(--radius-round);font-size:12px;font-weight:600}.badge-dot{width:6px;height:6px;border-radius:3px}.badge-open{background:#D1FAE5;color:#059669}.badge-open .badge-dot{background:#059669}.badge-progress{background:#FEF3C7;color:#D97706}.badge-progress .badge-dot{background:#D97706}.badge-done{background:#D1FAE5;color:#047857}.badge-done .badge-dot{background:#047857}.badge-cancel{background:#FEE2E2;color:#DC2626}.badge-cancel .badge-dot{background:#DC2626}.badge-customer{background:#EDE9FE;color:#7C3AED}.badge-contractor{background:#DBEAFE;color:#2563EB}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;border:none;transition:all .2s;font-family:inherit}.btn-primary{background:linear-gradient(135deg,var(--primary) 0,var(--primary-container) 100%);color:white}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-container) 0,var(--primary-fixed-dim) 100%);box-shadow:var(--shadow-md);transform:scale(.98)}.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border)}.btn-ghost:hover{background:var(--surface-2)}.btn-danger{background:#FEE2E2;color:#DC2626}.btn-danger:hover{background:#FCA5A5}.avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}.avatar-green{background:var(--surface-2);color:var(--primary-container)}.avatar-purple{background:#EDE9FE;color:#7C3AED}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease-out}.modal-content{background:var(--surface);border-radius:var(--radius-xl);padding:32px;box-shadow:var(--shadow-lg);max-height:90vh;overflow-y:auto;animation:slideUp .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}