:root{--bg: #0c0d10;--bg-elevated: #111318;--surface: #14161c;--surface-2: #1a1d24;--surface-3: #21252e;--border: #23262e;--border-strong: #303542;--text: #e9eaee;--muted: #9299a6;--faint: #626977;--accent: #2dd4bf;--on-accent: #062822;--accent-soft: rgba(45, 212, 191, .13);--success: #4ade80;--success-soft: rgba(74, 222, 128, .12);--warning: #fbbf24;--warning-soft: rgba(251, 191, 36, .12);--danger: #f87171;--danger-soft: rgba(248, 113, 113, .1);--radius: 14px;--radius-sm: 11px;--shadow: 0 18px 48px rgba(0, 0, 0, .4);--shadow-sm: 0 4px 16px rgba(0, 0, 0, .25);--font: Inter, ui-sans-serif, system-ui, "Segoe UI", sans-serif;--font-display: Sora, Inter, ui-sans-serif, system-ui, sans-serif;--ease: cubic-bezier(.22, .61, .36, 1);--dur-1: .15s;--dur-2: .28s;--dur-3: .48s}[data-theme=light]{--bg: #f5f5f2;--bg-elevated: #ffffff;--surface: #ffffff;--surface-2: #f0f0ec;--surface-3: #e8e8e2;--border: #e3e3dd;--border-strong: #c9c9c1;--text: #1c1e23;--muted: #5d636e;--faint: #9aa0a9;--accent: #0d9488;--on-accent: #ffffff;--accent-soft: rgba(13, 148, 136, .1);--success: #16a34a;--success-soft: rgba(22, 163, 74, .1);--warning: #b45309;--warning-soft: rgba(180, 83, 9, .1);--danger: #dc2626;--danger-soft: rgba(220, 38, 38, .07);--shadow: 0 18px 48px rgba(28, 30, 35, .1);--shadow-sm: 0 4px 16px rgba(28, 30, 35, .07)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font:15px/1.6 var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;transition:background var(--dur-2) var(--ease),color var(--dur-2) var(--ease)}h1,h2,h3{margin:0;font-family:var(--font-display);font-weight:600;letter-spacing:-.015em}h1{font-size:25px;font-weight:700}h2{font-size:16.5px}p{margin:0}a{color:var(--accent);text-decoration:none;transition:color var(--dur-1) var(--ease)}a:hover{text-decoration:underline}::selection{background:var(--accent-soft)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border:1px solid transparent;border-radius:var(--radius-sm);font:600 14px var(--font);color:var(--on-accent);cursor:pointer;background:var(--accent);transition:filter var(--dur-1) var(--ease),transform var(--dur-1) var(--ease),box-shadow var(--dur-2) var(--ease),background var(--dur-1) var(--ease),border-color var(--dur-1) var(--ease),color var(--dur-1) var(--ease),opacity var(--dur-1) var(--ease);white-space:nowrap}.btn:hover{filter:brightness(1.07);box-shadow:0 6px 18px var(--accent-soft)}.btn:active{transform:scale(.98)}.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.btn:disabled{opacity:.5;cursor:default;filter:none;box-shadow:none}.btn.ghost{background:var(--surface-2);border-color:var(--border);color:var(--text)}.btn.ghost:hover{border-color:var(--border-strong);background:var(--surface-3);filter:none;box-shadow:none}.btn.danger{background:var(--danger-soft);border-color:var(--danger);color:var(--danger)}.btn.danger:hover{background:var(--danger);color:var(--bg-elevated);filter:none;box-shadow:none}.btn.sm{padding:6px 13px;font-size:13px}.field{margin-bottom:16px}.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px;font-weight:500}.field input,.input{width:100%;padding:11px 14px;border-radius:var(--radius-sm);font:14.5px var(--font);background:var(--surface-2);border:1px solid var(--border);color:var(--text);outline:none;transition:border-color var(--dur-1) var(--ease),box-shadow var(--dur-2) var(--ease),background var(--dur-1) var(--ease)}.field input:focus,.input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);background:var(--surface)}.field .hint{font-size:12.5px;color:var(--faint);margin-top:5px}.form-error{background:var(--danger-soft);border:1px solid var(--danger);color:var(--danger);border-radius:var(--radius-sm);padding:10px 13px;font-size:13.5px;margin-bottom:16px;animation:slide-down var(--dur-2) var(--ease)}.form-success{background:var(--success-soft);border:1px solid var(--success);color:var(--success);border-radius:var(--radius-sm);padding:10px 13px;font-size:13.5px;margin-bottom:16px;animation:slide-down var(--dur-2) var(--ease)}@keyframes slide-down{0%{opacity:0;transform:translateY(-6px)}}.auth-shell{min-height:100%;display:grid;place-items:center;padding:24px}.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:38px 34px;box-shadow:var(--shadow);animation:rise var(--dur-3) var(--ease)}@keyframes rise{0%{opacity:0;transform:translateY(14px)}}.auth-card h1{font-size:21px;margin-bottom:5px}.auth-card .sub{color:var(--muted);font-size:14px;margin-bottom:26px}.auth-card .btn{width:100%;margin-top:8px;padding:12px}.auth-foot{text-align:center;margin-top:20px;font-size:13.5px;color:var(--muted)}.brand{display:flex;align-items:center;gap:10px;margin-bottom:26px;-webkit-user-select:none;user-select:none}.brand-dot{width:30px;height:30px;border-radius:9px;flex:none;background:var(--accent);display:grid;place-items:center;color:var(--on-accent);font:700 14px var(--font-display)}.brand span{font:600 15px var(--font-display);letter-spacing:.01em}.shell{display:flex;min-height:100%}.sidebar{width:254px;flex:none;padding:24px 16px 18px;border-right:1px solid var(--border);background:var(--bg-elevated);display:flex;flex-direction:column;gap:3px;position:sticky;top:0;height:100vh;transition:background var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease)}.sidebar .brand{padding:0 12px;margin-bottom:28px}.nav-link{position:relative;display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);color:var(--muted);font-size:14px;font-weight:500;transition:background var(--dur-1) var(--ease),color var(--dur-1) var(--ease),padding-left var(--dur-2) var(--ease)}.nav-link:hover{background:var(--surface-2);color:var(--text);text-decoration:none}.nav-link.active{background:var(--accent-soft);color:var(--accent)}.nav-link.active:before{content:"";position:absolute;left:0;top:22%;bottom:22%;width:3px;border-radius:3px;background:var(--accent);animation:grow-in var(--dur-2) var(--ease)}@keyframes grow-in{0%{transform:scaleY(0)}}.nav-link svg{width:18px;height:18px;flex:none}.sidebar-tools{display:flex;gap:8px;padding:10px 12px 4px;margin-top:auto}.tool-btn{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:7px 10px;border-radius:9px;border:1px solid var(--border);background:var(--surface-2);color:var(--muted);font:500 12.5px var(--font);cursor:pointer;transition:color var(--dur-1) var(--ease),border-color var(--dur-1) var(--ease),background var(--dur-1) var(--ease)}.tool-btn:hover{color:var(--text);border-color:var(--border-strong)}.tool-btn svg{width:15px;height:15px}.sidebar-user{display:flex;align-items:center;gap:11px;padding:14px 12px 0;border-top:1px solid var(--border);margin-top:10px}.sidebar-user .name{font-size:13.5px;font-weight:600;line-height:1.3}.sidebar-user .email{font-size:12px;color:var(--faint);word-break:break-all}.main{flex:1;min-width:0;padding:40px 48px 64px;max-width:980px}.page{animation:page-in var(--dur-3) var(--ease)}@keyframes page-in{0%{opacity:0;transform:translateY(10px)}}.page-head{margin-bottom:28px}.page-head p{color:var(--muted);margin-top:6px;font-size:14.5px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:20px;transition:background var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease);animation:card-in var(--dur-3) var(--ease) backwards}.card:nth-child(2){animation-delay:40ms}.card:nth-child(3){animation-delay:80ms}.card:nth-child(4){animation-delay:.12s}.card:nth-child(5){animation-delay:.16s}.card:nth-child(6){animation-delay:.2s}@keyframes card-in{0%{opacity:0;transform:translateY(8px)}}.card h2{margin-bottom:4px}.card .card-sub{color:var(--muted);font-size:13.5px;margin-bottom:18px}.card.danger-zone{border-color:var(--danger)}.row{display:flex;align-items:center;gap:14px}.row.between{justify-content:space-between}.stack{display:flex;flex-direction:column;gap:4px}.avatar{border-radius:50%;overflow:hidden;flex:none;background:var(--accent);display:grid;place-items:center;color:var(--on-accent);font-family:var(--font-display);font-weight:700;-webkit-user-select:none;user-select:none}.avatar img{width:100%;height:100%;object-fit:cover;display:block}.list{display:flex;flex-direction:column}.list-item{display:flex;align-items:center;gap:14px;padding:15px 8px;border-bottom:1px solid var(--border);border-radius:var(--radius-sm);transition:background var(--dur-1) var(--ease);animation:card-in var(--dur-2) var(--ease) backwards}.list-item:nth-child(2){animation-delay:30ms}.list-item:nth-child(3){animation-delay:60ms}.list-item:nth-child(4){animation-delay:90ms}.list-item:nth-child(5){animation-delay:.12s}.list-item:nth-child(6){animation-delay:.15s}.list-item:nth-child(7){animation-delay:.18s}.list-item:hover{background:var(--surface-2)}.list-item:last-child{border-bottom:0}.list-item .grow{flex:1;min-width:0}.list-item .title{font-size:14px;font-weight:600}.list-item .meta{font-size:12.5px;color:var(--muted);margin-top:2px}.icon-chip{width:38px;height:38px;border-radius:11px;flex:none;background:var(--surface-2);border:1px solid var(--border);display:grid;place-items:center;color:var(--muted);transition:border-color var(--dur-1) var(--ease)}.icon-chip svg{width:18px;height:18px}.icon-chip.ok{color:var(--success)}.icon-chip.warn{color:var(--warning)}.icon-chip.bad{color:var(--danger)}.badge{display:inline-block;font-size:11.5px;font-weight:600;padding:2.5px 9px;border-radius:99px;background:var(--accent-soft);color:var(--accent)}.badge.green{background:var(--success-soft);color:var(--success)}.badge.amber{background:var(--warning-soft);color:var(--warning)}.graph-wrap{position:relative;height:min(66vh,640px);min-height:420px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:background var(--dur-2) var(--ease),border-color var(--dur-2) var(--ease)}.graph-wrap svg{display:block;width:100%;height:100%}.graph-empty{position:absolute;left:50%;top:calc(50% + 76px);transform:translate(-50%);text-align:center;color:var(--muted);font-size:14px;width:85%;max-width:380px;pointer-events:none}.graph-node{cursor:pointer}.graph-node:focus{outline:none}.service-card{position:absolute;z-index:5;width:264px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow);animation:scale-in var(--dur-2) var(--ease)}@keyframes scale-in{0%{opacity:0;transform:scale(.96) translateY(4px)}}.service-card .scopes{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0 12px}.service-card .meta-line{font-size:12.5px;color:var(--muted);margin-top:3px}.service-list{display:none}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;background:#08090c9e;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fade var(--dur-2) var(--ease);padding:20px}@keyframes fade{0%{opacity:0}}.modal{width:100%;max-width:420px;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:18px;padding:26px;box-shadow:var(--shadow);animation:scale-in var(--dur-2) var(--ease)}.modal h2{margin-bottom:6px;font-size:18px}.modal .sub{color:var(--muted);font-size:13.5px;margin-bottom:18px}.modal .actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.toast{position:fixed;bottom:26px;left:50%;transform:translate(-50%);z-index:80;background:var(--bg-elevated);border:1px solid var(--border-strong);border-radius:12px;padding:11px 18px;font-size:14px;box-shadow:var(--shadow);animation:toast-in var(--dur-2) var(--ease);display:flex;align-items:center;gap:9px}.toast.success{border-color:var(--success)}.toast.error{border-color:var(--danger)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%,12px)}}.qr-box{background:#fff;border-radius:var(--radius-sm);padding:12px;width:fit-content;margin:6px 0 12px}.secret-code{font-family:ui-monospace,Cascadia Code,Consolas,monospace;font-size:13px;background:var(--surface-2);border:1px solid var(--border);padding:8px 12px;border-radius:8px;letter-spacing:1px;-webkit-user-select:all;user-select:all;word-break:break-all;display:inline-block}.spinner{width:22px;height:22px;border-radius:50%;border:2.5px solid var(--border-strong);border-top-color:var(--accent);animation:spin .7s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}.menu-btn{display:none}@media(max-width:860px){.shell{flex-direction:column}.sidebar{position:fixed;inset:0 auto 0 0;z-index:40;height:100dvh;transform:translate(-100%);transition:transform var(--dur-2) var(--ease);width:272px}.sidebar.open{transform:none;box-shadow:var(--shadow)}.main{padding:22px 18px 56px}.menu-btn{display:inline-flex;align-items:center;gap:9px;background:none;border:0;color:var(--text);font:600 15px var(--font-display);padding:0;margin-bottom:20px;cursor:pointer}.menu-btn svg{width:22px;height:22px}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:39;background:#08090c80;animation:fade var(--dur-2) var(--ease)}.graph-wrap{display:none}.service-list{display:block}}
