@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary:#0a0e1a;--bg-secondary:#111827;--bg-card:#1a1f35;--bg-card-hover:#222845;--bg-sidebar:#0d1225;--bg-input:#1e2440;--border-color:#2a3154;--border-focus:#6366f1;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-inverse:#0f172a;--accent:#6366f1;--accent-hover:#818cf8;--accent-glow:#6366f140;--accent-gradient:linear-gradient(135deg, #6366f1, #8b5cf6);--success:#22c55e;--success-bg:#22c55e1f;--warning:#f59e0b;--warning-bg:#f59e0b1f;--danger:#ef4444;--danger-bg:#ef44441f;--info:#3b82f6;--info-bg:#3b82f61f;--sidebar-width:260px;--sidebar-collapsed:72px;--header-height:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:20px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 24px var(--accent-glow);--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:14px}body{background:var(--bg-primary);color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;overflow-x:hidden}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border-color);z-index:100;transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;bottom:0;left:0;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-collapsed)}.sidebar-brand{height:var(--header-height);border-bottom:1px solid var(--border-color);align-items:center;gap:12px;padding:0 20px;display:flex}.sidebar-brand .logo{background:var(--accent-gradient);border-radius:var(--radius-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:16px;font-weight:800;display:flex}.sidebar-brand .brand-text{background:var(--accent-gradient);-webkit-text-fill-color:transparent;white-space:nowrap;-webkit-background-clip:text;font-size:15px;font-weight:700}.sidebar.collapsed .brand-text{display:none}.sidebar-nav{flex:1;padding:12px 8px;overflow-y:auto}.nav-section{margin-bottom:20px}.nav-section-title{text-transform:uppercase;letter-spacing:1.2px;color:var(--text-muted);margin-bottom:6px;padding:0 12px;font-size:10px;font-weight:600}.sidebar.collapsed .nav-section-title{display:none}.nav-item{border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;align-items:center;gap:12px;padding:10px 12px;font-size:13px;font-weight:500;display:flex;position:relative}.nav-item:hover{background:var(--bg-card);color:var(--text-primary)}.nav-item.active{background:var(--accent-glow);color:var(--accent-hover)}.nav-item.active:before{content:"";background:var(--accent);border-radius:0 4px 4px 0;width:3px;height:20px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.nav-item .icon{flex-shrink:0;width:20px;height:20px}.sidebar.collapsed .nav-item span:not(.icon){display:none}.nav-item .badge{background:var(--danger);color:#fff;text-align:center;border-radius:99px;min-width:20px;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:700}.main-content{margin-left:var(--sidebar-width);transition:margin-left var(--transition-base);flex-direction:column;flex:1;min-height:100vh;display:flex}.sidebar.collapsed~.main-content{margin-left:var(--sidebar-collapsed)}.header{height:var(--header-height);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#111827d9;align-items:center;gap:16px;padding:0 24px;display:flex;position:sticky;top:0}.header-search{flex:1;max-width:400px;position:relative}.header-search input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast);outline:none;padding:8px 12px 8px 36px;font-size:13px}.header-search input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow)}.header-search .search-icon{color:var(--text-muted);width:16px;height:16px;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.header-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.header-btn{border-radius:var(--radius-md);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;display:flex;position:relative}.header-btn:hover{background:var(--bg-card);color:var(--text-primary)}.header-btn .dot{background:var(--danger);border:2px solid var(--bg-secondary);border-radius:50%;width:8px;height:8px;position:absolute;top:6px;right:6px}.avatar{background:var(--accent-gradient);color:#fff;cursor:pointer;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.page{flex:1;padding:24px}.page-header{margin-bottom:24px}.page-header h1{margin-bottom:4px;font-size:24px;font-weight:700}.page-header p{color:var(--text-secondary);font-size:14px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast);padding:20px}.card:hover{box-shadow:var(--shadow-glow);border-color:#6366f14d}.card-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.card-title{color:var(--text-secondary);font-size:14px;font-weight:600}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-bottom:24px;display:grid}.kpi-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast);padding:20px;position:relative;overflow:hidden}.kpi-card:hover{box-shadow:var(--shadow-glow);border-color:#6366f14d;transform:translateY(-2px)}.kpi-card:after{content:"";background:var(--accent-gradient);border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.kpi-card.success:after{background:var(--success)}.kpi-card.warning:after{background:var(--warning)}.kpi-card.danger:after{background:var(--danger)}.kpi-card.info:after{background:var(--info)}.kpi-card .kpi-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:40px;height:40px;margin-bottom:12px;display:flex}.kpi-card .kpi-icon.accent{background:var(--accent-glow);color:var(--accent)}.kpi-card .kpi-icon.success{background:var(--success-bg);color:var(--success)}.kpi-card .kpi-icon.warning{background:var(--warning-bg);color:var(--warning)}.kpi-card .kpi-icon.danger{background:var(--danger-bg);color:var(--danger)}.kpi-card .kpi-icon.info{background:var(--info-bg);color:var(--info)}.kpi-value{margin-bottom:4px;font-size:28px;font-weight:800;line-height:1.1}.kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:500}.kpi-change{align-items:center;gap:4px;margin-top:8px;font-size:12px;font-weight:600;display:flex}.kpi-change.up{color:var(--success)}.kpi-change.down{color:var(--danger)}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;align-items:center;gap:8px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:600;display:inline-flex}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.btn-primary:hover{box-shadow:0 4px 16px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-input);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{border-color:var(--accent)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-card);color:var(--text-primary)}.btn-sm{padding:6px 12px;font-size:12px}.btn-danger{background:var(--danger);color:#fff}.table-container{border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow-x:auto}table{border-collapse:collapse;width:100%}th{text-align:left;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:12px 16px;font-size:11px;font-weight:600}td{border-bottom:1px solid var(--border-color);color:var(--text-secondary);padding:12px 16px;font-size:13px}tr:hover td{background:var(--bg-card-hover)}tr:last-child td{border-bottom:none}.badge{border-radius:99px;align-items:center;gap:4px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-open{background:var(--info-bg);color:var(--info)}.badge-resolved{background:var(--success-bg);color:var(--success)}.badge-pending{background:var(--warning-bg);color:var(--warning)}.badge-closed{color:var(--text-muted);background:#64748b1f}.badge-critical{background:var(--danger-bg);color:var(--danger)}.badge-high{color:#f97316;background:#f973161f}.badge-medium{background:var(--warning-bg);color:var(--warning)}.badge-low{background:var(--success-bg);color:var(--success)}.form-group{margin-bottom:16px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast);outline:none;padding:10px 14px;font-family:inherit;font-size:13px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow)}.form-textarea{resize:vertical;min-height:80px}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle, var(--accent-glow), transparent 70%);border-radius:50%;width:500px;height:500px;animation:4s ease-in-out infinite pulse-glow;position:absolute;top:-100px;right:-100px}.login-page:after{content:"";background:radial-gradient(circle,#8b5cf626,#0000 70%);border-radius:50%;width:400px;height:400px;animation:5s ease-in-out infinite reverse pulse-glow;position:absolute;bottom:-80px;left:-80px}@keyframes pulse-glow{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.login-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);z-index:1;width:400px;box-shadow:var(--shadow-lg);padding:40px;position:relative}.login-card .login-logo{background:var(--accent-gradient);border-radius:var(--radius-md);color:#fff;width:56px;height:56px;box-shadow:0 4px 20px var(--accent-glow);justify-content:center;align-items:center;margin:0 auto 24px;font-size:24px;font-weight:800;display:flex}.login-card h1{text-align:center;margin-bottom:4px;font-size:22px}.login-card .subtitle{text-align:center;color:var(--text-muted);margin-bottom:28px;font-size:13px}.login-card .btn-primary{justify-content:center;width:100%;padding:12px;font-size:14px}.grid-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-in{animation:fade-in .4s var(--transition-base) backwards}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin;display:inline-block}@media (width<=1024px){.kpi-grid,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0!important}.kpi-grid,.grid-2,.grid-3{grid-template-columns:1fr}}.field-service-mobile-view{max-width:800px;margin:0 auto}.hover-card:active{transform:scale(.98);background:var(--bg-card-hover)!important}.visit-detail-view .card{border-radius:var(--radius-xl);padding:16px}canvas{touch-action:none;-webkit-user-select:none;user-select:none;background:#fff}@media (width<=600px){.page.field-service-mobile-view{padding:12px}.hide-mobile{display:none}.modal-overlay .card{width:95%!important;padding:16px!important}}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;background:#000000b3;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.fc{--fc-border-color:var(--border-color);--fc-daygrid-event-dot-width:8px;--fc-page-bg-color:transparent;--fc-neutral-bg-color:var(--bg-secondary);--fc-list-event-hover-bg-color:var(--bg-card-hover);color:var(--text-primary);font-family:inherit}.fc .fc-toolbar-title{font-size:1.2rem;font-weight:700}.fc .fc-button-primary{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-secondary);text-transform:capitalize;font-size:.85rem;font-weight:600}.fc .fc-button-primary:hover{background:var(--bg-card-hover);border-color:var(--accent)}.fc .fc-button-active{background:var(--accent)!important;color:#fff!important}.fc-theme-standard td,.fc-theme-standard th{border-color:var(--border-color)!important}.fc .fc-day-today{background:#6366f10d!important}.fc-event{cursor:pointer;border-radius:4px;padding:2px 4px;font-size:.8rem;box-shadow:0 2px 4px #0003;border:none!important}.fc-v-event .fc-event-main,.fc-h-event .fc-event-main{color:#fff}.calendar-card .fc-view-harness{min-height:600px}@media (width<=768px){.fc .fc-toolbar{flex-direction:column;gap:10px}}
