@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap);:root{--primary:#2563eb;--primary-dark:#1d4ed8;--primary-light:#dbeafe;--secondary:#0f172a;--accent:#06b6d4;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--info:#6366f1;--bg:#f8fafc;--bg-card:#fff;--bg-sidebar:#0f172a;--sidebar-width:256px;--text:#1e293b;--text-muted:#64748b;--text-light:#94a3b8;--border:#e2e8f0;--border-focus:#2563eb;--shadow-sm:0 1px 3px #00000014;--shadow:0 4px 12px #0000001a;--shadow-lg:0 8px 24px #00000024;--radius:10px;--radius-sm:6px;--radius-lg:16px;--transition:0.18s ease}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:15px}body{-webkit-font-smoothing:antialiased;color:#1e293b;color:var(--text);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6}.loading-screen,body{background:#f8fafc;background:var(--bg)}.loading-screen{align-items:center;display:flex;height:100vh;justify-content:center}.spinner{animation:spin .7s linear infinite;border:3px solid #e2e8f0;border-top-color:#2563eb;border:3px solid var(--border);border-radius:50%;border-top-color:var(--primary);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.admin-layout{display:flex;min-height:100vh}.sidebar{background:#0f172a;background:var(--bg-sidebar);display:flex;flex-direction:column;height:100vh;left:0;position:fixed;top:0;transition:transform .18s ease;transition:transform var(--transition);width:256px;width:var(--sidebar-width);z-index:100}.sidebar-logo{border-bottom:1px solid #ffffff14;padding:24px 20px 20px}.sidebar-logo h1{color:#fff;font-size:1.1rem;font-weight:700;letter-spacing:-.02em}.sidebar-logo span{color:#06b6d4;color:var(--accent)}.sidebar-logo p{color:#fff6;font-size:.7rem;margin-top:2px}.sidebar-nav{flex:1 1;overflow-y:auto;padding:12px 0}.sidebar-nav::-webkit-scrollbar{width:3px}.sidebar-nav::-webkit-scrollbar-track{background:#0000}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.nav-section-label{color:#ffffff4d;font-size:.65rem;font-weight:600;letter-spacing:.08em;padding:16px 20px 6px;text-transform:uppercase}.nav-item{align-items:center;background:none;border:none;border-radius:0;color:#ffffffa6;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:10px;padding:10px 20px;position:relative;text-decoration:none;transition:all .18s ease;transition:all var(--transition);width:100%}.nav-item:hover{background:#ffffff0f;color:#fff}.nav-item.active{background:#2563eb40;color:#fff}.nav-item.active:before{background:#2563eb;background:var(--primary);border-radius:0 2px 2px 0;bottom:0;content:"";left:0;position:absolute;top:0;width:3px}.nav-item .badge{background:#ef4444;background:var(--danger);border-radius:10px;color:#fff;font-size:.65rem;font-weight:600;margin-left:auto;padding:1px 6px}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 20px}.sidebar-user{gap:10px;margin-bottom:12px}.avatar-circle,.sidebar-user{align-items:center;display:flex}.avatar-circle{background:#2563eb;background:var(--primary);border-radius:50%;color:#fff;flex-shrink:0;font-size:.8rem;font-weight:700;height:34px;justify-content:center;width:34px}.sidebar-user-info p{color:#fff;font-size:.8rem;font-weight:600}.sidebar-user-info span{color:#fff6;font-size:.7rem;text-transform:capitalize}.btn-logout{background:#ef444426;border:1px solid #ef444433;border-radius:6px;border-radius:var(--radius-sm);color:#fca5a5;cursor:pointer;font-size:.8rem;padding:8px;transition:all .18s ease;transition:all var(--transition);width:100%}.btn-logout:hover{background:#ef444440}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:256px;margin-left:var(--sidebar-width);min-width:0}.topbar{align-items:center;background:#fff;background:var(--bg-card);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow-sm);display:flex;height:60px;justify-content:space-between;padding:0 28px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.topbar-title{color:#1e293b;color:var(--text);font-size:1rem;font-weight:600}.topbar-right{align-items:center;display:flex;gap:12px}.page-content{flex:1 1;padding:28px}.card{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow-sm);overflow:hidden}.card-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:18px 20px}.card-header h2,.card-header h3{color:#1e293b;color:var(--text);font-size:.95rem;font-weight:600}.card-body{padding:20px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{align-items:flex-start;background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:10px;border-radius:var(--radius);box-shadow:0 1px 3px #00000014;box-shadow:var(--shadow-sm);display:flex;gap:14px;padding:20px;transition:box-shadow .18s ease;transition:box-shadow var(--transition)}.stat-card:hover{box-shadow:0 4px 12px #0000001a;box-shadow:var(--shadow)}.stat-icon{align-items:center;border-radius:6px;border-radius:var(--radius-sm);display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.stat-info p{color:#64748b;color:var(--text-muted);font-size:.75rem;font-weight:500;margin-bottom:4px}.stat-info h3{color:#1e293b;color:var(--text);font-size:1.6rem;font-weight:700;line-height:1}.stat-info .trend{color:#64748b;color:var(--text-muted);font-size:.72rem;margin-top:4px}.stat-info .trend.up{color:#10b981;color:var(--success)}.stat-info .trend.down{color:#ef4444;color:var(--danger)}.btn{align-items:center;border:1px solid #0000;border-radius:6px;border-radius:var(--radius-sm);cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:500;gap:6px;padding:8px 16px;text-decoration:none;transition:all .18s ease;transition:all var(--transition);white-space:nowrap}.btn-primary{background:#2563eb;background:var(--primary);border-color:#2563eb;border-color:var(--primary);color:#fff}.btn-primary:hover{background:#1d4ed8;background:var(--primary-dark);border-color:#1d4ed8;border-color:var(--primary-dark)}.btn-secondary{background:#f8fafc;background:var(--bg);border-color:#e2e8f0;border-color:var(--border);color:#1e293b;color:var(--text)}.btn-secondary:hover{background:#e2e8f0;background:var(--border)}.btn-success{background:#10b981;background:var(--success);border-color:#10b981;border-color:var(--success);color:#fff}.btn-danger{background:#ef4444;background:var(--danger);border-color:#ef4444;border-color:var(--danger);color:#fff}.btn-warning{background:#f59e0b;background:var(--warning);border-color:#f59e0b;border-color:var(--warning);color:#fff}.btn-outline{background:#0000;border-color:#2563eb;border-color:var(--primary);color:#2563eb;color:var(--primary)}.btn-outline:hover{background:#dbeafe;background:var(--primary-light)}.btn-sm{font-size:.78rem;padding:5px 10px}.btn-lg{font-size:.95rem;padding:11px 22px}.btn:disabled{cursor:not-allowed;opacity:.5}.form-group{margin-bottom:18px}.form-label{color:#1e293b;color:var(--text);display:block;font-size:.82rem;font-weight:500;margin-bottom:6px}.form-label .required{color:#ef4444;color:var(--danger);margin-left:2px}.form-control{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#1e293b;color:var(--text);font-family:inherit;font-size:.875rem;outline:none;padding:9px 13px;transition:border-color .18s ease,box-shadow .18s ease;transition:border-color var(--transition),box-shadow var(--transition);width:100%}.form-control:focus{border-color:#2563eb;border-color:var(--border-focus);box-shadow:0 0 0 3px #2563eb1f}.form-control::placeholder{color:#94a3b8;color:var(--text-light)}select.form-control{cursor:pointer}textarea.form-control{min-height:90px;resize:vertical}.form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.form-grid-3{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr 1fr}.form-error{color:#ef4444;color:var(--danger)}.form-error,.form-hint{font-size:.78rem;margin-top:4px}.form-hint{color:#64748b;color:var(--text-muted)}.table-container{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{background:#f8fafc;background:var(--bg);color:#64748b;color:var(--text-muted);font-size:.75rem;font-weight:600;letter-spacing:.04em;padding:10px 14px;text-align:left;text-transform:uppercase}tbody td,thead th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border)}tbody td{font-size:.875rem;padding:12px 14px}tbody tr:hover{background:#f8fafc}tbody tr:last-child td{border-bottom:none}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.72rem;font-weight:600;letter-spacing:.02em;padding:2px 8px}.badge-active,.badge-completed,.badge-success{background:#d1fae5;color:#065f46}.badge-suspended,.badge-warning{background:#fef3c7;color:#92400e}.badge-danger,.badge-disconnected,.badge-failed{background:#fee2e2;color:#991b1b}.badge-info,.badge-pending{background:#dbeafe;color:#1e40af}.badge-open{background:#fee2e2;color:#991b1b}.badge-in_progress{background:#fef3c7;color:#92400e}.badge-closed,.badge-resolved{background:#d1fae5;color:#065f46}.badge-broadband{background:#dbeafe;color:#1e40af}.badge-catv{background:#f3e8ff;color:#6b21a8}.badge-both{background:#dcfce7;color:#15803d}.filter-bar{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.search-input-wrapper{position:relative}.search-input-wrapper .search-icon{color:#94a3b8;color:var(--text-light);left:10px;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);font-size:.875rem;outline:none;padding:8px 12px 8px 34px;transition:border-color .18s ease;transition:border-color var(--transition);width:260px}.search-input:focus{border-color:#2563eb;border-color:var(--border-focus)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:200}.modal{border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 8px 24px #00000024;box-shadow:var(--shadow-lg);max-height:90vh;max-width:560px;overflow-y:auto;width:100%}.modal,.modal-header{background:#fff;background:var(--bg-card)}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px;position:-webkit-sticky;position:sticky;top:0;z-index:1}.modal-header h3{font-size:1rem;font-weight:600}.modal-close{background:none;border:none;border-radius:4px;color:#64748b;color:var(--text-muted);cursor:pointer;padding:4px}.modal-close:hover{background:#f8fafc;background:var(--bg);color:#1e293b;color:var(--text)}.modal-body{padding:24px}.modal-footer{gap:10px;padding:16px 24px}.modal-footer,.pagination{border-top:1px solid #e2e8f0;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.pagination{align-items:center;gap:6px;padding:16px 20px}.page-btn{background:#fff;background:var(--bg-card);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:6px;border-radius:var(--radius-sm);color:#1e293b;color:var(--text);cursor:pointer;font-size:.8rem;padding:5px 10px;transition:all .18s ease;transition:all var(--transition)}.page-btn:hover{background:#dbeafe;background:var(--primary-light)}.page-btn.active,.page-btn:hover{border-color:#2563eb;border-color:var(--primary)}.page-btn.active{background:#2563eb;background:var(--primary);color:#fff}.page-btn:disabled{cursor:not-allowed;opacity:.4}.empty-state{color:#64748b;color:var(--text-muted);padding:48px 24px;text-align:center}.empty-state svg{color:#94a3b8;color:var(--text-light);margin-bottom:12px}.empty-state h3{color:#1e293b;color:var(--text);font-size:.95rem;font-weight:600;margin-bottom:6px}.empty-state p{font-size:.85rem}.login-page{background:linear-gradient(135deg,#0f172a,#1e3a5f);display:flex;min-height:100vh}.login-box{background:#fff;border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 8px 24px #00000024;box-shadow:var(--shadow-lg);margin:auto;max-width:420px;padding:40px;width:100%}.login-logo{margin-bottom:28px;text-align:center}.login-logo h1{color:#0f172a;color:var(--secondary);font-size:1.5rem;font-weight:800}.login-logo h1 span{color:#2563eb;color:var(--primary)}.login-logo p{color:#64748b;color:var(--text-muted);font-size:.82rem;margin-top:4px}.timeline{position:relative}.timeline:before{background:#e2e8f0;background:var(--border);bottom:0;content:"";left:14px;position:absolute;top:0;width:2px}.timeline-item{gap:14px;margin-bottom:20px}.timeline-dot,.timeline-item{display:flex;position:relative}.timeline-dot{align-items:center;background:#2563eb;background:var(--primary);border:2px solid #f8fafc;border:2px solid var(--bg);border-radius:50%;flex-shrink:0;height:28px;justify-content:center;width:28px;z-index:1}.timeline-content{flex:1 1;padding-top:2px}.timeline-action{color:#1e293b;color:var(--text);font-size:.82rem;font-weight:600}.timeline-desc{color:#64748b;color:var(--text-muted);font-size:.8rem;margin-top:2px}.timeline-time{color:#94a3b8;color:var(--text-light);font-size:.72rem;margin-top:4px}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main-content{margin-left:0}.form-grid,.form-grid-3{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}.page-content{padding:16px}}.text-muted{color:#64748b;color:var(--text-muted)}.text-small{font-size:.8rem}.font-mono{font-family:JetBrains Mono,monospace}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mb-4{margin-bottom:16px}.mb-6{margin-bottom:24px}.mt-4{margin-top:16px}.grid-2{grid-gap:20px;grid-template-columns:1fr 1fr}.grid-2,.grid-3{display:grid;gap:20px}.grid-3{grid-gap:20px;grid-template-columns:1fr 1fr 1fr}.w-full{width:100%}.rupee:before{content:"₹"}
/*# sourceMappingURL=main.47255bf7.css.map*/