:root{
    --adn-blue:#087dcc;
    --adn-blue-2:#0076c8;
    --adn-blue-3:#005b9e;
    --adn-navy:#03162e;
    --adn-navy-2:#063a66;
    --adn-sky:#ecfbf6;
    --bg:#eef5ff;
    --panel:#ffffff;
    --panel-soft:#f6f9ff;
    --text:#0f172a;
    --muted:#64748b;
    --line:#dbe7fb;
    --line-2:#c8daf7;
    --success:#16a34a;
    --danger:#dc2626;
    --warning:#d97706;
    --info:#0284c7;
    --wan:#2672f6;
    --lan:#059669;
    --pppoe:#7c3aed;
    --unknown:#64748b;
    --radius:18px;
    --radius-sm:12px;
    --shadow:0 18px 45px rgba(8,40,95,.11);
    --shadow-sm:0 9px 24px rgba(8,40,95,.08);
    --sidebar-w:292px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.45}
a{color:inherit;text-decoration:none}
img{max-width:100%}
code{background:#eef5ff;border:1px solid #d4e4ff;color:#0b48b5;border-radius:8px;padding:2px 7px;font-weight:800}
.small{font-size:12px!important}.muted{color:var(--muted)!important}.text-right{text-align:right}.block{width:100%}

/* ===== Main AdminLTE/SBAdmin-style layout ===== */
.layout{min-height:100vh;display:flex;background:
    radial-gradient(circle at 8% 8%,rgba(38,114,246,.13),transparent 28%),
    radial-gradient(circle at 95% 0,rgba(147,197,253,.20),transparent 25%),
    linear-gradient(135deg,#f5f9ff 0%,#eef5ff 46%,#f8fbff 100%)}
.sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,#061a42 0%,#082c69 52%,#06142f 100%);color:#e5f0ff;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;padding:18px 16px;z-index:40;box-shadow:18px 0 45px rgba(3,13,32,.22);border-right:1px solid rgba(255,255,255,.08)}
.sidebar:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 36% 0,rgba(96,165,250,.24),transparent 31%);pointer-events:none}
.sidebar>*{position:relative;z-index:1}
.main{margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column;width:calc(100% - var(--sidebar-w))}
.sidebar-scrim{display:none;position:fixed;inset:0;background:rgba(2,6,23,.50);z-index:30;backdrop-filter:blur(3px)}

.brand{display:flex;align-items:center;gap:12px;padding:7px 7px 17px;border-bottom:1px solid rgba(255,255,255,.10)}
.brand-logo-box{width:58px;height:58px;border-radius:18px;background:#fff;display:grid;place-items:center;box-shadow:0 18px 34px rgba(38,114,246,.34);overflow:hidden;border:1px solid rgba(255,255,255,.80)}
.brand-logo-box img{width:54px;height:54px;object-fit:contain;display:block;filter:drop-shadow(0 4px 5px rgba(0,0,0,.14))}
.brand-title{font-size:17px;font-weight:950;letter-spacing:.2px;color:#fff;line-height:1.1}.brand-subtitle{font-size:11px;color:#bcd4ff;font-weight:800;letter-spacing:.04em;text-transform:uppercase;margin-top:4px}
.nav{margin-top:24px;display:grid;gap:8px}.nav a{padding:12px 13px;border-radius:14px;color:#c8d9f4;font-weight:850;display:flex;align-items:center;gap:11px;letter-spacing:.01em;border:1px solid transparent;transition:.16s ease}
.nav a i{width:21px;text-align:center;color:#9fc5ff;font-size:15px}.nav a:hover{background:rgba(255,255,255,.08);color:white;border-color:rgba(255,255,255,.08);transform:translateX(2px)}
.nav a.active{background:linear-gradient(90deg,rgba(47,125,255,.28),rgba(255,255,255,.07));box-shadow:inset 4px 0 0 #55a0ff;color:#fff;border-color:rgba(96,165,250,.22)}
.sidebar-footer{margin-top:auto;padding:17px 7px 4px;border-top:1px solid rgba(255,255,255,.10);font-size:13px;color:#dbeafe}.sidebar-footer a{display:inline-flex;gap:8px;align-items:center;margin-top:12px;color:#bfdbfe;font-weight:850}.sidebar-footer a:hover{color:white}.user-pill{display:flex;gap:9px;align-items:center;min-width:0}.user-pill span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.role-pill{margin-top:8px;color:#bcd4ff;font-size:12px;font-weight:900;display:flex;gap:7px;align-items:center}

.topbar{min-height:78px;background:rgba(255,255,255,.90);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;padding:0 26px;position:sticky;top:0;z-index:20;box-shadow:0 10px 24px rgba(8,40,95,.04)}
.topbar-logo{width:42px;height:42px;border-radius:14px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;box-shadow:var(--shadow-sm);overflow:hidden;flex:0 0 auto}.topbar-logo img{width:38px;height:38px;object-fit:contain}.top-title{font-weight:950;color:#0b2d66;letter-spacing:-.01em}.top-subtitle{font-size:12px;color:var(--muted);margin-top:2px}.topbar-actions{margin-left:auto;display:flex;gap:8px;align-items:center}.menu-btn{display:none;border:0;background:#e9f2ff;color:#0b2d66;border-radius:12px;padding:10px 12px;font-size:18px;box-shadow:inset 0 0 0 1px #d4e4ff;cursor:pointer}.content{padding:26px;flex:1;max-width:1920px;width:100%;margin:0 auto}.footer{padding:18px 26px;color:var(--muted);font-size:12px;border-top:1px solid rgba(219,231,251,.65);background:rgba(255,255,255,.42)}

/* ===== Pages ===== */
.page-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:20px}.page-head h1{margin:0 0 7px;font-size:29px;font-weight:950;letter-spacing:-.035em;color:#071a3f}.page-head p{margin:0;color:var(--muted);max-width:900px;line-height:1.65}.section-title{margin-top:18px;margin-bottom:16px}.section-title h2{margin:0 0 6px;font-size:22px;font-weight:950;color:#071a3f;letter-spacing:-.02em}.toolbar{display:flex;gap:10px;align-items:center}.toolbar.wrap{flex-wrap:wrap;margin-bottom:14px}.toolbar select,.toolbar input{min-width:220px}.toolbar.wrap select,.toolbar.wrap input{min-width:170px}
.card,.stat-card,.help-card,.empty-state{background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card{padding:20px;margin-bottom:18px}.card-title{font-weight:950;font-size:17px;margin-bottom:14px;color:#0b2d66;letter-spacing:-.01em}.card-title-row{display:flex;justify-content:space-between;gap:14px;align-items:center;margin-bottom:14px}.card-title-row .card-title{margin-bottom:0}.subhead{font-size:13px;color:var(--muted)}
.empty-state{padding:38px;text-align:center}.empty-state h2{margin:0 0 8px;font-size:24px;font-weight:950;color:#071a3f}.empty-state p{margin:0 auto 18px;color:var(--muted);max-width:650px}

.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:15px;margin-bottom:18px}.stat-card{padding:19px;position:relative;overflow:hidden;min-height:128px}.stat-card:before{content:"";position:absolute;right:-34px;top:-34px;width:122px;height:122px;border-radius:999px;background:rgba(38,114,246,.11)}.stat-card:after{content:"";position:absolute;right:24px;top:22px;width:8px;height:8px;border-radius:999px;background:var(--adn-blue);box-shadow:0 0 0 8px rgba(38,114,246,.10)}.stat-card.lan:before{background:rgba(5,150,105,.11)}.stat-card.lan:after{background:var(--lan);box-shadow:0 0 0 8px rgba(5,150,105,.10)}.stat-card.pppoe:before{background:rgba(124,58,237,.10)}.stat-card.warn:before{background:rgba(217,119,6,.12)}.stat-label{font-size:12px;color:var(--muted);font-weight:950;text-transform:uppercase;letter-spacing:.055em}.stat-value{font-size:27px;font-weight:950;margin-top:8px;letter-spacing:-.045em;color:#061a42}.stat-note{font-size:12px;color:var(--muted);margin-top:6px}.stat-icon{position:absolute;right:18px;bottom:16px;color:#b7cff6;font-size:28px}
.chart-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.grid-2{display:grid;grid-template-columns:420px 1fr;gap:18px;align-items:start}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.help-card{padding:16px;display:grid;gap:8px}.help-card span{font-size:13px;color:var(--muted);line-height:1.48}.chart-meta{display:flex;gap:12px;color:var(--muted);font-size:12px;font-weight:850}.rx-dot,.tx-dot{display:inline-block;width:10px;height:10px;border-radius:99px;margin-right:5px}.rx-dot{background:#2563eb}.tx-dot{background:#16a34a}canvas{display:block;width:100%;max-width:100%;border:1px solid var(--line);border-radius:15px;background:#fff}

/* ===== Forms & buttons ===== */
input,select,textarea{width:100%;border:1px solid var(--line-2);border-radius:12px;padding:10px 12px;background:#fff;color:var(--text);outline:none;transition:.16s ease;font:inherit}textarea{min-height:92px;resize:vertical}select{appearance:auto}input:focus,select:focus,textarea:focus{border-color:#7db2ff;box-shadow:0 0 0 4px rgba(38,114,246,.12);background:#fff}.form-grid{display:grid;gap:13px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:13px}label{display:grid;gap:7px;font-weight:900;color:#334155;font-size:13px}.check-row{background:#f4f8ff;border:1px solid var(--line);border-radius:13px;padding:10px 12px}.check-row label{display:flex;align-items:center;gap:9px;margin:0}.check-row input{width:auto}.table-input{min-width:160px;padding:8px 10px!important}.wide-input{min-width:240px!important}.mt-3{margin-top:1rem!important}
.btn{border:1px solid var(--line-2);background:#fff;color:#10213f;border-radius:12px;padding:10px 14px;font-weight:900;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;line-height:1.1;box-shadow:0 3px 8px rgba(8,40,95,.04);transition:.16s ease}.btn:hover{border-color:#a9c5f2;background:#f7fbff;transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn.primary{background:linear-gradient(135deg,#2f7dff,#155bd6);border-color:#2a72f0;color:#fff;box-shadow:0 12px 24px rgba(38,114,246,.24)}.btn.primary:hover{background:linear-gradient(135deg,#176af3,#0d47b8);border-color:#155bd6}.btn.danger{color:#fff;background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#dc2626}.btn.success{color:#fff;background:linear-gradient(135deg,#22c55e,#16a34a);border-color:#16a34a}.btn.small{padding:7px 10px;font-size:12px;border-radius:10px}.actions{display:flex;gap:7px;align-items:center}.actions form{display:inline-flex}
.alert{border-radius:14px;padding:12px 14px;margin-bottom:14px;border:1px solid;font-weight:800}.alert.info{background:#eef7ff;color:#075985;border-color:#bfdbfe}.alert.success{background:#ecfdf5;color:#166534;border-color:#bbf7d0}.alert.danger{background:#fff1f2;color:#9f1239;border-color:#fecdd3}.alert.warning{background:#fffbeb;color:#92400e;border-color:#fde68a}
.badge{display:inline-flex;align-items:center;gap:5px;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:950;text-transform:uppercase;letter-spacing:.035em}.badge.ok,.badge.success{background:#dcfce7;color:#166534}.badge.bad,.badge.danger{background:#fee2e2;color:#991b1b}.badge.warn,.badge.warning{background:#fef3c7;color:#92400e}.badge.off{background:#e5e7eb;color:#334155}.badge.role-admin{background:#dbeafe;color:#1d4ed8}.badge.role-noc{background:#cffafe;color:#0e7490}.badge.role-wan{background:#dbeafe;color:#1d4ed8}.badge.role-lan{background:#dcfce7;color:#166534}.badge.role-pppoe{background:#ede9fe;color:#6d28d9}.badge.role-auto{background:#f1f5f9;color:#475569}.badge.role-unknown{background:#e5e7eb;color:#475569}

/* ===== Tables ===== */
.table-wrap{overflow:auto;border-radius:16px;border:1px solid var(--line);background:#fff}.table{width:100%;border-collapse:collapse;background:#fff;margin:0}.table th,.table td{padding:12px 13px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle;white-space:nowrap}.table th{font-size:12px;text-transform:uppercase;letter-spacing:.055em;color:#0b2d66;background:#f4f8ff;font-weight:950}.table tr:last-child td{border-bottom:0}.table tbody tr:hover{background:#fbfdff}.meter{width:130px;max-width:100%;height:9px;border-radius:99px;background:#e2e8f0;overflow:hidden}.meter span{display:block;height:100%;background:linear-gradient(90deg,#22c55e,#f59e0b,#ef4444);border-radius:inherit}.meter-label{margin-top:4px;font-size:11px;color:var(--muted);font-weight:900}

/* ===== Router cards ===== */
.router-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.router-card{display:block;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid var(--line);border-radius:18px;padding:16px;box-shadow:var(--shadow-sm);transition:.16s ease}.router-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:#bad3fb}.router-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.router-metrics{margin-top:12px;display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.router-metrics div{border:1px solid var(--line);background:#fff;border-radius:13px;padding:10px}.router-metrics span{font-size:10px;text-transform:uppercase;color:var(--muted);font-weight:950;letter-spacing:.05em}.router-metrics b{display:block;margin-top:4px;font-size:15px;color:#071a3f}.router-foot{margin-top:12px;color:var(--muted);font-size:12px;line-height:1.5}.router-error{margin-top:10px;border-radius:11px;background:#fff1f2;color:#991b1b;border:1px solid #fecdd3;padding:8px;font-size:12px;font-weight:800}

/* ===== Login ===== */
.login-body{min-height:100vh;margin:0;background:linear-gradient(135deg,#eaf3ff 0%,#f8fbff 45%,#e9f1ff 100%);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;color:#0f172a}.adn-login-bg{background:
    radial-gradient(circle at 10% 12%,rgba(38,114,246,.23),transparent 28%),
    radial-gradient(circle at 90% 12%,rgba(147,197,253,.34),transparent 25%),
    linear-gradient(135deg,#eaf3ff 0%,#f8fbff 47%,#e9f1ff 100%)}
.login-shell{min-height:100vh;display:grid;grid-template-columns:minmax(420px,1.05fr) minmax(380px,.95fr);align-items:stretch}.login-hero{position:relative;overflow:hidden;background:linear-gradient(145deg,#061a42 0%,#0c3b89 58%,#155bd6 100%);color:#fff;padding:50px;display:flex;flex-direction:column;justify-content:space-between}.login-hero:before{content:"";position:absolute;inset:auto -14% -28% auto;width:540px;height:540px;border-radius:999px;background:rgba(255,255,255,.10)}.login-hero:after{content:"";position:absolute;inset:8% auto auto -18%;width:360px;height:360px;border-radius:999px;background:rgba(96,165,250,.20)}.login-hero>*{position:relative;z-index:1}.login-hero-logo{background:rgba(255,255,255,.96);border:1px solid rgba(255,255,255,.55);border-radius:28px;padding:24px;max-width:520px;box-shadow:0 30px 70px rgba(0,0,0,.25)}.login-hero-logo img{display:block;width:100%;height:auto;filter:drop-shadow(0 8px 12px rgba(0,0,0,.12))}.login-hero-title{margin-top:28px}.login-hero-title h1{margin:0;font-size:36px;line-height:1.08;font-weight:950;letter-spacing:-.05em}.login-hero-title p{margin:14px 0 0;color:#dbeafe;font-weight:650;max-width:640px;line-height:1.7}.login-feature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:24px;max-width:650px}.login-feature{border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.09);border-radius:16px;padding:14px;backdrop-filter:blur(8px)}.login-feature i{color:#bfdbfe;margin-right:8px}.login-feature b{display:block;font-size:13px}.login-feature span{display:block;font-size:12px;color:#dbeafe;margin-top:4px}.login-panel{display:grid;place-items:center;padding:34px}.login-card{width:min(455px,94vw);border:1px solid rgba(38,114,246,.17);box-shadow:0 28px 86px rgba(7,26,63,.20);border-radius:26px;background:rgba(255,255,255,.94);padding:30px}.login-card-adn{backdrop-filter:blur(14px)}.login-card-logo{display:none}.login-heading{text-align:left;margin:0 0 18px}.login-title{font-size:24px;font-weight:950;color:#0b2d66;letter-spacing:-.035em}.login-subtitle{font-size:13px;color:#64748b;margin-top:5px;font-weight:750;line-height:1.55}.login-foot{text-align:center;margin-top:16px;color:#64748b;font-size:12px;font-weight:750}.input-icon{position:relative}.input-icon i{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:#2672f6}.input-icon input{padding-left:43px;background:#f8fbff;border-color:#d5e5ff}.login-submit{margin-top:3px;min-height:45px}.login-mini-brand{display:flex;align-items:center;gap:10px;margin-bottom:22px}.login-mini-brand img{width:52px;height:52px;object-fit:contain;border-radius:14px;background:#fff;border:1px solid var(--line);padding:5px}.login-mini-brand b{display:block;color:#0b2d66;font-size:16px}.login-mini-brand span{display:block;color:var(--muted);font-size:12px;font-weight:800}

/* ===== NOC Display ===== */
.display-body{margin:0;background:#020617;color:#e2e8f0;font-family:Inter,system-ui,"Segoe UI",Arial,sans-serif}.display-shell{min-height:100vh;padding:20px;background:radial-gradient(circle at 12% 10%,rgba(38,114,246,.42),transparent 26%),radial-gradient(circle at 84% 0,rgba(96,165,250,.20),transparent 25%),#020617}.display-top{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:16px}.display-title h1{margin:0;font-size:24px;font-weight:950;letter-spacing:-.03em}.display-title p{margin:5px 0 0;color:#9ab0cf}.display-toolbar{display:flex;gap:8px;align-items:center}.display-toolbar select{background:#0f172a;color:#e5e7eb;border-color:#334155;min-width:170px}.display-brand-row{display:flex;align-items:center;gap:14px}.display-brand-row img{width:64px;height:64px;object-fit:contain;border-radius:18px;background:#fff;padding:5px;border:1px solid rgba(96,165,250,.35);box-shadow:0 16px 32px rgba(38,114,246,.24)}.display-kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:14px}.display-card{border:1px solid rgba(96,165,250,.26);background:linear-gradient(180deg,rgba(15,23,42,.95),rgba(2,6,23,.89));border-radius:22px;padding:18px;box-shadow:0 22px 56px rgba(0,0,0,.30)}.display-card .label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:#9ab0cf;font-weight:950}.display-card .value{font-size:32px;font-weight:950;margin-top:8px;color:white;letter-spacing:-.045em}.display-card .note{font-size:12px;color:#9ab0cf;margin-top:6px}.display-card canvas{background:#0b1220;border-color:#1e3a5f}.display-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:14px}.display-router-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.display-router{border:1px solid rgba(148,163,184,.20);background:rgba(15,23,42,.78);border-radius:16px;padding:14px}.display-router h3{margin:0;color:white;font-size:15px;font-weight:950}.display-router .ip{color:#9ab0cf;font-size:12px;margin-top:4px}.display-router .metrics{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:11px}.display-router .metrics div{background:rgba(15,23,42,.9);border:1px solid rgba(148,163,184,.12);border-radius:12px;padding:9px}.display-router span{font-size:10px;text-transform:uppercase;color:#9ab0cf;font-weight:950}.display-router b{display:block;color:white;margin-top:4px}.noc-table{width:100%;border-collapse:collapse}.noc-table th,.noc-table td{border-bottom:1px solid rgba(148,163,184,.16);padding:10px;text-align:left;white-space:nowrap}.noc-table th{color:#9ab0cf;font-size:11px;text-transform:uppercase;letter-spacing:.06em}.noc-table td{color:#e5e7eb}.status-dot{width:10px;height:10px;border-radius:999px;background:#22c55e;display:inline-block;margin-right:6px}.status-dot.off{background:#ef4444}.status-dot.warn{background:#f59e0b}

/* ===== Responsive ===== */
@media(max-width:1280px){.router-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.display-kpis{grid-template-columns:repeat(3,1fr)}.display-router-grid{grid-template-columns:repeat(2,1fr)}.display-grid{grid-template-columns:1fr}.login-shell{grid-template-columns:1fr}.login-hero{min-height:auto;padding:36px}.login-panel{padding:30px}.login-hero-logo{max-width:420px}.login-hero-title h1{font-size:30px}.login-feature-grid{grid-template-columns:repeat(4,1fr);max-width:none}}
@media(max-width:1100px){:root{--sidebar-w:286px}.stats-grid,.grid-4{grid-template-columns:repeat(2,1fr)}.chart-grid,.grid-2{grid-template-columns:1fr}.sidebar{transform:translateX(-105%);transition:.22s ease}.main{margin-left:0;width:100%}.menu-btn{display:block}.sidebar-open .sidebar{transform:translateX(0)}.sidebar-open .sidebar-scrim{display:block}.topbar-actions{display:none}.topbar-logo{display:none}}
@media(max-width:760px){body{font-size:13px}.content{padding:16px}.topbar{padding:0 16px;min-height:70px}.page-head{display:block}.page-head h1{font-size:24px}.toolbar{margin-top:14px;align-items:stretch;flex-direction:column}.toolbar select,.toolbar input{min-width:0}.stats-grid,.display-kpis{grid-template-columns:1fr}.form-row{grid-template-columns:1fr}.card-title-row{align-items:flex-start;flex-direction:column}.stat-value{font-size:23px}.router-grid,.display-router-grid{grid-template-columns:1fr}.router-metrics{grid-template-columns:1fr}.actions{flex-wrap:wrap}.table th,.table td{white-space:normal}.display-top{flex-direction:column;align-items:stretch}.display-toolbar{flex-direction:column}.display-card .value{font-size:26px}.display-brand-row{align-items:flex-start}.display-brand-row img{width:52px;height:52px}.login-hero{padding:24px}.login-hero-logo{display:none}.login-feature-grid{grid-template-columns:1fr 1fr}.login-panel{padding:20px}.login-card{padding:24px;border-radius:22px}.login-card-logo{display:flex;justify-content:center;background:#fff;border:1px solid #e2edff;border-radius:18px;padding:12px;margin-bottom:18px}.login-card-logo img{max-height:135px;object-fit:contain}.login-hero-title h1{font-size:24px}.login-hero-title p{font-size:13px}.login-shell{display:block}.top-subtitle{display:none}.footer{padding:14px 16px}.display-shell{padding:14px}}
@media(max-width:480px){.login-feature-grid{grid-template-columns:1fr}.stat-card{min-height:118px}.table-wrap{border-radius:12px}.card{padding:16px}.btn{width:100%}.actions .btn{width:auto}.display-toolbar .btn{width:100%}}
/* Compatibility for simple access-denied/login cards generated from PHP */
.login-logo{display:block;max-width:260px;max-height:160px;object-fit:contain;margin:0 auto 18px}

/* ===== Globalhome professional responsive cleanup + dark NOC contrast fix ===== */
.card-lite{border:1px solid var(--line);background:linear-gradient(180deg,#f8fbff,#ffffff);border-radius:16px;padding:14px;display:grid;gap:12px;box-shadow:inset 0 1px 0 rgba(255,255,255,.75)}
.card-title-sm{font-size:13px;font-weight:950;letter-spacing:.02em;color:#0b2d66;text-transform:uppercase;display:flex;gap:8px;align-items:center}
.error-text{color:#b91c1c!important;font-weight:850;white-space:normal;max-width:360px}
.badge.alerting{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.table td strong{color:#071a3f}.table td{color:#1f2937}.table .muted{color:#64748b!important}
.table input,.table select{background:#fff;color:#0f172a;border-color:#cbdcf6}.table input[type="checkbox"]{width:18px;height:18px;min-width:18px;accent-color:var(--adn-blue)}
pre.code-block{white-space:pre-wrap;word-break:break-word;line-height:1.55}

.display-body{background:#030712!important;color:#e5edf8!important;overflow-x:hidden}.display-body *{text-shadow:none!important}.display-shell{background:radial-gradient(circle at 10% 0,rgba(38,114,246,.36),transparent 28%),radial-gradient(circle at 88% 0,rgba(14,165,233,.16),transparent 28%),linear-gradient(180deg,#071a3f 0%,#030712 58%,#020617 100%)!important;min-width:0}.display-top{position:sticky;top:0;z-index:5;padding:6px 0 12px;background:linear-gradient(180deg,rgba(3,7,18,.88),rgba(3,7,18,.35),transparent);backdrop-filter:blur(10px)}
.display-title h1,.display-title h1 i{color:#f8fafc!important}.display-title p{color:#b8c7df!important}.display-card{color:#e5edf8!important;background:linear-gradient(180deg,rgba(15,23,42,.96),rgba(5,12,28,.96))!important;border-color:rgba(96,165,250,.30)!important;box-shadow:0 22px 55px rgba(0,0,0,.38)!important}.display-card .label,.display-card .note,.display-router span,.display-router .ip{color:#a8bad6!important}.display-card .value,.display-router h3,.display-router b{color:#fff!important}.display-card canvas{background:#07111f!important;border-color:rgba(96,165,250,.24)!important}.display-brand-row img{background:#fff!important;box-shadow:0 18px 38px rgba(37,99,235,.32)!important}.display-toolbar select,.display-body select{background:#0b1220!important;color:#f8fafc!important;border-color:rgba(148,163,184,.42)!important;box-shadow:none!important}.display-toolbar select option{background:#0b1220;color:#f8fafc}.display-toolbar .btn,.display-body .btn.small{background:#f8fafc!important;color:#061a42!important;border-color:rgba(219,231,251,.9)!important;font-weight:950}.display-toolbar .btn:hover,.display-body .btn.small:hover{background:#dbeafe!important;color:#061a42!important;transform:none!important}.display-body .table-wrap{background:rgba(15,23,42,.82)!important;border-color:rgba(96,165,250,.24)!important;box-shadow:none!important}.display-body .noc-table{width:100%;border-collapse:separate;border-spacing:0;background:transparent!important;color:#e5edf8!important}.display-body .noc-table thead tr{background:rgba(30,58,138,.42)!important}.display-body .noc-table th{color:#bfdbfe!important;background:rgba(30,58,138,.42)!important;border-bottom:1px solid rgba(96,165,250,.30)!important;font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:950}.display-body .noc-table td{color:#e5edf8!important;background:rgba(15,23,42,.46)!important;border-bottom:1px solid rgba(148,163,184,.16)!important;font-weight:800}.display-body .noc-table tr:hover td{background:rgba(30,64,175,.28)!important}.display-body .noc-table td:nth-child(1),.display-body .noc-table td:nth-child(2){color:#ffffff!important}.display-body .noc-table td:nth-child(4),.display-body .noc-table td:nth-child(5){color:#93c5fd!important;font-weight:950}.display-router{background:linear-gradient(180deg,rgba(15,23,42,.88),rgba(6,14,31,.9))!important;border-color:rgba(96,165,250,.26)!important}.display-router .metrics div{background:rgba(2,6,23,.48)!important;border-color:rgba(148,163,184,.18)!important}.display-router-grid{align-items:start}.display-body .badge{box-shadow:none!important}.display-body .muted{color:#a8bad6!important}.display-body .status-dot{box-shadow:0 0 0 4px rgba(34,197,94,.14)}.display-body .status-dot.off{box-shadow:0 0 0 4px rgba(239,68,68,.14)}.display-body .status-dot.warn{box-shadow:0 0 0 4px rgba(245,158,11,.16)}

@media(max-width:1500px){.display-kpis{grid-template-columns:repeat(3,minmax(0,1fr))}.display-router-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.content{padding:22px}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.router-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:980px){:root{--sidebar-w:274px}.display-kpis,.display-router-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.display-grid,.chart-grid,.grid-2{grid-template-columns:1fr!important}.grid-2>.card:first-child{order:0}.table-wrap{max-width:100%}.actions{flex-wrap:wrap}.actions form{display:inline-flex}.card{padding:18px}.top-title{font-size:14px}.top-subtitle{font-size:11px}}
@media(max-width:620px){.display-kpis,.display-router-grid,.stats-grid,.router-grid,.grid-4{grid-template-columns:1fr!important}.display-shell{padding:12px!important}.display-title h1{font-size:18px!important}.display-brand-row{gap:10px!important}.display-brand-row img{width:46px!important;height:46px!important}.display-card{padding:14px!important;border-radius:16px!important}.display-card .value{font-size:24px!important}.display-toolbar{width:100%}.display-toolbar select,.display-toolbar .btn{width:100%;min-width:0!important}.content{padding:14px!important}.page-head h1{font-size:22px!important}.card{padding:14px!important;border-radius:14px!important}.form-row{grid-template-columns:1fr!important}.table th,.table td{font-size:12px;padding:10px 9px}.login-mini-brand b{font-size:14px}.login-title{font-size:21px}}

/* Autosave Interface Role */
.autosave-status{
    display:inline-flex;align-items:center;gap:.45rem;border:1px solid rgba(37,99,235,.22);background:#eff6ff;color:#1e3a8a;border-radius:999px;padding:.48rem .75rem;font-size:.82rem;font-weight:800;white-space:nowrap;
}
.autosave-status.success{border-color:rgba(22,163,74,.28);background:#ecfdf5;color:#065f46;}
.autosave-status.danger{border-color:rgba(220,38,38,.30);background:#fef2f2;color:#991b1b;}
.js-iface-autosave.saving{outline:2px solid rgba(37,99,235,.25);}
.js-iface-autosave.save-ok{outline:2px solid rgba(22,163,74,.35);}
.js-iface-autosave.save-error{outline:2px solid rgba(220,38,38,.45);}
@media (max-width: 768px){.autosave-status{width:100%;justify-content:center}.card-title-row .toolbar{width:100%;display:flex;flex-direction:column;align-items:stretch}}

/* ===== NOC: each router detail cards ===== */
.display-section-title{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:10px 0 12px;color:#e5edf8}
.display-section-title h2{margin:0;font-size:20px;font-weight:950;color:#fff;letter-spacing:-.02em}
.display-section-title p{margin:3px 0 0;color:#b8c7df;font-size:13px}
.display-router-grid-full{grid-template-columns:repeat(2,minmax(360px,1fr));gap:14px;align-items:start}
.display-router-full{padding:16px;min-height:0}
.display-router-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.display-router-head h3{margin:0;display:flex;align-items:center;gap:2px;min-width:0;word-break:break-word}
.display-router-status{border:1px solid rgba(148,163,184,.24);border-radius:999px;padding:5px 9px;font-size:10px;font-weight:950;letter-spacing:.06em;color:#cbd5e1;background:rgba(148,163,184,.10);white-space:nowrap}
.display-router-status.ok{border-color:rgba(34,197,94,.38);background:rgba(34,197,94,.14);color:#bbf7d0}
.display-router-status.warn{border-color:rgba(245,158,11,.38);background:rgba(245,158,11,.14);color:#fde68a}
.display-router-status.off{border-color:rgba(239,68,68,.38);background:rgba(239,68,68,.14);color:#fecaca}
.display-router-metrics-4{grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:12px}
.display-router-chart{width:100%;height:160px;border:1px solid rgba(96,165,250,.24);border-radius:14px;margin:2px 0 12px;display:block;background:#07111f}
.display-router-bottom{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px}
.display-router-bottom>div{border:1px solid rgba(148,163,184,.18);background:rgba(2,6,23,.40);border-radius:12px;padding:10px}
.display-router-bottom span{display:block;font-size:10px;text-transform:uppercase;color:#9ab0cf;font-weight:950;letter-spacing:.05em}.display-router-bottom b{display:block;margin-top:4px;color:#fff;font-size:12px}
.display-top-list{list-style:none;margin:0;padding:0;border:1px solid rgba(148,163,184,.18);border-radius:14px;overflow:hidden;background:rgba(2,6,23,.28)}
.display-top-list li{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:9px 11px;border-bottom:1px solid rgba(148,163,184,.12)}
.display-top-list li:last-child{border-bottom:0}.display-top-list span{color:#f8fafc!important;font-size:12px;font-weight:900;text-transform:none!important;letter-spacing:0!important}.display-top-list small{display:block;color:#93a9c7;font-size:10px;font-weight:900;margin-top:2px}.display-top-list b{color:#93c5fd!important;font-size:12px;white-space:nowrap}.display-router-alert{margin-top:10px;border:1px solid rgba(239,68,68,.30);background:rgba(127,29,29,.24);color:#fecaca;border-radius:12px;padding:9px 10px;font-size:12px;font-weight:850}
@media(max-width:1300px){.display-router-grid-full{grid-template-columns:1fr}.display-router-metrics-4{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:620px){.display-section-title{display:block}.display-section-title h2{font-size:18px}.display-router-grid-full{grid-template-columns:1fr;gap:12px}.display-router-head{display:block}.display-router-status{display:inline-flex;margin-top:8px}.display-router-metrics-4,.display-router-bottom{grid-template-columns:1fr}.display-router-chart{height:140px}}

/* ===== Globalhome Theme Override - Blue/Green Professional ===== */
:root{
    --adn-blue:#087dcc;
    --adn-blue-2:#0076c8;
    --adn-blue-3:#005b9e;
    --adn-navy:#03162e;
    --adn-navy-2:#063a66;
    --adn-sky:#ecfbf6;
    --bg:#eef8f7;
    --panel:#ffffff;
    --panel-soft:#f6fffc;
    --text:#0b172a;
    --muted:#5d7288;
    --line:#d8ecee;
    --line-2:#c4e2e6;
    --wan:#087dcc;
    --lan:#08d88c;
    --success:#08b981;
    --info:#087dcc;
    --shadow:0 18px 45px rgba(3,47,73,.10);
    --shadow-sm:0 9px 24px rgba(3,47,73,.08);
}
.layout{background:
    radial-gradient(circle at 8% 8%,rgba(8,125,204,.13),transparent 28%),
    radial-gradient(circle at 88% 0,rgba(8,216,140,.18),transparent 25%),
    linear-gradient(135deg,#f4fbff 0%,#effaf6 48%,#f9fcff 100%)!important;}
.sidebar{background:linear-gradient(180deg,#03162e 0%,#063a66 54%,#021021 100%)!important;border-right:1px solid rgba(8,216,140,.18)}
.sidebar:before{background:radial-gradient(circle at 35% 0,rgba(8,216,140,.18),transparent 28%),radial-gradient(circle at 90% 18%,rgba(8,125,204,.20),transparent 24%)!important}
.brand-logo-box{width:64px;height:64px;border-radius:20px;box-shadow:0 18px 34px rgba(8,125,204,.24)!important}.brand-logo-box img{width:56px;height:56px}.brand-title{font-size:18px}.brand-subtitle{color:#bff7df!important}
.nav a i{color:#9debd0!important}.nav a.active{background:linear-gradient(90deg,rgba(8,125,204,.28),rgba(8,216,140,.10))!important;box-shadow:inset 4px 0 0 #08d88c!important;border-color:rgba(8,216,140,.22)!important}.nav a:hover{background:rgba(8,216,140,.09)!important}
.topbar{background:rgba(255,255,255,.92)!important;border-bottom:1px solid var(--line)!important}.topbar-logo,.login-mini-brand img{border-color:#caece2!important}.top-title,.brand-title,.page-head h1,.section-title h2,.card-title,.empty-state h2{color:#052248!important}.top-subtitle{color:#557184!important}
.btn.primary{background:linear-gradient(135deg,#087dcc,#08b981)!important;border-color:#087dcc!important;box-shadow:0 12px 24px rgba(8,125,204,.22)!important}.btn.primary:hover{background:linear-gradient(135deg,#006eb7,#06a976)!important}.input-icon i{color:#087dcc!important}input:focus,select:focus,textarea:focus{border-color:#57c5e2!important;box-shadow:0 0 0 4px rgba(8,216,140,.14)!important}
.stat-card:before{background:rgba(8,125,204,.11)!important}.stat-card:after{background:#087dcc!important;box-shadow:0 0 0 8px rgba(8,125,204,.10)!important}.stat-card.lan:before{background:rgba(8,216,140,.12)!important}.stat-card.lan:after{background:#08d88c!important;box-shadow:0 0 0 8px rgba(8,216,140,.11)!important}.stat-icon{color:#b0e8dd!important}
.login-body{background:linear-gradient(135deg,#ebf9ff 0%,#ffffff 42%,#eafff7 100%)!important}.adn-login-bg{background:
    radial-gradient(circle at 18% 10%,rgba(8,125,204,.12),transparent 28%),
    radial-gradient(circle at 90% 88%,rgba(8,216,140,.18),transparent 28%),
    linear-gradient(135deg,#effaff 0%,#fff 48%,#effff8 100%)!important;}
.login-hero{background:linear-gradient(145deg,#03162e 0%,#064b7e 58%,#08b981 140%)!important}.login-hero:before{background:rgba(8,216,140,.13)!important}.login-hero:after{background:rgba(8,125,204,.22)!important}.login-hero-logo{max-width:560px;border-color:rgba(8,216,140,.35)!important}.login-feature{border-color:rgba(190,247,223,.22)!important;background:rgba(255,255,255,.10)!important}.login-feature i{color:#a7f3d0!important}.login-title,.login-mini-brand b{color:#052248!important}.login-card{border-color:rgba(8,125,204,.18)!important;box-shadow:0 28px 86px rgba(3,47,73,.18)!important}
.display-shell{background:radial-gradient(circle at 10% 0,rgba(8,125,204,.34),transparent 28%),radial-gradient(circle at 88% 0,rgba(8,216,140,.16),transparent 28%),linear-gradient(180deg,#03162e 0%,#07111f 55%,#020617 100%)!important}.display-brand-row img{box-shadow:0 18px 38px rgba(8,125,204,.28)!important;border-color:rgba(8,216,140,.35)!important}.display-card{border-color:rgba(8,125,204,.30)!important}.display-body .noc-table thead tr,.display-body .noc-table th{background:linear-gradient(90deg,rgba(8,82,154,.62),rgba(7,119,124,.52))!important;border-bottom:1px solid rgba(8,216,140,.24)!important}.display-body .noc-table td:nth-child(4),.display-body .noc-table td:nth-child(5),.display-top-list b{color:#a7f3d0!important}.display-router-status.ok{border-color:rgba(8,216,140,.38)!important;background:rgba(8,216,140,.14)!important;color:#b6ffe2!important}.status-dot{background:#08d88c!important}.status-dot.off{background:#ef4444!important}.status-dot.warn{background:#f59e0b!important}.rx-dot{background:#087dcc!important}.tx-dot{background:#08d88c!important}
.login-logo-wrap,.login-card-logo{background:#fff;border:1px solid #d6eee9;border-radius:20px;padding:14px}.login-logo{display:block;max-width:min(520px,85vw);height:auto;margin:0 auto}.login-hero-logo img{max-height:300px;object-fit:contain}.login-card-logo img{max-height:150px;object-fit:contain}
@media(max-width:760px){.brand-logo-box{width:54px;height:54px}.brand-logo-box img{width:48px;height:48px}.login-hero-logo img{max-height:210px}.login-card-logo img{max-height:120px}.top-title{font-size:14px}.brand-title{font-size:16px}}
