@import url("https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=JetBrains+Mono:wght@400;500&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0c10;--bg-elevated:#0e1016;--surface:#13151c;--surface-2:#181b24;--surface-hover:#1d2029;--surface-active:#22252f;--border:rgba(255,255,255,0.06);--border-subtle:rgba(255,255,255,0.04);--border-strong:rgba(255,255,255,0.1);--text:#e8e9ed;--text-secondary:#a0a3ad;--text-muted:#6b6e7a;--text-faint:#4a4d57;--primary:#6366f1;--primary-hover:#7477f5;--primary-muted:rgba(99,102,241,0.12);--primary-glow:rgba(99,102,241,0.06);--green:#34d399;--green-muted:rgba(52,211,153,0.12);--red:#f87171;--red-muted:rgba(248,113,113,0.12);--yellow:#fbbf24;--yellow-muted:rgba(251,191,36,0.12);--blue:#60a5fa;--blue-muted:rgba(96,165,250,0.12);--radius:8px;--radius-lg:12px;--radius-xl:16px;--shadow-sm:0 1px 2px rgba(0,0,0,0.3);--shadow-md:0 4px 12px rgba(0,0,0,0.25);--shadow-lg:0 8px 32px rgba(0,0,0,0.35);--shadow-glow:0 0 20px rgba(99,102,241,0.08);--font-sans:"DM Sans",-apple-system,BlinkMacSystemFont,sans-serif;--font-mono:"JetBrains Mono","SF Mono","Fira Code",monospace;--transition-fast:120ms ease;--transition:200ms ease;--transition-slow:350ms cubic-bezier(0.4,0,0.2,1)}html{font-size:15px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.5;overflow-x:hidden;height:100vh;height:100dvh;overflow:hidden}::selection{background:rgba(99,102,241,.3);color:white}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;height:100dvh;gap:14px}.loading-spinner{width:20px;height:20px;border:2px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.loading-text{font-size:.9rem;color:var(--text-muted);font-weight:500;letter-spacing:.02em}@keyframes spin{to{transform:rotate(1turn)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-border{0%,to{border-color:rgba(99,102,241,.15)}50%{border-color:rgba(99,102,241,.35)}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:24px;background:radial-gradient(ellipse 60% 50% at 50% 0,rgba(99,102,241,.08) 0,transparent 60%),var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-xl);padding:3rem 2.5rem;text-align:center;max-width:420px;width:100%;box-shadow:var(--shadow-lg),var(--shadow-glow);animation:fadeIn .5s ease}.login-logo{width:56px;height:56px;margin:0 auto 20px;border-radius:var(--radius-lg);object-fit:contain}.login-card h1{font-size:1.5rem;font-weight:700;margin-bottom:6px;letter-spacing:-.02em}.login-subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:2rem;line-height:1.6}.login-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 24px;background:#ffffff;color:#1f1f1f;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);font-size:.9rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition);letter-spacing:.01em}.login-btn:hover{background:#f1f1f1;box-shadow:0 2px 12px rgba(255,255,255,.1);transform:translateY(-1px)}.login-btn:active{transform:translateY(0)}.login-btn svg{width:18px;height:18px;flex-shrink:0}.app{display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden}.topbar{gap:16px;height:56px;padding:0 24px;background:var(--bg-elevated);border-bottom:1px solid var(--border);position:-webkit-sticky;position:sticky;top:0;z-index:100;flex-shrink:0}.topbar,.topbar-brand{display:flex;align-items:center}.topbar-brand{gap:10px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;transition:opacity var(--transition-fast)}.topbar-brand:hover{opacity:.8}.topbar-brand img{width:28px;height:28px;border-radius:6px}.topbar-brand span{font-size:.95rem;font-weight:600;letter-spacing:-.01em;color:var(--text)}.topbar-right{margin-left:auto;gap:16px}.topbar-right,.ws-indicator{display:flex;align-items:center}.ws-indicator{gap:6px;font-size:.75rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase;color:var(--text-muted)}.ws-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.ws-dot.on{background:var(--green);box-shadow:0 0 6px rgba(52,211,153,.5)}.ws-dot.off{background:var(--text-faint)}.user-chip{gap:8px;padding:4px 12px 4px 6px;background:var(--surface);border:1px solid var(--border);border-radius:20px;font-size:.8rem;color:var(--text-secondary)}.user-avatar,.user-chip{display:flex;align-items:center}.user-avatar{width:24px;height:24px;border-radius:50%;background:var(--primary-muted);color:var(--primary);justify-content:center;font-size:.65rem;font-weight:700;text-transform:uppercase}.topbar-logout{background:none;border:1px solid var(--border);color:var(--text-muted);padding:5px 12px;border-radius:var(--radius);font-size:.75rem;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:all var(--transition-fast)}.topbar-logout:hover{color:var(--text);border-color:var(--border-strong);background:var(--surface)}.hamburger{display:none;background:none;border:none;color:var(--text);font-size:1.2rem;cursor:pointer;padding:4px}.layout{display:flex;flex:1 1;overflow:hidden}.sidebar{width:220px;background:var(--bg-elevated);border-right:1px solid var(--border);padding:16px 12px;flex-shrink:0;display:flex;flex-direction:column;gap:2px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:9px 14px;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius);font-size:.85rem;font-weight:500;font-family:var(--font-sans);transition:all var(--transition-fast);letter-spacing:.01em}.nav-item:hover{background:var(--surface-hover);color:var(--text-secondary)}.nav-item.active{background:var(--primary-muted);color:var(--primary-hover);font-weight:600}.nav-icon{width:18px;height:18px;opacity:.7;flex-shrink:0}.nav-item.active .nav-icon{opacity:1}.nav-spacer{flex:1 1;min-height:8px}a.nav-item.nav-external{text-decoration:none;font-size:.8rem;color:var(--text-faint);opacity:.8}a.nav-item.nav-external:hover{color:var(--text-secondary);opacity:1}.content-scroll{flex:1 1;overflow-y:auto;overflow-x:hidden}.content{max-width:1200px;margin:0 auto;padding:32px;animation:fadeIn .3s ease}.bottom-tabs{display:none}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page-title{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.page-title .count{font-weight:400;color:var(--text-muted);font-size:1rem;margin-left:4px}.page-actions{display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface);color:var(--text-secondary);cursor:pointer;font-size:.825rem;font-weight:500;font-family:var(--font-sans);transition:all var(--transition-fast);white-space:nowrap;letter-spacing:.01em}.btn:hover{background:var(--surface-hover);color:var(--text);border-color:var(--border-strong)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);border-color:var(--primary);color:white;font-weight:600}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 0 16px rgba(99,102,241,.15);color:white}.btn-sm{padding:5px 10px;font-size:.75rem}.btn-danger{background:transparent;border-color:rgba(248,113,113,.3);color:var(--red)}.btn-danger:hover{background:var(--red-muted);border-color:rgba(248,113,113,.5);color:var(--red)}.btn-ghost{background:none;border:none;padding:6px 10px;color:var(--text-muted)}.btn-ghost:hover{color:var(--text);background:var(--surface-hover)}.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:.85rem}.col-check{width:40px;text-align:center}.col-status{white-space:nowrap;width:85px}.col-name{max-width:200px}.col-groups,.col-license,.col-role{white-space:nowrap}.col-groups{max-width:130px}.col-actions,.col-seen,.col-usage,.col-version{white-space:nowrap}.col-actions{width:120px}.version-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;letter-spacing:.3px}.version-current{background:rgba(16,185,129,.15);color:#10b981}.outdated-badge,.version-outdated{background:rgba(245,158,11,.15);color:#f59e0b}.outdated-badge{display:inline-block;padding:1px 6px;border-radius:4px;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;margin-top:3px;line-height:1.4}.version-label{display:block;font-size:10px;color:#6b7280;margin-top:2px}.version-label.outdated{color:#f59e0b}.version-label.unknown{color:#4b5563;font-style:italic}.install-group-select{flex:1 1;padding:6px 10px;background:var(--bg-secondary);color:var(--text-primary);font-size:13px}.install-group-select,.show-archived-btn{border:1px solid var(--border);border-radius:6px}.show-archived-btn{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:6px 12px;font-size:12px;color:var(--text-secondary);background:none;cursor:pointer;transition:color .15s,border-color .15s}.show-archived-btn:hover{color:var(--text-primary);border-color:var(--text-secondary)}.updating-badge{display:inline-flex;align-items:center;gap:4px;padding:1px 6px;border-radius:4px;font-size:9px;font-weight:600;background:rgba(99,102,241,.15);color:#818cf8;margin-top:3px;line-height:1.4}.machine-menu-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--text-secondary);border-radius:6px;cursor:pointer;transition:background .15s,color .15s}.machine-menu-btn:hover{background:rgba(255,255,255,.08);color:var(--text-primary)}.machine-menu-dropdown{position:fixed;transform:translateX(-100%);min-width:180px;background:#1e2130;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:4px;z-index:9999;box-shadow:0 8px 24px rgba(0,0,0,.6)}.machine-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:transparent;color:var(--text-primary);font-size:13px;border-radius:6px;cursor:pointer;text-align:left;transition:background .12s}.machine-menu-item:hover:not(:disabled){background:rgba(255,255,255,.06)}.machine-menu-item:disabled{opacity:.5;cursor:default}.machine-menu-danger{color:#f87171}.machine-menu-danger:hover:not(:disabled){background:rgba(248,113,113,.1)}.machine-menu-result{padding:6px 12px;font-size:11px;font-weight:600;text-align:center;border-top:1px solid var(--border);margin-top:4px}.result-valid{color:#6ee7b7}.result-invalid{color:#fca5a5}.test-modal-machine{font-size:14px;color:var(--text-secondary);margin-bottom:16px}.test-modal-steps{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.test-step{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-secondary)}.test-step.step-active{color:var(--text-primary)}.test-step.step-done{color:var(--text-secondary);opacity:.6}.test-step.step-pending{opacity:.3}.test-step-icon{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:rgba(255,255,255,.06);font-size:11px;font-weight:600;flex-shrink:0}.test-result-box{border-radius:8px;padding:14px;margin-top:4px}.test-result-box.test-valid{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25)}.test-result-box.test-invalid{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25)}.test-result-header{display:flex;align-items:center;gap:8px;font-size:14px;margin-bottom:10px}.test-valid .test-result-header{color:#6ee7b7}.test-invalid .test-result-header{color:#fca5a5}.test-result-row{display:flex;align-items:baseline;gap:8px;font-size:12px;padding:3px 0;color:var(--text-secondary)}.test-label{font-weight:600;color:var(--text-primary);min-width:55px;opacity:.7}.test-result-row code{font-family:monospace;font-size:11px;background:rgba(255,255,255,.06);padding:1px 5px;border-radius:3px}.test-error-text{color:#fca5a5}.usage-cell{display:inline-flex;align-items:baseline;gap:4px;cursor:default}.usage-clickable{cursor:pointer;padding:2px 6px;border-radius:4px;transition:background var(--transition-fast)}.usage-clickable:hover{background:var(--surface-2)}.usage-sep{color:var(--text-muted);opacity:.4;font-size:.75rem;margin:0 1px}.usage-total{font-weight:600;font-size:.85rem;color:var(--text)}.usage-label{font-size:.75rem;color:var(--text-muted)}.usage-today{font-size:.7rem;font-weight:500;color:#34d399;background:rgba(52,211,153,.1);padding:1px 5px;border-radius:8px}.usage-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.usage-panel{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;max-width:560px;max-height:85vh;overflow-y:auto;padding:24px}.usage-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.usage-header h3{font-size:1rem;font-weight:600;color:var(--text);margin:0}.usage-close{background:none;border:none;color:var(--text-muted);font-size:1.4rem;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all var(--transition-fast)}.usage-close:hover{color:var(--text);background:var(--surface-2)}.usage-range-bar{display:flex;gap:4px;margin-bottom:20px;background:var(--surface-2);border-radius:8px;padding:3px}.usage-range-btn{flex:1 1;padding:6px 0;border:none;background:none;color:var(--text-muted);font-size:.8rem;font-weight:500;cursor:pointer;border-radius:6px;transition:all var(--transition-fast)}.usage-range-btn.active{background:var(--primary);color:white}.usage-range-btn:hover:not(.active){color:var(--text)}.usage-loading{text-align:center;color:var(--text-muted);padding:40px 0}.usage-summary{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px;margin-bottom:20px}.usage-card{background:var(--surface-2);border-radius:8px;padding:12px;text-align:center}.usage-card-value{font-size:1.3rem;font-weight:700;color:var(--text);line-height:1.2}.usage-card-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px}.usage-chart-section{margin-bottom:18px}.usage-section-title{font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.usage-chart{display:flex;align-items:flex-end;gap:2px;height:100px;padding:0 2px}.usage-bar-col{flex:1 1;display:flex;flex-direction:column;align-items:center;height:100%;justify-content:flex-end;min-width:0}.usage-bar{width:100%;background:linear-gradient(180deg,var(--primary),#6366f1);border-radius:3px 3px 0 0;position:relative;min-height:2px;transition:height .4s ease}.usage-bar-label{position:absolute;top:-16px;left:50%;transform:translateX(-50%);white-space:nowrap}.usage-bar-hour,.usage-bar-label{font-size:.6rem;color:var(--text-muted)}.usage-bar-hour{margin-top:4px}.usage-models{display:flex;flex-direction:column;gap:8px}.usage-model-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--surface-2);border-radius:6px}.usage-model-name{font-size:.8rem;font-weight:600;color:var(--text)}.usage-model-tokens{display:flex;gap:10px;font-size:.75rem}.usage-tok-in{color:#60a5fa}.usage-tok-out{color:#f472b6}.usage-tok-cache{color:#a78bfa}.usage-lifetime{display:flex;gap:8px;font-size:.85rem;color:var(--text)}.usage-empty{text-align:center;color:var(--text-muted);padding:30px 0;font-size:.85rem}thead{background:var(--surface-2)}th{text-align:left;padding:10px 16px;color:var(--text-muted);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;border-bottom:1px solid var(--border)}td{padding:12px 16px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);vertical-align:middle}tbody tr{transition:background var(--transition-fast)}tbody tr:hover td{background:var(--surface-hover)}tbody tr:last-child td{border-bottom:none}td strong{color:var(--text);font-weight:600}.cell-truncate{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.name-cell{display:flex;align-items:center;gap:6px;cursor:pointer;border-radius:4px;padding:2px 4px;margin:-2px -4px;transition:background var(--transition-fast)}.name-cell:hover{background:var(--surface-hover)}.name-cell .edit-icon{opacity:0;flex-shrink:0;color:var(--text-faint);transition:opacity var(--transition-fast)}.name-cell:hover .edit-icon{opacity:.7}.inline-edit{display:flex;align-items:center}.inline-edit-input{padding:4px 8px!important;font-size:.85rem!important;font-weight:600!important;width:100%!important;min-width:100px}td .meta{font-size:.72rem;color:var(--text-faint);margin-top:2px;font-family:var(--font-mono);letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}td .timestamp{font-size:.78rem;color:var(--text-muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.status-cell{display:flex;align-items:center;gap:8px}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.online{background:var(--green);box-shadow:0 0 6px rgba(52,211,153,.4)}.status-dot.offline{background:var(--text-faint)}.status-label{font-size:.8rem;font-weight:500}.status-label.online{color:var(--green)}.status-label.offline{color:var(--text-muted)}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}.dot.online{background:var(--green);box-shadow:0 0 6px rgba(52,211,153,.4)}.dot.offline{background:var(--text-faint)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap}.badge-active{background:var(--green-muted);color:var(--green)}.badge-expired{background:var(--red-muted);color:var(--red)}.badge-source{background:var(--primary-muted);color:var(--primary)}.badge-follower{background:var(--yellow-muted);color:var(--yellow)}.badge-managed{background:rgba(107,110,122,.12);color:var(--text-muted)}select{padding:7px 28px 7px 10px;border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text-secondary);font-size:.82rem;font-family:var(--font-sans);cursor:pointer;transition:border-color var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236b6e7a' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}select:hover{border-color:rgba(255,255,255,.15)}select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(99,102,241,.15)}input[type=email],input[type=password],input[type=text]{padding:10px 14px;border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text);font-size:.875rem;font-family:var(--font-sans);width:100%;transition:all var(--transition-fast)}input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(99,102,241,.12);background:var(--surface)}input::placeholder{color:var(--text-faint)}input:disabled{opacity:.5;cursor:not-allowed}.cb{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:4px;border:1.5px solid var(--border-strong);background:var(--surface-2);color:white;cursor:pointer;padding:0;transition:all var(--transition-fast);flex-shrink:0}.cb:hover{background:var(--primary-muted)}.cb-checked,.cb:hover{border-color:var(--primary)}.cb-checked{background:var(--primary)}.cb-checked:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.cb-indeterminate{background:var(--primary);border-color:var(--primary)}input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.code-block{background:var(--bg);border:1px solid var(--border);color:var(--green);padding:14px 18px;border-radius:var(--radius);font-family:var(--font-mono);font-size:.78rem;line-height:1.6;overflow-x:auto;position:relative;word-break:break-all}.code-block code{font-family:inherit}.form-group{margin-bottom:18px}.form-group label{display:block;margin-bottom:6px;font-size:.8rem;font-weight:500;color:var(--text-muted);letter-spacing:.02em}.form-section-title{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}.empty-state{text-align:center;padding:64px 24px;color:var(--text-muted);animation:fadeIn .4s ease}.empty-icon{width:48px;height:48px;margin:0 auto 16px;opacity:.3}.empty-state h3{margin-bottom:8px;color:var(--text-secondary);font-weight:600;font-size:1.05rem}.empty-state p{max-width:360px;margin:0 auto;line-height:1.6;font-size:.88rem}.empty-state code{font-family:var(--font-mono);background:var(--surface-2);padding:2px 6px;border-radius:4px;font-size:.82rem;color:var(--text-secondary)}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:24px;animation:fadeIn .15s ease}.modal{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-xl);padding:28px;min-width:420px;max-width:90vw;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .25s ease}.modal h3{font-size:1.1rem;font-weight:700;margin-bottom:18px;letter-spacing:-.01em}.modal-description{color:var(--text-muted);font-size:.88rem;margin-bottom:20px;line-height:1.5}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:24px}.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;max-width:520px;margin-bottom:20px}@media (max-width:1024px){.content{padding:24px}}@media (max-width:768px){html{font-size:14px}.topbar{height:52px;padding:0 16px}.hamburger{display:none}.topbar-brand span{font-size:.9rem}.sidebar,.user-chip{display:none}.bottom-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--bg-elevated);border-top:1px solid var(--border);z-index:100;padding:0 4px env(safe-area-inset-bottom,0)}.tab-item{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;color:var(--text-faint);cursor:pointer;font-family:var(--font-sans);font-size:.65rem;font-weight:500;letter-spacing:.02em;transition:color var(--transition-fast);padding:4px 0;position:relative}.tab-item.active{color:var(--primary)}.tab-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:24px;height:2px;background:var(--primary);border-radius:0 0 2px 2px}.tab-icon,.tab-item svg{width:20px;height:20px}.content{padding:20px 16px 80px;max-width:none}.page-header{flex-direction:column;align-items:flex-start}.page-actions{width:100%}.page-actions .btn-primary{flex:1 1}.table-card{border-radius:var(--radius)}.col-groups,.col-seen,.col-usage,.col-version{display:none}td,th{padding:10px 12px}.modal{min-width:auto;width:100%;margin:0;border-radius:var(--radius-lg)}.modal-overlay{padding:16px;align-items:flex-end}.settings-section{max-width:none}}@media (max-width:480px){.content{padding:16px 12px 80px}.topbar{padding:0 12px}.topbar-logout{padding:5px 8px;font-size:.7rem}.page-title{font-size:1.15rem}td,th{padding:8px 10px}.btn,td,th{font-size:.8rem}.btn{padding:7px 12px}select{font-size:.78rem;padding:6px 24px 6px 8px}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.15)}.install-command{-webkit-user-select:all;-moz-user-select:all;user-select:all;cursor:text;white-space:pre-wrap;word-break:break-all;font-size:.76rem;line-height:1.7}.setup-step{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:12px}.setup-step-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.step-number{display:flex;align-items:center;justify-content:center;width:28px;height:28px;min-width:28px;border-radius:50%;background:var(--primary);color:white;font-size:.78rem;font-weight:600}.setup-step-header strong{display:block;font-size:.88rem;color:var(--text-primary);margin-bottom:2px}.step-hint{display:block;font-size:.74rem;color:var(--text-muted);line-height:1.4}.onboarding{max-width:580px;margin:0 auto;padding:40px 0}.onboarding-header{text-align:center;margin-bottom:32px}.onboarding-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:16px;background:var(--primary-muted);color:var(--primary);margin-bottom:20px}.onboarding-header h2{font-size:1.4rem;font-weight:600;margin-bottom:10px}.onboarding-subtitle{color:var(--text-muted);font-size:.88rem;line-height:1.6;max-width:440px;margin:0 auto}.onboarding-card{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-xl);padding:28px;margin-bottom:16px}.onboarding-step-label{display:flex;align-items:center;gap:10px;font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:14px}.step-badge{display:inline-flex;align-items:center;padding:2px 10px;border-radius:100px;background:var(--primary);color:white;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.step-badge-muted{background:var(--surface-2);color:var(--text-muted)}.onboarding-description{color:var(--text-muted);font-size:.84rem;line-height:1.6;margin-bottom:20px}.onboarding-description strong{color:var(--text-secondary)}.input-hint{display:block;font-size:.72rem;color:var(--text-faint);margin-top:6px}.onboarding-note{display:flex;gap:10px;margin-top:20px;padding:14px 16px;background:var(--primary-muted);border:1px solid rgba(99,102,241,.15);border-radius:var(--radius);font-size:.78rem;color:var(--text-secondary);line-height:1.6}.onboarding-note svg{flex-shrink:0;margin-top:2px;color:var(--primary)}.onboarding-note strong{color:var(--text)}.onboarding-note em{color:var(--primary-hover);font-style:normal;font-weight:500}.onboarding-next{display:flex;align-items:center;gap:10px;padding:16px 20px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);font-size:.82rem;color:var(--text-muted)}@media (max-width:768px){.onboarding{padding:20px 0}.onboarding-card{padding:20px}.onboarding-header h2{font-size:1.2rem}}.confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:300;padding:24px;animation:fadeIn .12s ease}.confirm-modal{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-xl);padding:32px;width:100%;max-width:400px;text-align:center;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.confirm-icon{width:48px;height:48px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--surface-2);border:1px solid var(--border);color:var(--text-muted)}.confirm-icon svg{width:22px;height:22px}.confirm-title{font-size:1.1rem;font-weight:700;letter-spacing:-.01em;margin-bottom:8px;color:var(--text)}.confirm-message{color:var(--text-muted);font-size:.88rem;line-height:1.6;margin-bottom:28px;text-align:left}.confirm-message p{margin:0 0 8px;text-align:center}.confirm-message strong{color:var(--text)}.confirm-list{list-style:none;padding:0;margin:12px 0 0;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);max-height:160px;overflow-y:auto}.confirm-list li{padding:8px 14px;font-size:.82rem;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle)}.confirm-list li:last-child{border-bottom:none}.confirm-actions{display:flex;gap:10px}.confirm-actions .btn{flex:1 1;justify-content:center;padding:10px 16px;font-size:.85rem}.btn-danger-fill{background:var(--red);border-color:var(--red);color:white;font-weight:600}.btn-danger-fill:hover{background:#ef5350;border-color:#ef5350;box-shadow:0 0 16px rgba(248,113,113,.2);color:white}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:white;border-radius:50%;animation:spin .6s linear infinite;margin-right:6px}@media (max-width:768px){.confirm-overlay{padding:16px;align-items:flex-end}.confirm-modal{max-width:none;border-radius:var(--radius-lg);padding:28px 24px}}@media (max-width:480px){.confirm-actions{flex-direction:column-reverse}}.loading{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-muted);font-size:.9rem}.ws-status{display:none}.platform-toggle{display:flex;gap:0;margin-bottom:12px;border:1px solid var(--border-strong);border-radius:var(--radius);overflow:hidden;width:-moz-fit-content;width:fit-content}.platform-btn{padding:6px 16px;background:var(--surface-2);border:none;color:var(--text-muted);font-size:.75rem;font-weight:500;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);letter-spacing:.02em}.platform-btn:not(:last-child){border-right:1px solid var(--border-strong)}.platform-btn:hover{color:var(--text-secondary);background:var(--surface-hover)}.platform-btn.active{background:var(--primary-muted);color:var(--primary-hover);font-weight:600}.version-badge{position:fixed;bottom:12px;right:16px;font-size:.68rem;font-family:var(--font-mono);color:var(--text-faint);letter-spacing:.03em;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:50}@media (max-width:768px){.version-badge{bottom:76px;right:12px}}.dd{position:relative}.dd,.dd-trigger{display:inline-flex}.dd-trigger{align-items:center;gap:6px;padding:5px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);font-size:.8rem;font-family:var(--font-sans);cursor:pointer;transition:all .15s ease;white-space:nowrap;min-width:0}.dd-trigger:hover{border-color:var(--border-strong);background:var(--surface-hover);color:var(--text)}.dd-open .dd-trigger{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary-muted)}.dd-trigger:disabled{cursor:default;opacity:.7}.dd-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}.dd-chevron{flex-shrink:0;opacity:.4;transition:transform .15s ease}.dd-open .dd-chevron{transform:rotate(180deg);opacity:.7}.dd-menu{background:var(--surface-2);border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:4px;animation:dd-fade-in .12s ease;max-height:240px;overflow-y:auto}@keyframes dd-fade-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dd-option{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:none;background:none;color:var(--text-secondary);font-size:.8rem;font-family:var(--font-sans);cursor:pointer;border-radius:5px;text-align:left;transition:all .1s ease;white-space:nowrap}.dd-option:hover{background:var(--surface-hover);color:var(--text)}.dd-option-selected{color:var(--text);font-weight:500}.dd-check{color:var(--primary);flex-shrink:0}.dd-role-source{color:var(--green);border-color:rgba(52,211,153,.2);background:var(--green-muted)}.dd-role-source:hover{border-color:rgba(52,211,153,.35);background:rgba(52,211,153,.16)}.dd-role-managed{color:var(--text-secondary)}.dd-role-follower{color:var(--blue);border-color:rgba(96,165,250,.2);background:var(--blue-muted)}.dd-role-follower:hover{border-color:rgba(96,165,250,.35);background:rgba(96,165,250,.16)}.dd-license-active{color:var(--text)}.dd-license-none{color:var(--text-faint);font-style:italic}.dd-spinner{width:14px;height:14px;border:2px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;animation:dd-spin .6s linear infinite}@keyframes dd-spin{to{transform:rotate(1turn)}}.group-expand-btn{display:flex;align-items:center;gap:8px;background:none;border:none;color:inherit;cursor:pointer;font-family:var(--font-sans);font-size:inherit;padding:2px 4px;margin:-2px -4px;border-radius:4px;transition:background var(--transition-fast)}.group-expand-btn:hover{background:var(--surface-hover)}.expand-chevron{flex-shrink:0;transition:transform .2s ease;color:var(--text-faint)}.expand-chevron.expanded{transform:rotate(90deg)}.group-members-row td{padding:0!important;background:var(--bg)!important}.group-members-list{display:flex;flex-direction:column;padding:8px 16px}.group-member-item{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:4px;transition:background var(--transition-fast)}.group-member-item:hover{background:var(--surface-hover)}.group-member-name{font-size:.82rem;color:var(--text);font-weight:500}.group-member-meta{font-size:.72rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em}.machine-select-list{display:flex;flex-direction:column;gap:2px;max-height:320px;overflow-y:auto;margin-bottom:8px;border:1px solid var(--border);border-radius:var(--radius);padding:4px}.machine-select-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:none;border:1px solid transparent;border-radius:6px;cursor:pointer;font-family:var(--font-sans);font-size:.84rem;color:var(--text-secondary);text-align:left;transition:all var(--transition-fast);width:100%}.machine-select-item:hover{background:var(--surface-hover)}.machine-select-item.selected{background:var(--primary-muted);border-color:rgba(99,102,241,.2);color:var(--text)}.machine-select-name{font-weight:500;color:var(--text)}.machine-select-role{font-size:.72rem;color:var(--text-faint);text-transform:uppercase;letter-spacing:.04em}.gp{display:flex;flex-wrap:wrap;gap:4px;min-height:26px}.gp,.gp-pill{align-items:center}.gp-pill{display:inline-flex;gap:2px;padding:2px 8px;background:var(--surface-2);border:1px solid var(--border);border-radius:100px;font-size:.7rem;font-weight:500;color:var(--text-secondary);white-space:nowrap;animation:gp-enter .2s cubic-bezier(.34,1.56,.64,1);transition:all .15s ease;max-width:120px}.gp-pill:hover{border-color:rgba(255,255,255,.12);background:var(--surface-hover)}.gp-pill-label{overflow:hidden;text-overflow:ellipsis;letter-spacing:.01em}.gp-pill-x{display:flex;align-items:center;justify-content:center;width:14px;height:14px;border:none;background:none;color:var(--text-faint);cursor:pointer;border-radius:50%;padding:0;opacity:0;transform:scale(.7);transition:all .12s ease;margin-left:1px;margin-right:-4px;flex-shrink:0}.gp-pill:hover .gp-pill-x{opacity:1;transform:scale(1)}.gp-pill-x:hover{background:var(--red-muted);color:var(--red)}.gp-pill-exit{opacity:0;transform:scale(.8);transition:all .18s ease}.gp-pill-hidden{display:none}.gp-add{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:1px dashed var(--border-strong);border-radius:50%;background:none;color:var(--text-faint);cursor:pointer;padding:0;flex-shrink:0;transition:all .15s ease}.gp-add-active,.gp-add:hover:not(:disabled){border-color:var(--primary);border-style:solid;color:var(--primary);background:var(--primary-muted)}.gp-add:disabled{opacity:.3;cursor:default}.gp-add-spinner{width:10px;height:10px;border:1.5px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;animation:dd-spin .6s linear infinite}.gp-empty{color:var(--text-faint);font-size:.8rem}.gp-menu{background:var(--surface-2);border:1px solid var(--border-strong);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:4px;animation:dd-fade-in .12s ease;max-height:200px;overflow-y:auto}.gp-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:none;background:none;color:var(--text-secondary);font-size:.8rem;font-family:var(--font-sans);cursor:pointer;border-radius:5px;text-align:left;transition:all .1s ease;white-space:nowrap}.gp-menu-item:hover{background:var(--surface-hover);color:var(--text)}.gp-menu-dot{width:6px;height:6px;border-radius:50%;background:var(--primary);opacity:.5;flex-shrink:0}.gp-menu-item:hover .gp-menu-dot{opacity:1}@keyframes gp-enter{0%{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}.integrate-page{position:fixed;inset:0;padding:40px 24px 80px;background:radial-gradient(ellipse 60% 40% at 50% 0,rgba(99,102,241,.06) 0,transparent 60%),var(--bg);overflow-y:auto;-webkit-overflow-scrolling:touch}.integrate-container{max-width:760px;margin:0 auto;animation:fadeIn .4s ease}.integrate-header{margin-bottom:48px}.integrate-badge{display:inline-block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--primary);background:var(--primary-muted);padding:4px 10px;border-radius:20px;margin-bottom:16px}.integrate-header h1{font-size:2.2rem;font-weight:700;letter-spacing:-.03em;margin-bottom:12px}.integrate-subtitle{font-size:1.05rem;color:var(--text-secondary);line-height:1.7;max-width:600px}.integrate-section{margin-bottom:40px}.integrate-section h2{font-size:1.2rem;font-weight:600;letter-spacing:-.01em;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--border)}.integrate-section h3{font-size:.9rem;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.integrate-flow{display:flex;flex-direction:column;gap:4px}.flow-step{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;font-size:.9rem;color:var(--text-secondary);line-height:1.5}.flow-step strong{color:var(--text)}.flow-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--primary-muted);color:var(--primary);font-size:.8rem;font-weight:700;flex-shrink:0}.flow-arrow{text-align:center;color:var(--text-faint);font-size:.85rem;line-height:1}.integrate-endpoint{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;margin-bottom:12px}.integrate-endpoint code{font-family:var(--font-mono);font-size:.9rem;color:var(--text)}.method-badge{font-family:var(--font-mono);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 8px;border-radius:4px;background:var(--green-muted);color:var(--green);flex-shrink:0}.method-badge.get-badge{background:var(--blue-muted);color:var(--blue)}.integrate-note{font-size:.85rem;color:var(--text-muted);line-height:1.6}.integrate-note code{font-family:var(--font-mono);font-size:.8rem;background:var(--surface-2);padding:1px 5px;border-radius:3px;color:var(--text-secondary)}.integrate-code-block{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.code-header{padding:8px 14px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);background:var(--surface-2)}.code-header.error-header{color:var(--red)}.integrate-code-block pre{padding:16px;overflow-x:auto;-webkit-overflow-scrolling:touch}.integrate-code-block code{font-family:var(--font-mono);font-size:.8rem;line-height:1.7;color:var(--text-secondary)}.integrate-fields{margin-top:20px}.fields-table{width:100%;border-collapse:collapse;font-size:.85rem}.fields-table th{text-align:left;padding:8px 12px;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border-strong)}.fields-table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text-secondary);line-height:1.5;vertical-align:top}.fields-table td code{font-family:var(--font-mono);font-size:.8rem;color:var(--text);white-space:nowrap}.optional-badge,.required-badge{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border-radius:3px;white-space:nowrap}.required-badge{background:var(--red-muted);color:var(--red)}.optional-badge{background:rgba(255,255,255,.04);color:var(--text-muted)}.example-block{margin-bottom:20px}.practices-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:12px;gap:12px}.practice-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.practice-icon{font-size:1.3rem;margin-bottom:8px}.practice-card h4{font-size:.85rem;font-weight:600;margin-bottom:6px}.practice-card p{font-size:.8rem;color:var(--text-muted);line-height:1.5}.practice-card code{font-family:var(--font-mono);font-size:.75rem;background:var(--surface-2);padding:1px 4px;border-radius:3px}.prereq-list{display:flex;flex-direction:column;gap:12px}.prereq-item{display:flex;align-items:flex-start;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;font-size:.85rem;color:var(--text-secondary);line-height:1.5}.prereq-item strong{color:var(--text)}.prereq-item code{font-family:var(--font-mono);font-size:.8rem;background:var(--surface-2);padding:1px 5px;border-radius:3px;color:var(--text-secondary)}.prereq-check{width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--green-muted);color:var(--green);font-size:.7rem;font-weight:700;flex-shrink:0}.integrate-footer{margin-top:60px;padding-top:20px;border-top:1px solid var(--border);text-align:center;font-size:.8rem;color:var(--text-faint)}.identifier-examples{display:flex;flex-direction:column;gap:14px}.id-example{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.id-example-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.id-example-type{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--primary);background:var(--primary-muted);padding:2px 8px;border-radius:4px}.id-example-label{font-size:.8rem;color:var(--text-muted)}.id-example p{font-size:.85rem;color:var(--text-secondary);line-height:1.6}.id-example strong{color:var(--text)}@media (max-width:600px){.integrate-page{padding:24px 16px 60px}.integrate-header h1{font-size:1.6rem}.integrate-subtitle{font-size:.95rem}.practices-grid{grid-template-columns:1fr}.fields-table{font-size:.8rem}.fields-table td,.fields-table th{padding:8px}.integrate-endpoint{flex-direction:column;align-items:flex-start;gap:8px}.integrate-endpoint code{font-size:.8rem;word-break:break-all}}