:root{--bg: #0b1220;--bg-soft: #16213a;--panel: #ffffff;--panel-soft: #f6f8fb;--border: #e4e9f2;--text: #101828;--text-soft: #667085;--primary: #2563eb;--primary-dark: #1d4ed8;--primary-soft: #eff4ff;--accent: #7c3aed;--green: #16a34a;--amber: #d97706;--red: #dc2626;--slate: #64748b;--radius: 12px;--radius-sm: 8px;--shadow: 0 1px 2px rgba(16, 24, 40, .05), 0 1px 3px rgba(16, 24, 40, .06);--shadow-lift: 0 4px 12px rgba(16, 24, 40, .08), 0 2px 4px rgba(16, 24, 40, .05);--sidebar-w: 250px;--header-h: 56px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}html{-webkit-text-size-adjust:100%}body{font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--panel-soft);color:var(--text);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3{margin:0 0 .25rem;letter-spacing:-.01em}code,pre{font-family:ui-monospace,SFMono-Regular,Menlo,monospace}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.app{display:flex;min-height:100vh;min-height:100dvh}.sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,var(--bg) 0%,#0e1730 100%);color:#cbd5e1;display:flex;flex-direction:column;flex-shrink:0}.sidebar .brand{padding:1.4rem 1.25rem 1rem;display:flex;align-items:center;gap:.7rem}.sidebar .brand .logo{width:36px;height:36px;border-radius:10px;flex-shrink:0;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:.85rem;letter-spacing:.02em}.sidebar .brand h1{color:#fff;font-size:1.05rem;margin:0}.sidebar .brand p{color:#8294ab;font-size:.72rem;margin:0}.sidebar nav{padding:.6rem;flex:1;overflow-y:auto}.sidebar nav a{display:flex;align-items:center;gap:.65rem;padding:.65rem .8rem;border-radius:var(--radius-sm);color:#b6c2d4;font-weight:500;margin-bottom:2px;border-left:3px solid transparent;transition:background .15s,color .15s}.sidebar nav a:hover{background:#94a3b81f;text-decoration:none;color:#fff}.sidebar nav a.active{background:linear-gradient(90deg,#2563eb40,#2563eb1a);border-left-color:var(--primary);color:#fff}.sidebar .org{padding:1rem 1.25rem calc(1rem + env(safe-area-inset-bottom));border-top:1px solid rgba(148,163,184,.15);font-size:.8rem}.sidebar .org .name{color:#fff;font-weight:600}.sidebar .org button{margin-top:.6rem}.main{flex:1;overflow:auto;min-width:0}.topbar{padding:1.25rem clamp(1rem,3vw,2rem);border-bottom:1px solid var(--border);background:var(--panel)}.topbar h2{font-size:1.4rem}.topbar p{color:var(--text-soft);margin:0}.content{padding:clamp(1rem,3vw,1.75rem) clamp(1rem,3vw,2rem)}.mobile-header{display:none;position:sticky;top:0;z-index:40;height:var(--header-h);align-items:center;gap:.75rem;padding:0 .75rem;background:var(--bg);color:#fff;padding-top:env(safe-area-inset-top)}.mobile-header .nav-toggle{background:transparent;border:none;color:#e2e8f0;padding:.55rem;border-radius:var(--radius-sm);display:inline-flex;min-height:44px;min-width:44px;align-items:center;justify-content:center}.mobile-header .nav-toggle:hover{background:#94a3b826}.mobile-header .mobile-brand{font-weight:700;font-size:1rem;display:flex;align-items:center;gap:.55rem}.mobile-header .logo{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:.68rem}.backdrop{display:none}@media (max-width: 920px){.app{flex-direction:column}.mobile-header{display:flex}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:60;transform:translate(-100%);transition:transform .22s ease;box-shadow:none;width:min(var(--sidebar-w),82vw)}.app.nav-open .sidebar{transform:translate(0);box-shadow:0 0 40px #00000073}.backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#0b12208c;opacity:0;pointer-events:none;transition:opacity .22s ease}.app.nav-open .backdrop{opacity:1;pointer-events:auto}.main{overflow:visible}}.panel{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.panel-pad{padding:1.25rem}.grid{display:grid;gap:1rem}.grid.cols-4{grid-template-columns:repeat(4,1fr)}.grid.cols-2{grid-template-columns:repeat(2,1fr)}@media (max-width: 1100px){.grid.cols-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 920px){.grid.cols-2{grid-template-columns:1fr}}@media (max-width: 480px){.grid{gap:.75rem}}.stat{padding:1rem 1.25rem}.stat .label{color:var(--text-soft);font-size:.76rem;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.stat .value{font-size:1.8rem;font-weight:700;letter-spacing:-.02em}@media (max-width: 480px){.stat{padding:.8rem .9rem}.stat .value{font-size:1.4rem}}.badge{display:inline-flex;align-items:center;gap:.35rem;padding:.18rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600;white-space:nowrap}.dot{width:.55rem;height:.55rem;border-radius:50%;display:inline-block;flex-shrink:0}.badge.healthy{background:#dcfce7;color:#166534}.badge.warning{background:#fef3c7;color:#92400e}.badge.failed{background:#fee2e2;color:#991b1b}.badge.offline{background:#e2e8f0;color:#334155}.badge.never{background:#ede9fe;color:#5b21b6}.badge.pending{background:#fef3c7;color:#92400e}.badge.applied{background:#dcfce7;color:#166534}.dot.healthy{background:var(--green)}.dot.warning,.dot.pending{background:var(--amber)}.dot.failed{background:var(--red)}.dot.offline{background:var(--slate)}.dot.never{background:#7c3aed}.dot.applied{background:var(--green)}.pill{background:var(--panel-soft);border:1px solid var(--border);border-radius:6px;padding:.1rem .45rem;font-size:.72rem;color:var(--text-soft);white-space:nowrap}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:inherit}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.7rem .9rem;border-bottom:1px solid var(--border)}tbody tr:last-child td{border-bottom:none}th{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-soft);background:var(--panel-soft);white-space:nowrap}tbody tr:hover{background:var(--panel-soft);cursor:pointer}td.mono,.mono{font-family:ui-monospace,monospace;font-size:.8rem}button{font:inherit;cursor:pointer;border:1px solid transparent;border-radius:var(--radius-sm);padding:.55rem 1rem;font-weight:600;background:var(--primary);color:#fff;min-height:38px;transition:background .15s,box-shadow .15s,transform .05s}button:hover{background:var(--primary-dark);box-shadow:var(--shadow)}button:active{transform:translateY(1px)}button.secondary{background:#fff;color:var(--text);border-color:var(--border)}button.secondary:hover{background:var(--panel-soft)}button.danger{background:var(--red)}button.danger:hover{background:#b91c1c}button:disabled{opacity:.5;cursor:not-allowed}button.small{padding:.3rem .65rem;font-size:.8rem;min-height:30px}label{display:block;font-weight:600;font-size:.82rem;margin:.75rem 0 .25rem}input,select,textarea{width:100%;font:inherit;padding:.55rem .7rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--text);transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb26}@media (max-width: 640px){input,select,textarea{font-size:16px}}.hint{color:var(--text-soft);font-size:.78rem;margin-top:.2rem}.row{display:flex;gap:1rem}.row>*{flex:1}@media (max-width: 640px){.row{flex-direction:column;gap:0}.row>*{max-width:none!important}}.toolbar{display:flex;gap:.75rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap}.toolbar .spacer{flex:1}.toolbar input,.toolbar select{width:auto}@media (max-width: 640px){.toolbar input{width:100%;min-width:0!important}.toolbar select{flex:1}}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:1rem;background:radial-gradient(1200px 800px at 80% -10%,#1e3a8a55 0%,transparent 60%),var(--bg)}.login-card{background:#fff;border-radius:16px;padding:2rem;width:min(380px,100%);box-shadow:0 10px 40px #0006}.login-card h1{font-size:1.5rem}.login-card .sub{color:var(--text-soft);margin-bottom:1rem}.login-card button{width:100%;margin-top:1rem}.login-card .logo{width:42px;height:42px;border-radius:12px;margin-bottom:.9rem;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:.95rem}.error{background:#fee2e2;color:#991b1b;padding:.55rem .75rem;border-radius:var(--radius-sm);font-size:.85rem}.success{background:#dcfce7;color:#166534;padding:.55rem .75rem;border-radius:var(--radius-sm);font-size:.85rem}.notice{background:#fef9c3;color:#854d0e;padding:.55rem .75rem;border-radius:var(--radius-sm);font-size:.85rem;border:1px solid #fde68a}pre.script{background:var(--bg);color:#e2e8f0;padding:1rem;border-radius:var(--radius-sm);overflow:auto;font-size:.78rem;line-height:1.45;max-width:100%}.muted{color:var(--text-soft)}.mt{margin-top:1rem}.mb{margin-bottom:1rem}.flex{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.between{justify-content:space-between}.tag{display:inline-block;background:#eff6ff;color:#1e40af;border-radius:6px;padding:.05rem .4rem;font-size:.72rem;margin-right:.25rem}.back-link{display:inline-block;margin-bottom:.5rem}.loglevel-error{color:var(--red);font-weight:600}.loglevel-warn{color:var(--amber);font-weight:600}.loglevel-info{color:var(--text-soft)}.setting-card{display:block;padding:1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--panel-soft);color:var(--text);text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .15s}.setting-card:hover{border-color:var(--primary);box-shadow:var(--shadow-lift);text-decoration:none;transform:translateY(-1px)}.setting-card h4{margin:0 0 .35rem}.setting-card p{margin:0 0 .5rem;font-size:.82rem}.setting-card-go{color:var(--primary);font-size:.8rem;font-weight:600}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:flex-start;justify-content:center;padding:3rem 1rem;overflow:auto;z-index:80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{width:520px;max-width:100%;background:#fff}@media (max-width: 640px){.modal-overlay{padding:1rem .5rem}}
