:root{--brand: #8B00BB;--brand-dark: #6A0090;--brand-light: #B144D6;--accent: #FF8C00;--accent-dark: #E07B00;--bg: #F7F4FA;--bg-1: #FFFFFF;--bg-2: #FAF7FC;--txt: #1A0E22;--txt-2: #5A4965;--txt-3: #9B8FA5;--border: #E8E0EF;--border-soft: #F1ECF5;--green: #16A34A;--green-bg:#DCFCE7;--red: #DC2626;--red-bg: #FEE2E2;--orange: #F97316;--orange-bg:#FFEDD5;--blue: #2563EB;--blue-bg: #DBEAFE;--gray: #6B7280;--gray-bg: #F3F4F6;--shadow-sm: 0 1px 2px 0 rgba(0,0,0,.04);--shadow: 0 4px 12px -2px rgba(139,0,187,.08), 0 2px 6px -2px rgba(0,0,0,.04);--shadow-lg: 0 20px 40px -8px rgba(139,0,187,.18), 0 8px 16px -4px rgba(0,0,0,.06);--radius: 12px;--radius-sm: 8px;--radius-lg: 18px}*{box-sizing:border-box}html,body{margin:0;padding:0;overflow-x:hidden;overflow-x:clip;width:100%;max-width:100vw}#root{width:100%;max-width:100vw;overflow-x:hidden;overflow-x:clip}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Inter,Roboto,sans-serif;font-size:14px;line-height:1.55;color:var(--txt);background:var(--bg);background-image:radial-gradient(circle at 0% 0%,rgba(139,0,187,.06) 0%,transparent 40%),radial-gradient(circle at 100% 0%,rgba(255,140,0,.04) 0%,transparent 35%);background-attachment:fixed;min-height:100vh;min-height:-webkit-fill-available;-webkit-font-smoothing:antialiased;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:inherit}a{color:var(--brand);text-decoration:none}a:hover{color:var(--brand-dark)}.app-header{position:sticky;top:0;z-index:100;background:linear-gradient(135deg,#FFF 0%,var(--bg-2) 100%);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:14px max(32px,env(safe-area-inset-right)) 14px max(32px,env(safe-area-inset-left));display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-sm)}.app-header .brand{display:flex;align-items:center;gap:16px}.app-header img.logo{height:36px;width:auto;display:block}.app-header .brand-divider{width:1px;height:28px;background:var(--border)}.app-header .cond-name{font-size:14px;font-weight:600;color:var(--txt)}.app-header .cond-name small{display:block;color:var(--txt-3);font-weight:400;font-size:11px}.app-header .user-info{display:flex;align-items:center;gap:12px;font-size:13px}.app-header .user-info .user-name{font-weight:600}.app-header .user-info .user-role{font-size:10px;padding:2px 8px;border-radius:12px;background:var(--brand);color:#fff;text-transform:uppercase;letter-spacing:.04em}.app-header .btn-logout{background:transparent;border:1px solid var(--border);padding:6px 12px;border-radius:var(--radius-sm);color:var(--txt-2);font-size:12px;transition:all .15s}.app-header .btn-logout:hover{border-color:var(--red);color:var(--red);background:var(--red-bg)}.page{max-width:1400px;margin:0 auto;padding:32px max(32px,env(safe-area-inset-right)) 32px max(32px,env(safe-area-inset-left))}.page-title{font-size:22px;font-weight:800;color:var(--txt);margin:0 0 6px;letter-spacing:-.02em;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.page-subtitle{color:var(--txt-2);font-size:13px;margin:0 0 28px;word-wrap:break-word;overflow-wrap:break-word;max-width:100%}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;display:flex;align-items:flex-start;justify-content:space-between;box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}.stat-card .label{font-size:11px;font-weight:700;color:var(--txt-3);text-transform:uppercase;letter-spacing:.08em;margin:0 0 8px}.stat-card .value{font-size:32px;font-weight:800;color:var(--txt);line-height:1;letter-spacing:-.03em}.stat-card .value small{display:block;font-size:11px;font-weight:500;color:var(--txt-3);margin-top:6px;letter-spacing:0}.stat-card .icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px}.stat-card.brand .icon{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-light) 100%);color:#fff}.stat-card.green .icon{background:var(--green-bg);color:var(--green)}.stat-card.red .icon{background:var(--red-bg);color:var(--red)}.stat-card.orange .icon{background:var(--orange-bg);color:var(--orange)}.stat-card.blue .icon{background:var(--blue-bg);color:var(--blue)}.filter-bar{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:18px;box-shadow:var(--shadow-sm)}.filter-bar label{font-size:11px;font-weight:700;color:var(--txt-3);text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:4px}.filter-bar .field{display:flex;flex-direction:column}.filter-bar select,.filter-bar input[type=text]{background:var(--bg-2);border:1px solid var(--border);padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;color:var(--txt);outline:none;transition:border-color .15s}.filter-bar select:focus,.filter-bar input[type=text]:focus{border-color:var(--brand)}.filter-bar input[type=text]{min-width:220px}.filter-bar .spacer{flex:1}.filter-bar .btn-clear{background:transparent;border:1px solid var(--border);padding:8px 14px;border-radius:var(--radius-sm);color:var(--txt-2);font-size:12px}.filter-bar .btn-clear:hover{border-color:var(--brand);color:var(--brand)}.filter-bar .btn-refresh{background:var(--brand);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius-sm);font-size:12px;font-weight:600;letter-spacing:.03em;transition:background .15s}.filter-bar .btn-refresh:hover{background:var(--brand-dark)}.filter-bar .btn-refresh:disabled{background:var(--gray);cursor:not-allowed}.onu-table-wrap{background:var(--bg-1);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.onu-table{width:100%;border-collapse:collapse;font-size:13px}.onu-table thead th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--txt-3);font-weight:700;padding:12px 16px;background:var(--bg-2);border-bottom:1px solid var(--border);position:sticky;top:0}.onu-table tbody td{padding:14px 16px;border-bottom:1px solid var(--border-soft);vertical-align:middle}.onu-table tbody tr:last-child td{border-bottom:none}.onu-table tbody tr:hover{background:var(--bg-2)}.onu-table .serial{font-family:SF Mono,Consolas,Monaco,monospace;font-size:11px;color:var(--txt-2)}.onu-table .ap-info{display:flex;flex-direction:column;gap:2px}.onu-table .ap-info .ap-num{font-weight:700;font-size:14px}.onu-table .ap-info .bloco{font-size:11px;color:var(--txt-3)}.onu-table .client-name{font-weight:600}.onu-table .pppoe-user{font-family:SF Mono,Consolas,Monaco,monospace;font-size:11px;color:var(--txt-3)}.onu-table .actions{text-align:right;white-space:nowrap}.onu-table tbody tr.inactive{opacity:.65}.onu-table tbody tr.inactive td{background:var(--red-bg)}.onu-table tbody tr.inactive:hover td{background:#fdd}.pill{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:700;padding:4px 10px;border-radius:999px;letter-spacing:.04em}.pill:before{content:"";display:block;width:6px;height:6px;border-radius:50%}.pill.active{background:var(--green-bg);color:var(--green)}.pill.active:before{background:var(--green)}.pill.inactive{background:var(--red-bg);color:var(--red)}.pill.inactive:before{background:var(--red)}.pill.online{background:var(--blue-bg);color:var(--blue)}.pill.online:before{background:var(--blue)}.pill.offline{background:var(--gray-bg);color:var(--gray)}.pill.offline:before{background:var(--gray)}.btn-action{padding:6px 14px;border:1px solid;border-radius:var(--radius-sm);font-size:12px;font-weight:700;transition:all .15s;letter-spacing:.02em}.btn-deactivate{background:var(--bg-1);border-color:var(--red);color:var(--red)}.btn-deactivate:hover{background:var(--red);color:#fff}.btn-activate{background:var(--bg-1);border-color:var(--green);color:var(--green)}.btn-activate:hover{background:var(--green);color:#fff}.btn-action:disabled{opacity:.4;cursor:not-allowed}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}.login-card{background:var(--bg-1);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:40px 36px;width:100%;max-width:420px;border:1px solid var(--border)}.login-card .logo-wrap{text-align:center;margin-bottom:28px}.login-card .logo-wrap img{height:56px;width:auto;margin-bottom:14px}.login-card .logo-wrap .title{font-size:13px;color:var(--txt-3);font-weight:600;letter-spacing:.12em;text-transform:uppercase}.login-card .logo-wrap .subtitle{font-size:11px;color:var(--accent);font-weight:500;margin-top:4px;font-style:italic}.login-card h1{font-size:22px;margin:0 0 24px;text-align:center;font-weight:800;letter-spacing:-.02em}.login-card label{font-size:11px;font-weight:700;color:var(--txt-3);text-transform:uppercase;letter-spacing:.06em;display:block;margin:14px 0 6px}.login-card input{width:100%;padding:12px 14px;background:var(--bg-2);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;color:var(--txt);outline:none;transition:border-color .15s}.login-card input:focus{border-color:var(--brand);background:#fff}.login-card .btn-submit{width:100%;margin-top:22px;padding:13px;background:linear-gradient(135deg,var(--brand) 0%,var(--brand-light) 100%);color:#fff;border:none;border-radius:var(--radius-sm);font-size:14px;font-weight:700;letter-spacing:.03em;transition:opacity .15s,transform .15s}.login-card .btn-submit:hover{opacity:.92;transform:translateY(-1px)}.login-card .btn-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-card .error-box{background:var(--red-bg);border:1px solid var(--red);color:var(--red);padding:10px 14px;border-radius:var(--radius-sm);font-size:12px;margin-top:14px}.login-card .footer-note{margin-top:22px;padding-top:18px;border-top:1px solid var(--border-soft);text-align:center;font-size:11px;color:var(--txt-3)}.toast{position:fixed;bottom:24px;right:24px;background:var(--bg-1);border:1px solid var(--border);border-left:4px solid var(--brand);padding:14px 18px;border-radius:var(--radius);box-shadow:var(--shadow-lg);font-size:13px;max-width:380px;z-index:9999;animation:slide-in .3s ease-out}.toast.success{border-left-color:var(--green)}.toast.error{border-left-color:var(--red)}.toast .toast-title{font-weight:700;margin-bottom:4px}.toast .toast-msg{color:var(--txt-2);font-size:12px}@keyframes slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.spinner{display:inline-block;width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--brand);border-radius:50%;animation:spin .8s linear infinite;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{padding:60px 20px;text-align:center;color:var(--txt-3)}.empty-state .icon{font-size:48px;opacity:.4;margin-bottom:12px}.empty-state .msg{font-size:14px}.btn-history{background:var(--bg-2);border:1px solid var(--border);width:32px;height:32px;border-radius:var(--radius-sm);font-size:14px;line-height:1;padding:0;transition:all .15s;color:var(--txt-2)}.btn-history:hover{background:var(--brand);color:#fff;border-color:var(--brand)}.onu-table th.th-history,.onu-table .actions-history{width:50px;text-align:center;padding-right:4px}.onu-table .actions-history{padding-left:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#140a1e8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fade-in .15s ease-out;padding:20px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--bg-1);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:640px;max-height:85vh;display:flex;flex-direction:column;border:1px solid var(--border);animation:slide-up .2s ease-out}@keyframes slide-up{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.modal-title{font-size:16px;font-weight:800;color:var(--txt);letter-spacing:-.01em}.modal-subtitle{font-size:12px;color:var(--txt-2);margin-top:4px}.modal-close{background:transparent;border:none;width:28px;height:28px;border-radius:50%;font-size:18px;color:var(--txt-3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:var(--bg-2);color:var(--red)}.modal-body{padding:16px 24px;overflow-y:auto;flex:1}.modal-footer{padding:14px 24px;border-top:1px solid var(--border-soft);display:flex;justify-content:space-between;align-items:center}.btn-close{background:var(--brand);color:#fff;border:none;padding:8px 18px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;transition:background .15s}.btn-close:hover{background:var(--brand-dark)}.audit-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.audit-item{display:flex;align-items:stretch;background:var(--bg-2);border:1px solid var(--border-soft);border-radius:var(--radius);padding:12px 14px;gap:14px}.audit-item-failure{background:var(--red-bg);border-color:var(--red)}.audit-time{min-width:88px;text-align:center;display:flex;flex-direction:column;justify-content:center}.audit-date{font-size:11px;font-weight:700;color:var(--txt-2);letter-spacing:.03em}.audit-hour{font-size:13px;font-weight:800;color:var(--txt);font-family:SF Mono,Consolas,monospace}.audit-divider{width:1px;background:var(--border)}.audit-content{flex:1}.audit-action-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px}.audit-action-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:800;padding:3px 8px;border-radius:999px;letter-spacing:.06em}.audit-fail-tag{font-size:9px;font-weight:800;background:var(--red);color:#fff;padding:2px 8px;border-radius:999px;letter-spacing:.08em}.audit-meta{font-size:10px;color:var(--txt-3);font-family:SF Mono,Consolas,monospace}.audit-actor{font-size:12px;color:var(--txt-2)}.audit-actor strong{color:var(--txt);font-weight:700}.audit-role{display:inline-block;margin-left:6px;font-size:9px;font-weight:700;background:var(--brand);color:#fff;padding:1px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.06em}.audit-error{font-size:11px;color:var(--red);margin-top:6px}.audit-tech{font-size:9px;color:var(--txt-3);margin-top:6px;font-family:SF Mono,Consolas,monospace;display:flex;gap:8px;flex-wrap:wrap}@media (max-width: 768px){.page{padding:16px max(16px,env(safe-area-inset-right)) 16px max(16px,env(safe-area-inset-left))}.page-title{font-size:18px}.page-subtitle{font-size:12px;margin-bottom:18px}.app-header{padding:12px max(16px,env(safe-area-inset-right)) 12px max(16px,env(safe-area-inset-left));flex-wrap:wrap;gap:12px}.app-header .brand{gap:10px;min-width:0;flex:1}.app-header .brand img.logo{height:28px;flex-shrink:0}.app-header .brand .cond-name{font-size:13px;min-width:0;overflow:hidden;text-overflow:ellipsis}.app-header .user-info{font-size:12px;flex-shrink:0}.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-card{padding:14px 16px}.stat-card .value{font-size:24px}.stat-card .icon{width:36px;height:36px;font-size:18px}.stat-card .value small{font-size:9px}.filter-bar{padding:12px}.filter-bar .field{flex:1 1 100%;min-width:100%}.filter-bar input[type=text]{min-width:100%;width:100%}.filter-bar .btn-refresh{flex:1}.onu-table-wrap{overflow-x:hidden}.onu-table thead{display:none}.onu-table,.onu-table tbody,.onu-table tr{display:block;width:100%}.onu-table tbody tr{border-bottom:1px solid var(--border);padding:14px 16px;display:grid;grid-template-columns:auto auto auto 1fr;grid-template-rows:auto auto auto auto;column-gap:8px;row-gap:8px;align-items:center}.onu-table tbody tr:last-child{border-bottom:none}.onu-table tbody td{display:block;padding:0;border:none}.onu-table tbody td:nth-child(1){grid-column:1 / -1;grid-row:1;font-size:12px;color:var(--txt-3)}.onu-table tbody td:nth-child(1) .ap-info{flex-direction:row;gap:8px;align-items:baseline}.onu-table tbody td:nth-child(1) .ap-num{font-size:14px}.onu-table tbody td:nth-child(2){grid-column:1 / -1;grid-row:2;font-weight:700;font-size:14px}.onu-table tbody td:nth-child(3){grid-column:1 / -1;grid-row:3;font-size:10px}.onu-table tbody td:nth-child(4){grid-column:2;grid-row:4;margin:0}.onu-table tbody td:nth-child(5){grid-column:3;grid-row:4;margin:0}.onu-table tbody td:nth-child(6),.onu-table thead th:nth-child(6){display:none}.onu-table tbody td.actions-history{grid-column:1;grid-row:4;justify-self:start;align-self:center;width:auto;padding:0}.btn-history{width:40px;height:40px;font-size:16px}.onu-table tbody td.actions{grid-column:4;grid-row:1 / 5;justify-self:end;align-self:center;text-align:right;padding:0}.btn-action{padding:10px 14px;font-size:12px;white-space:nowrap}.modal-overlay{padding:0;align-items:flex-end}.modal-card{max-height:92vh;border-radius:18px 18px 0 0;max-width:100%}}@media (max-width: 400px){.stats-grid{grid-template-columns:1fr}.app-header .brand .cond-name{font-size:12px}.app-header .user-info .user-role{display:none}}
