:root{--primary: #0052cc;--primary-hover: #0047b3;--bg-color: #f8fafc;--surface: #ffffff;--text-main: #0f172a;--text-muted: #64748b;--border: #e2e8f0;--success: #16a34a;--warning: #d97706;--danger: #dc2626;--info: #2563eb;--radius-sm: 3px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg-color);color:var(--text-main);line-height:1.5;-webkit-font-smoothing:antialiased}a{text-decoration:none;color:inherit}button{cursor:pointer;border:none;background:none;font-family:inherit}.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.flex-col{flex-direction:column}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.grid{display:grid}.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)}.w-full{width:100%}.h-full{height:100%}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.text-4xl{font-size:2.25rem}.font-medium{font-weight:500}.font-bold{font-weight:700}.text-muted{color:var(--text-muted)}.text-primary{color:var(--primary)}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.card{background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);padding:1.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.45rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;transition:background .15s,color .15s,border-color .15s;gap:.4rem}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-outline{border:1px solid var(--border);background:var(--surface);color:var(--text-main)}.btn-outline:hover{border-color:#94a3b8}.btn-outline.btn-hover-primary:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-ghost{color:var(--text-muted)}.btn-ghost:hover{background:var(--bg-color);color:var(--text-main)}.badge{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600;letter-spacing:.02em;background:var(--bg-color);color:var(--text-muted)}.badge.success{background:#f0fdf4;color:#15803d}.badge.warning{background:#fffbeb;color:#b45309}.badge.danger{background:#fef2f2;color:#b91c1c}.badge.info{background:#eff6ff;color:#1d4ed8}.navbar{height:56px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;position:sticky;top:0;z-index:50}.nav-link{color:var(--text-muted);font-size:.875rem;font-weight:500;transition:color .15s}.nav-link:hover,.nav-link.active{color:var(--text-main)}.table-container{width:100%;overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}th{font-weight:600;color:var(--text-muted);font-size:.8rem}.dashboard-layout{display:flex;min-height:calc(100vh - 64px)}.sidebar{width:320px;background:var(--surface);border-left:1px solid var(--border);padding:1.5rem}.main-content{flex:1;padding:2rem;overflow-y:auto}.trend-up{color:var(--success);display:flex;align-items:center;gap:.25rem;font-size:.875rem}.trend-down{color:var(--danger);display:flex;align-items:center;gap:.25rem;font-size:.875rem}.avatar{width:40px;height:40px;border-radius:var(--radius-full);background:var(--border);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--text-muted);overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1.5rem;gap:.25rem}.tab{padding:.6rem 1rem;font-size:.875rem;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:color .15s}.tab.active{color:var(--text-main);border-bottom-color:var(--text-main)}.progress-bg{width:100%;height:6px;background:var(--border);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;border-radius:var(--radius-full)}body.dark-mode{--bg-color: #0f172a;--surface: #1e293b;--text-main: #e2e8f0;--text-muted: #94a3b8;--border: #334155;--primary: #3b82f6;--primary-hover: #2563eb;background-color:#0f172a;color:#e2e8f0}body.dark-mode .navbar{background:#1e293b!important;border-bottom-color:#334155!important}body.dark-mode .card{background:#1e293b!important;border-color:#334155!important;color:#e2e8f0!important}body.dark-mode main{background:#0f172a!important}body.dark-mode *[style*="background: white"],body.dark-mode *[style*="background: #ffffff"],body.dark-mode *[style*="background: rgb(255, 255, 255)"],body.dark-mode *[style*="background-color: white"],body.dark-mode *[style*="background-color: #ffffff"],body.dark-mode *[style*="background-color: rgb(255, 255, 255)"]{background:#1e293b!important;border-color:#334155!important}body.dark-mode *[style*="background: #f8fafc"],body.dark-mode *[style*="background: rgb(248, 250, 252)"],body.dark-mode *[style*="background: #fafafa"],body.dark-mode *[style*="background: rgb(250, 250, 250)"],body.dark-mode *[style*="background: #f1f5f9"],body.dark-mode *[style*="background: rgb(241, 245, 249)"],body.dark-mode *[style*="background-color: #f8fafc"],body.dark-mode *[style*="background-color: rgb(248, 250, 252)"],body.dark-mode *[style*="background-color: #f1f5f9"],body.dark-mode *[style*="background-color: rgb(241, 245, 249)"]{background:#0f172a!important}body.dark-mode *[style*="color: #0f172a"],body.dark-mode *[style*="color: rgb(15, 23, 42)"],body.dark-mode *[style*="color: #1e293b"],body.dark-mode *[style*="color: rgb(30, 41, 59)"],body.dark-mode *[style*="color: #334155"],body.dark-mode *[style*="color: rgb(51, 65, 85)"]{color:#e2e8f0!important}body.dark-mode *[style*="color: #475569"],body.dark-mode *[style*="color: rgb(71, 85, 105)"],body.dark-mode *[style*="color: #64748b"],body.dark-mode *[style*="color: rgb(100, 116, 139)"]{color:#94a3b8!important}body.dark-mode *[style*="border: 1px solid #e2e8f0"],body.dark-mode *[style*="border: 1px solid rgb(226, 232, 240)"],body.dark-mode *[style*="border-bottom: 1px solid #e2e8f0"],body.dark-mode *[style*="border-bottom: 1px solid rgb(226, 232, 240)"],body.dark-mode *[style*="border-bottom: 2px solid #e2e8f0"],body.dark-mode *[style*="border-bottom: 2px solid rgb(226, 232, 240)"],body.dark-mode *[style*="border-bottom: 1px solid #f1f5f9"],body.dark-mode *[style*="border-bottom: 1px solid rgb(241, 245, 249)"],body.dark-mode *[style*="border-top: 1px solid #e2e8f0"],body.dark-mode *[style*="border-top: 1px solid rgb(226, 232, 240)"],body.dark-mode *[style*="border-right: 1px solid #e2e8f0"],body.dark-mode *[style*="border-right: 1px solid rgb(226, 232, 240)"],body.dark-mode *[style*="border-left: 1px solid #e2e8f0"],body.dark-mode *[style*="border-left: 1px solid rgb(226, 232, 240)"]{border-color:#334155!important}body.dark-mode th{color:#94a3b8!important;background:#1e293b!important;border-bottom-color:#334155!important}body.dark-mode td{border-bottom-color:#334155!important}body.dark-mode input,body.dark-mode select{background:#1e293b!important;border-color:#334155!important;color:#e2e8f0!important}body.dark-mode ::-webkit-scrollbar-track{background:#0f172a}body.dark-mode ::-webkit-scrollbar-thumb{background:#334155;border-radius:4px}body.dark-mode .recharts-default-tooltip{background:#1e293b!important;border-color:#334155!important;color:#e2e8f0!important}body.dark-mode .recharts-tooltip-label{color:#94a3b8!important}body.dark-mode .recharts-tooltip-item{color:#e2e8f0!important}body.dark-mode tbody tr:hover{background:#33415559!important}body.dark-mode *[style*="background: rgb(220, 252, 231)"],body.dark-mode *[style*="background: #dcfce7"]{background:#16a34a26!important;color:#4ade80!important}body.dark-mode *[style*="background: rgb(255, 247, 237)"],body.dark-mode *[style*="background: #fff7ed"]{background:#ea580c26!important;color:#fb923c!important}body.dark-mode *[style*="background: rgb(243, 244, 246)"],body.dark-mode *[style*="background: #f3f4f6"]{background:#4755694d!important;color:#94a3b8!important}body.dark-mode *[style*="background: rgb(239, 246, 255)"],body.dark-mode *[style*="background: #eff6ff"]{background:#3b82f626!important}body.dark-mode *[style*="background: rgb(240, 253, 244)"],body.dark-mode *[style*="background: #f0fdf4"]{background:#16a34a1a!important}body.dark-mode *[style*="background: rgb(254, 242, 242)"],body.dark-mode *[style*="background: #fef2f2"]{background:#ef44441a!important}body.dark-mode *[style*="color: #374151"],body.dark-mode *[style*="color: rgb(55, 65, 81)"]{color:#e2e8f0!important}body.dark-mode *[style*="border: 1.5px solid #e2e8f0"],body.dark-mode *[style*="border: 1.5px solid rgb(226, 232, 240)"]{border-color:#334155!important}.navbar-mobile{display:none;position:relative;flex-wrap:wrap;height:auto;min-height:56px}.navbar-desktop{display:flex}@media (max-width: 767px){.navbar-desktop{display:none}.navbar-mobile{display:flex;flex-direction:column;align-items:stretch}.navbar-mobile>.flex{width:100%;min-height:56px;align-items:center}.main-content{padding:1rem}.container{padding:0 .75rem}.card{padding:1rem}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}th,td{padding:.65rem .75rem;font-size:.8rem}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;gap:0}.tab{white-space:nowrap;padding:.6rem .85rem;font-size:.8rem}.dashboard-layout{flex-direction:column}.sidebar{width:100%;border-left:none;border-top:1px solid var(--border);padding:1rem}.text-3xl{font-size:1.5rem}.text-4xl{font-size:1.875rem}.gap-8{gap:1rem}.gap-6{gap:.75rem}}@media (max-width: 768px){body{overflow-x:hidden}.dash-main{padding:1rem!important}.dash-summary-grid{grid-template-columns:repeat(2,1fr)!important;gap:.75rem!important}.dash-summary-card{padding:1rem .85rem!important}.dash-date-range{flex-wrap:nowrap!important;overflow-x:auto!important;-webkit-overflow-scrolling:touch;gap:.4rem!important}.dash-building-header{flex-direction:column!important;align-items:flex-start!important;gap:.75rem!important}.dash-viz-scroll{overflow-x:auto!important;-webkit-overflow-scrolling:touch}.dash-viz-inner{min-width:500px!important}.dash-charts-row{grid-template-columns:1fr!important;gap:1rem!important}.dash-ai-grid{grid-template-columns:1fr!important;gap:1.5rem!important}}@media (max-width: 768px){.login-left-panel{display:none!important}.login-right-panel{padding:2rem 1rem!important}}@media (max-width: 768px){.dir-page-header{flex-direction:column!important;align-items:flex-start!important;gap:.75rem!important}.dir-search{max-width:100%!important}.dir-search input{font-size:16px!important}.dir-contact-grid{grid-template-columns:1fr!important;gap:.75rem!important}.dir-contact-card{padding:1rem!important}.dir-contact-card .avatar{width:36px!important;height:36px!important;font-size:.75rem!important;flex-shrink:0!important}.dir-contact-card .btn{min-height:44px!important}.dir-contact-card .flex.items-center.gap-2.text-sm{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;min-width:0}.dir-modal-card{width:calc(100vw - 2rem)!important;max-width:400px!important}}
