@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--bg: #f0f2f5;--bg-card: #ffffff;--bg-hover: #f7f8fa;--bg-input: #f7f8fa;--border: #dfe3e8;--border-strong: #c4cdd5;--text: #1c2b3a;--text-2: #4a5568;--text-3: #718096;--text-muted: #a0aec0;--accent: #0b6e4f;--accent-hover: #0a5e44;--accent-soft: rgba(11, 110, 79, .1);--accent-2: #2b6cb0;--accent-2-soft: rgba(43, 108, 176, .1);--green: #22543d;--green-bg: #f0fff4;--red: #c53030;--red-bg: #fff5f5;--amber: #c05621;--amber-bg: #fffaf0;--nav-bg: #1c2b3a;--sans: "Inter", system-ui, -apple-system, sans-serif;--radius: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.07);--shadow-lg: 0 10px 30px rgba(0,0,0,.1);--transition: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--sans);background:var(--bg);color:var(--text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}.app{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--nav-bg);color:#fff;display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:200;transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.25rem 1.5rem;text-decoration:none;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-brand-logo{height:28px;width:auto;filter:brightness(0) invert(1);flex-shrink:0}.sidebar-nav{flex:1;padding:.75rem;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.sidebar-nav a{display:flex;align-items:center;gap:.65rem;padding:.6rem .75rem;font-size:.9rem;font-weight:500;color:#ffffffa6;border-radius:var(--radius);transition:background var(--transition),color var(--transition);text-decoration:none}.sidebar-nav a:hover{color:#fff;background:#ffffff14}.sidebar-nav a.active{color:#fff;background:var(--accent)}.sidebar-nav-icon{flex-shrink:0;opacity:.7}.sidebar-nav a.active .sidebar-nav-icon{opacity:1}.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:.5rem}.sidebar-user{display:flex;align-items:center;gap:.6rem}.sidebar-user-avatar{width:32px;height:32px;background:#ffffff1f;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;color:#fffc;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:.85rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.7rem;color:#ffffff80;text-transform:capitalize}.sidebar-logout{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:#ffffffb3;padding:.45rem .75rem;border-radius:var(--radius);cursor:pointer;font-size:.85rem;font-family:var(--sans);font-weight:500;transition:background var(--transition),color var(--transition);text-align:center}.sidebar-logout:hover{background:#ffffff1f;color:#fff}.app-body{flex:1;margin-left:240px;display:flex;flex-direction:column;min-height:100vh}.topbar{display:none;align-items:center;gap:.75rem;padding:0 1rem;height:56px;background:var(--nav-bg);position:sticky;top:0;z-index:150;box-shadow:0 2px 8px #00000026}.topbar-toggle{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#ffffff14;border:none;color:#fff;cursor:pointer;border-radius:var(--radius);font-size:1.25rem;flex-shrink:0}.topbar-toggle:active{background:#ffffff26}.topbar-brand-section{display:flex;align-items:center;gap:.6rem;flex:1;min-width:0}.topbar-logo-img{height:24px;width:auto;filter:brightness(0) invert(1);flex-shrink:0}.topbar-user{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.topbar-avatar{width:30px;height:30px;background:#ffffff1f;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;color:#fffc}.topbar-role{font-size:.7rem;color:var(--nav-bg);background:#ffffffe6;padding:.15rem .45rem;border-radius:4px;font-weight:600;text-transform:capitalize}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:199;opacity:0;transition:opacity .3s ease}.sidebar-backdrop.visible{display:block;opacity:1}@media (max-width: 860px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.topbar{display:flex}.app-body{margin-left:0}}.main{flex:1;padding:1.5rem 2rem;max-width:1200px;width:100%}@media (max-width: 860px){.main{padding:1.25rem 1rem}}@media (max-width: 480px){.main{padding:1rem .75rem}}.page-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.page-title{font-size:1.5rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.breadcrumb{display:flex;align-items:center;gap:.4rem;margin-bottom:.5rem;font-size:.85rem;color:var(--text-3)}.breadcrumb a{color:var(--text-2);font-weight:500}.breadcrumb a:hover{color:var(--accent)}.breadcrumb-sep{color:var(--text-muted)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;margin-bottom:1rem;box-shadow:var(--shadow-sm)}.card-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);margin-bottom:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.55rem 1.1rem;font-size:.9rem;font-weight:600;font-family:var(--sans);border:none;border-radius:var(--radius);cursor:pointer;transition:all var(--transition);background:var(--accent);color:#fff;line-height:1.2}.btn:hover{background:var(--accent-hover);box-shadow:var(--shadow)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-ghost{background:var(--bg-card);border:1px solid var(--border);color:var(--text-2)}.btn-ghost:hover{background:var(--bg-hover);border-color:var(--border-strong);color:var(--text);box-shadow:none}.btn-full{width:100%}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.8rem;font-weight:600;color:var(--text-2)}.form-group input,.form-group select,.form-group textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:16px;font-family:var(--sans);padding:.55rem .8rem;transition:border-color var(--transition),box-shadow var(--transition)}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:#fff}.form-group select option{background:#fff}.form-row{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:.75rem}.form-row .form-group{flex:1;min-width:200px}@media (max-width: 640px){.form-row{flex-direction:column}.form-row .form-group{min-width:0}}.filters-bar{display:flex;align-items:flex-end;gap:.75rem;flex-wrap:wrap;margin-bottom:1.25rem}.filters-bar .form-group{flex:1;min-width:160px;max-width:260px}.filters-bar .form-group.wide{max-width:340px}@media (max-width: 640px){.filters-bar{flex-direction:column;align-items:stretch}.filters-bar .form-group{max-width:none}}.table-wrapper{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.table-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.25rem;border-bottom:1px solid var(--border)}.table-header-title{font-size:.85rem;font-weight:600;color:var(--text-2)}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:.9rem}thead{background:var(--bg-hover)}th{padding:.7rem 1rem;text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);white-space:nowrap;border-bottom:2px solid var(--border)}th:first-child{padding-left:1.25rem}th:last-child{padding-right:1.25rem}td{padding:.75rem 1rem;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}td:first-child{padding-left:1.25rem}td:last-child{padding-right:1.25rem}tbody tr{transition:background .1s}tbody tr:hover{background:var(--bg-hover)}tbody tr:last-child td{border-bottom:none}.table-link{color:var(--accent);font-weight:600}.table-link:hover{color:var(--accent-hover);text-decoration:underline}.table-empty{padding:3rem 1rem;text-align:center;color:var(--text-muted)}.table-footer{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.25rem;border-top:1px solid var(--border);background:var(--bg-hover)}.table-count{font-size:.85rem;color:var(--text-3);font-weight:500}.cell-mono{font-size:.85rem;color:var(--text-2)}@media (max-width: 768px){.table-scroll{overflow-x:visible}table{min-width:0!important}thead{display:none}tbody tr{display:block;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:.5rem;padding:.75rem 1rem;box-shadow:var(--shadow-sm)}tbody tr:hover{background:var(--bg-card)}td{display:flex;justify-content:space-between;align-items:center;padding:.35rem 0!important;border-bottom:none!important;gap:.75rem}td:first-child{padding-left:0!important}td:last-child{padding-right:0!important}td:before{content:attr(data-label);font-size:.75rem;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.03em;flex-shrink:0;min-width:90px}td:not([data-label]):before{display:none}.table-wrapper{border:none;box-shadow:none;background:transparent;border-radius:0}.table-header{border-radius:var(--radius) var(--radius) 0 0}.table-footer{border-radius:0 0 var(--radius) var(--radius);margin-top:-.5rem}.table-empty{display:block;text-align:center}}.badge{display:inline-flex;align-items:center;font-size:.75rem;font-weight:600;padding:.2rem .55rem;border-radius:6px;letter-spacing:.02em;white-space:nowrap}.badge-count{background:var(--accent);color:#fff;border-radius:20px;padding:.15rem .6rem}.badge-service{background:var(--accent-2-soft);color:var(--accent-2)}.badge-type{background:var(--bg-hover);color:var(--text-2);border:1px solid var(--border)}.status-dot{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:500}.status-dot:before{content:"";width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.status-active{color:var(--green)}.status-dot.status-active:before{background:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.status-dot.status-inactive{color:var(--red)}.status-dot.status-inactive:before{background:var(--red);box-shadow:0 0 0 3px var(--red-bg)}.status-dot.status-suspended{color:var(--amber)}.status-dot.status-suspended:before{background:var(--amber);box-shadow:0 0 0 3px var(--amber-bg)}.loading-row{padding:3rem;text-align:center;color:var(--text-muted);font-size:.9rem}.error-msg{color:var(--red);font-size:.9rem;padding:.85rem 1rem;background:var(--red-bg);border:1px solid rgba(197,48,48,.15);border-radius:var(--radius);margin-bottom:1rem;font-weight:500}.login-wrapper{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--nav-bg);padding:1.5rem}.login-card{background:var(--bg-card);border-radius:16px;padding:2.5rem 2rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.login-logo{display:flex;justify-content:center;margin-bottom:2rem}.login-logo-img{height:40px;width:auto}.login-title{font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:.25rem;letter-spacing:-.02em}.login-subtitle{font-size:.95rem;color:var(--text-3);margin-bottom:2rem}.login-card .form-group{margin-bottom:1.25rem}.login-card .form-group input{width:100%;background:#fff;padding:.65rem .85rem;font-size:16px}.login-card .btn{padding:.65rem 1.25rem;font-size:.95rem;margin-top:.5rem}@media (max-width: 480px){.login-card{padding:2rem 1.5rem;border-radius:12px}.login-title{font-size:1.3rem}}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:.75rem;margin-bottom:1.5rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1rem;cursor:pointer;transition:all var(--transition);display:flex;flex-direction:column;gap:.3rem;box-shadow:var(--shadow-sm)}.stat-card:hover{box-shadow:var(--shadow-md);border-color:var(--accent);transform:translateY(-2px)}.stat-card.total{background:var(--accent);border-color:var(--accent)}.stat-card.total .stat-number{color:#fff}.stat-card.total .stat-label{color:#ffffffbf}.stat-card.total:hover{background:var(--accent-hover)}.stat-number{font-size:1.75rem;font-weight:700;color:var(--text);line-height:1;letter-spacing:-.02em}.stat-label{font-size:.75rem;color:var(--text-3);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.status-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.25rem;display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;box-shadow:var(--shadow-sm)}.status-bar-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3)}.status-bar-items{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.status-bar-item{display:flex;align-items:baseline;gap:.4rem}.status-bar-count{font-size:1.3rem;font-weight:700;line-height:1}.status-bar-count.active{color:var(--accent)}.status-bar-count.inactive{color:var(--red)}.status-bar-count.suspended{color:var(--amber)}.status-bar-name{font-size:.85rem;color:var(--text-3)}.section-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin:1.75rem 0 .75rem}.tech-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.75rem;margin-bottom:1rem}.tech-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem;cursor:pointer;transition:all var(--transition);display:flex;flex-direction:column;gap:.25rem;box-shadow:var(--shadow-sm)}.tech-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.tech-count{font-size:1.6rem;font-weight:700;line-height:1}.tech-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-3)}.tech-gpon .tech-count{color:var(--accent-2)}.tech-fiber .tech-count{color:var(--accent)}.tech-radio .tech-count{color:var(--amber)}.tech-other .tech-count{color:var(--text-2)}.tech-badge{font-size:.75rem;font-weight:600;padding:.2rem .5rem;border-radius:6px}.tech-gpon{background:var(--accent-2-soft);color:var(--accent-2)}.tech-fiber{background:var(--accent-soft);color:var(--accent)}.tech-radio{background:var(--amber-bg);color:var(--amber)}.tech-other{background:var(--bg-hover);color:var(--text-2)}.detail-info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem 2rem}.detail-field-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);margin-bottom:.15rem}.detail-field-value{font-size:.95rem;color:var(--text)}@media (max-width: 480px){.detail-info-grid{grid-template-columns:1fr;gap:1rem}}.import-zone{border:2px dashed var(--border-strong);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;color:var(--text-3);transition:all var(--transition);cursor:pointer}.import-zone:hover{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 0;flex-wrap:wrap}.pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 .5rem;font-size:.85rem;font-weight:500;font-family:var(--sans);background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-2);cursor:pointer;transition:all var(--transition)}.pagination-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-strong);color:var(--text)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.pagination-info{font-size:.85rem;color:var(--text-3);padding:0 .5rem}.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:1.5rem 0 .5rem}.section-title-row .section-title{margin:0}.btn-sm{padding:.35rem .75rem;font-size:.8rem}.btn-outline{background:transparent;border:1px solid var(--border-strong);color:var(--text-2)}.btn-outline:hover{background:var(--bg-hover);color:var(--text);border-color:var(--accent)}.th-action{width:1%;white-space:nowrap}.cell-action{text-align:right}@media (max-width: 768px){.cell-action{text-align:center;padding-top:.5rem!important}.cell-action .btn{width:100%;display:block;text-align:center}.cell-action:before{display:none!important}}
