:root{--background:#0a0c10;--foreground:#eaedf0;--card:#13161d;--card-foreground:#eaedf0;--card-hover:#1a1e28;--popover:#1a1e28;--popover-foreground:#eaedf0;--primary:#6366f1;--primary-foreground:#fff;--secondary:#1a1e28;--secondary-foreground:#d1d5db;--muted:#1e2230;--muted-foreground:#b8c0cc;--accent:#1e2230;--accent-foreground:#eaedf0;--destructive:#ef4444;--destructive-foreground:#fee2e2;--border:#23283a;--border-hover:#343b52;--input:#13161d;--ring:#6366f1;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 24px #00000080;--shadow-glow:0 0 20px #6366f126;--empty-icon-bg:#6366f114;--empty-icon-border:#6366f124;--status-running:#22c55e;--status-warning:#f59e0b;--status-error:#ef4444}*,:before,:after{box-sizing:border-box}button:focus-visible,a:focus-visible,[tabindex]:not([tabindex="-1"]):focus-visible{outline:2px solid var(--ring);outline-offset:2px}body{background-color:var(--background);color:var(--foreground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.mantine-Tooltip-tooltip{background-color:var(--popover);color:var(--popover-foreground);border:1px solid var(--border);box-shadow:var(--shadow-md);border-radius:var(--mantine-radius-md);padding:6px 12px;font-size:.8125rem}.mantine-Tooltip-arrow{background-color:var(--popover);border-color:var(--border)}@keyframes ripple{to{opacity:0;width:600px;height:600px;margin-top:-300px;margin-left:-300px}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes fadeIn{0%{opacity:0;transform:translate(-4px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}.identity-modal-content{background:var(--card);border:1px solid var(--border);width:min(92vw,1680px);max-width:min(92vw,1680px);height:min(92vh,980px);padding:0;overflow:hidden}.identity-modal-body{flex-direction:column;height:100%;padding:0;display:flex}.identity-shimmer{background:linear-gradient(to right, var(--primary), #6366f180, var(--primary));background-size:200% 100%;height:3px;animation:2s linear infinite shimmer}.identity-shimmer--success{background:var(--status-running);animation:none}.identity-shimmer--error{background:var(--status-error);animation:none}.identity-shimmer--hidden{opacity:0}.identity-header{border-bottom:1px solid var(--border);grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;padding:.75rem 1rem;display:grid}.identity-header>.identity-close-btn,.identity-header>.identity-close-btn--abort{justify-self:end}.identity-header-center{justify-content:center;align-items:center;gap:.625rem;display:flex}.identity-status-label{color:var(--primary);white-space:nowrap;text-overflow:ellipsis;text-shadow:0 0 8px #6366f180,0 0 16px #6366f140;align-items:center;gap:.4rem;max-width:420px;font-size:.8125rem;font-weight:500;animation:2s ease-in-out infinite status-glow;display:inline-flex;overflow:hidden}.identity-status-spinner{border:2px solid #6366f14d;border-top-color:var(--primary);border-radius:9999px;flex-shrink:0;width:.75rem;height:.75rem;animation:.8s linear infinite spin}@keyframes status-glow{0%,to{text-shadow:0 0 6px #6366f166,0 0 12px #6366f126}50%{text-shadow:0 0 10px #6366f1b3,0 0 20px #6366f159}}.identity-title{color:var(--foreground);white-space:nowrap;margin:0;font-size:1.125rem;font-weight:500}.identity-close-btn:disabled{opacity:.3}.identity-close-btn--abort{transition:background-color .15s}.identity-close-btn--abort:hover{background-color:#ef444426}.identity-content{flex-direction:column;flex:1;min-height:0;display:flex}.identity-browser{background:#26262633;flex:1;justify-content:center;align-items:center;min-width:0;min-height:0;padding:1rem;display:flex}.identity-browser:has(.identity-vnc-layout){justify-content:stretch;align-items:stretch;padding:0}.identity-vnc-layout{flex-direction:column;width:100%;height:100%;min-height:0;display:flex;position:relative}.identity-success{text-align:center;flex-direction:column;align-items:center;gap:1rem;display:flex}.identity-success-icon{background:#22c55e33;border-radius:9999px;justify-content:center;align-items:center;width:4rem;height:4rem;display:flex}.identity-success-title{color:var(--foreground);margin:0 0 .5rem;font-size:1.25rem}.identity-success-desc{color:var(--muted-foreground);margin:0;font-size:.875rem}.identity-loading{text-align:center;flex-direction:column;justify-content:center;align-items:center;width:100%;height:100%;display:flex}.identity-spinner{border:4px solid #6366f14d;border-top-color:var(--primary);border-radius:9999px;width:4rem;height:4rem;margin:0 auto 1rem;animation:1s linear infinite spin}.identity-loading-text{color:var(--muted-foreground);margin:0}.identity-loading-hint{color:var(--muted-foreground);margin:.5rem 0 0;font-size:.75rem}.identity-post-login-overlay{z-index:10;background:var(--card);flex-direction:column;justify-content:center;align-items:center;gap:.25rem;display:flex;position:absolute;inset:0}.identity-vnc-container{background:#0d1018;flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative;overflow:hidden}.identity-vnc-sizer{flex-shrink:0;position:relative;overflow:hidden}.identity-vnc-screen{transform-origin:0 0;border:0;display:block}.identity-vnc-screen--connecting{opacity:0}.identity-vnc-connecting{z-index:1;flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:absolute;inset:0}.identity-spinner--small{width:2.5rem;height:2.5rem}.identity-terminal{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;width:100%;max-width:420px;margin:0 auto;display:flex}.identity-terminal-icon{border-radius:9999px;justify-content:center;align-items:center;width:4rem;height:4rem;display:flex}.identity-terminal-icon--warning{background:#f59e0b26}.identity-terminal-icon--error{background:#ef444426}.identity-terminal-title{color:var(--foreground);margin:0;font-size:1.25rem}.identity-terminal-desc{color:var(--muted-foreground);max-width:300px;margin:0;font-size:.875rem}.identity-terminal-hint{color:var(--muted-foreground);max-width:300px;margin:0;font-size:.75rem}.identity-retry-btn{margin-top:.5rem}.identity-syslog{text-align:left;background:#0003;border:1px solid #ffffff0f;border-radius:8px;flex-direction:column;gap:.3rem;width:100%;max-height:140px;margin-top:1.5rem;padding:.6rem .8rem;display:flex;overflow-y:auto}.identity-syslog-line{font-family:var(--mantine-font-family-monospace);color:#e5e5e5a6;font-size:.75rem;line-height:1.4}.identity-syslog-prompt{color:var(--primary);margin-right:.4rem}.identity-abort-modal-content{background:var(--card);border:1px solid var(--border)}.identity-abort-modal-body{padding:1.5rem}.identity-abort-content{text-align:center;flex-direction:column;align-items:center;gap:.75rem;display:flex}.identity-abort-icon{background:#ef444426;border-radius:9999px;justify-content:center;align-items:center;width:3.5rem;height:3.5rem;display:flex}.identity-abort-title{color:var(--foreground);margin:0;font-size:1.125rem;font-weight:500}.identity-abort-desc{max-width:300px}.identity-abort-actions{gap:.75rem;margin-top:.5rem;display:flex}@media (width<=640px){.identity-modal-content{width:100vw;max-width:100vw;height:100dvh}.identity-content{flex:1;min-height:0}.identity-browser{flex:1;min-height:0;padding:.75rem}.identity-browser:has(.identity-vnc-layout){padding:0}.identity-header{grid-template-columns:1fr auto;gap:.5rem;padding:.5rem .75rem}.identity-title,.identity-header-center .mantine-Badge-root{display:none}.identity-header-center{justify-content:flex-start}.identity-status-label{max-width:calc(100vw - 5rem);font-size:.75rem}.identity-close-btn,.identity-close-btn--abort{min-width:2.75rem;min-height:2.75rem}.identity-modal-body{height:100%;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);flex-direction:column;display:flex}}.sync-pill{border:1px solid var(--border);color:var(--foreground);cursor:pointer;background:#26262680;border-radius:9999px;align-items:center;gap:.5rem;padding:.375rem .75rem;font-family:inherit;transition:border-color .2s,background-color .2s;display:flex}.sync-pill:hover{border-color:var(--primary)}.sync-pill:disabled{opacity:.6;cursor:default}.sync-pill:disabled:hover{border-color:var(--border)}.sync-pill--fetching{opacity:.6}.sync-pill--invalid{border-color:#f59e0b66}.sync-pill--invalid:hover{background:#f59e0b14;border-color:#f59e0bb3}.sync-pill-dot{border-radius:9999px;width:.5rem;height:.5rem}.sync-pill-dot--valid{background:var(--status-running);box-shadow:0 0 8px #22c55e99}.sync-pill-dot--invalid{background:var(--status-warning);animation:2s cubic-bezier(.4,0,.6,1) infinite sync-pill-pulse;box-shadow:0 0 8px #f59e0b99}.sync-pill-dot--never{background:var(--muted-foreground);box-shadow:0 0 4px #9996}.sync-pill-dot--unknown{background:var(--muted-foreground);animation:1s cubic-bezier(.4,0,.6,1) infinite sync-pill-pulse;box-shadow:0 0 4px #9996}.sync-pill-label{font-size:.75rem;font-family:var(--mantine-font-family-monospace)}@keyframes sync-pill-pulse{0%,to{opacity:1}50%{opacity:.5}}.back-button{border:1px solid var(--border);border-radius:var(--mantine-radius-md);color:var(--muted-foreground);cursor:pointer;background:0 0;align-items:center;gap:.375rem;padding:.5rem .875rem;font-family:inherit;font-size:.875rem;transition:border-color .2s,color .2s;display:flex}.back-button:hover{border-color:var(--muted-foreground);color:var(--foreground)}.sub-modal-content{background:var(--card)!important;border:1px solid var(--border)!important;box-shadow:var(--shadow-lg), 0 0 60px #6366f114!important;border-radius:20px!important}.sub-modal-body{padding:0!important}.sub-modal{text-align:center;padding:2.5rem 2rem 2rem}.sub-modal-icon-wrapper{margin-bottom:1.5rem;display:inline-flex}.sub-modal-icon{color:#a5b4fc;background:linear-gradient(135deg,#6366f126,#8b5cf626);border:1px solid #6366f140;border-radius:16px;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.sub-modal-title{letter-spacing:-.02em;color:var(--foreground);margin:0 0 .625rem;font-size:1.5rem;font-weight:700}.sub-modal-description{color:var(--muted-foreground);max-width:380px;margin:0 auto 1.5rem;font-size:.9375rem;line-height:1.55}.sub-modal-highlights{text-align:left;flex-direction:column;gap:.625rem;margin-bottom:1.75rem;padding:0 .5rem;display:flex}.sub-modal-highlight{color:var(--foreground);align-items:flex-start;gap:.625rem;font-size:.875rem;display:flex}.sub-modal-highlight-icon{color:#4ade80;flex-shrink:0;margin-top:1px}.sub-modal-price{justify-content:center;align-items:baseline;gap:.25rem;margin-bottom:1.5rem;display:flex}.sub-modal-price-amount{letter-spacing:-.03em;color:var(--foreground);font-size:2rem;font-weight:800}.sub-modal-price-period{color:var(--muted-foreground);font-size:.9375rem}.sub-modal-actions{flex-direction:column;gap:.75rem;display:flex}.sub-modal-cta{background:var(--primary)!important;border:none!important;border-radius:10px!important;height:44px!important;font-size:.9375rem!important;font-weight:600!important;transition:background .15s,box-shadow .2s!important}.sub-modal-cta:hover{background:#4f46e5!important;box-shadow:0 0 24px #6366f14d!important}.sub-modal-dismiss{color:var(--muted-foreground);cursor:pointer;background:0 0;border:none;padding:.5rem;font-family:inherit;font-size:.8125rem;transition:color .15s}.sub-modal-dismiss:hover{color:var(--foreground)}.sub-modal-dismiss:disabled{opacity:.5;cursor:not-allowed}.onboarding-checklist{z-index:1000;background:var(--card);border:1px solid var(--border);border-radius:12px;width:280px;animation:.3s ease-out onboardingSlideUp;position:fixed;bottom:1.25rem;right:1.25rem;box-shadow:0 8px 32px #00000040}.onboarding-checklist-header{justify-content:space-between;align-items:center;padding:.75rem 1rem .5rem;display:flex}.onboarding-checklist-title-row{align-items:center;gap:.375rem;display:flex}.onboarding-checklist-rocket{color:var(--primary)}.onboarding-checklist-title{color:var(--foreground);font-size:.8125rem;font-weight:600}.onboarding-checklist-count{color:var(--muted-foreground);font-size:.6875rem;font-weight:500}.onboarding-checklist-actions{align-items:center;gap:.125rem;display:flex}.onboarding-checklist-action{width:24px;height:24px;color:var(--muted-foreground);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:color .15s,background .15s;display:flex}.onboarding-checklist-action:hover{color:var(--foreground);background:#ffffff0f}.onboarding-checklist-progress{background:#ffffff0f;border-radius:2px;height:3px;margin:0 1rem .5rem;overflow:hidden}.onboarding-checklist-progress-fill{background:var(--primary);border-radius:2px;height:100%;transition:width .4s}.onboarding-checklist-steps{margin:0;padding:0 .5rem .5rem;list-style:none}.onboarding-checklist-step{margin:0}.onboarding-checklist-step-btn{width:100%;font:inherit;color:var(--foreground);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem;font-size:.8125rem;transition:background .15s;display:flex}.onboarding-checklist-step-btn:hover:not(:disabled){background:#ffffff0a}.onboarding-checklist-step-btn--done{opacity:.5;cursor:default}.onboarding-checklist-check{border:1.5px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;transition:all .2s;display:flex}.onboarding-checklist-check--done{background:var(--primary);border-color:var(--primary);color:#fff}.onboarding-checklist-check-empty{background:var(--muted-foreground);opacity:.3;border-radius:50%;width:6px;height:6px}.onboarding-checklist-step-label{text-align:left;flex:1}.onboarding-fab{z-index:1000;background:var(--card);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:transform .2s,box-shadow .2s;display:flex;position:fixed;bottom:1.25rem;right:1.25rem;box-shadow:0 4px 16px #0000004d}.onboarding-fab:hover{transform:scale(1.08);box-shadow:0 6px 24px #00000059}.onboarding-fab-ring{width:100%;height:100%;position:absolute;inset:0;transform:rotate(-90deg)}.onboarding-fab-ring-bg{stroke:#ffffff0f}.onboarding-fab-ring-fill{stroke:var(--primary);transition:stroke-dasharray .4s}.onboarding-fab-icon{color:var(--primary);z-index:1;position:relative}@keyframes onboardingSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (width<=480px){.onboarding-checklist{width:auto;bottom:.75rem;left:.75rem;right:.75rem}.onboarding-fab{bottom:.75rem;right:.75rem}}.app-header{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#0d0d0d4d}.app-header-inner{justify-content:space-between;align-items:center;max-width:1200px;height:100%;margin:0 auto;padding:0 1.5rem;display:flex}.app-logo-button{cursor:pointer;background:0 0;border:none;align-items:center;gap:.75rem;padding:0;transition:opacity .2s;display:flex}.app-logo-button:hover{opacity:.8}.app-logo-mark{object-fit:cover;border-radius:9999px;flex-shrink:0;width:2rem;height:2rem;transition:box-shadow .2s;display:block;box-shadow:0 0 14px #8a8aff40}.app-logo-button:hover .app-logo-mark{box-shadow:0 0 18px #8a8aff66}.app-logo-text{color:var(--foreground);letter-spacing:-.04em;font-size:1.3rem;font-weight:600}.app-header-actions{align-items:center;gap:.5rem;display:flex}.app-header-docs-link{padding-left:.75rem;padding-right:.875rem}.app-header-docs-link--active{color:var(--primary);background:#6366f11f;border-color:#6366f173}.app-free-tier-badge{color:var(--muted-foreground);font-size:.6875rem;font-weight:500;font-family:var(--mantine-font-family-monospace);white-space:nowrap;letter-spacing:.01em;background:#6366f114;border:1px solid #6366f133;border-radius:9999px;align-items:center;padding:.25rem .75rem;display:inline-flex}.app-upgrade-button{color:#fbbf24;font-size:.75rem;font-weight:600;font-family:var(--mantine-font-family-monospace);cursor:pointer;white-space:nowrap;background:linear-gradient(135deg,#f59e0b1f,#fbbf2414);border:1px solid #f59e0b4d;border-radius:9999px;align-items:center;gap:.375rem;padding:.375rem .875rem;transition:background .15s,border-color .15s,box-shadow .15s;display:inline-flex}.app-upgrade-button:hover{background:linear-gradient(135deg,#f59e0b33,#fbbf2424);border-color:#f59e0b80;box-shadow:0 0 16px #f59e0b1f}.app-upgrade-button:disabled{opacity:.5;cursor:not-allowed}.app-avatar-button{cursor:pointer;background:0 0;border:2px solid #0000;border-radius:9999px;justify-content:center;align-items:center;padding:2px;transition:border-color .2s;display:flex}.app-avatar-button:hover{border-color:var(--primary)}.app-avatar{font-size:.875rem;font-weight:600}.app-menu-dropdown{background:var(--popover);border:1px solid var(--border)}.app-menu-user{flex-direction:column;gap:.125rem;padding:.5rem .75rem;display:flex}.app-menu-user-name{color:var(--foreground);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:600;overflow:hidden}.app-menu-user-email{color:var(--muted-foreground);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.app-back-bar{max-width:1200px;margin:0 auto;padding:1rem 1.5rem 0}.app-mobile-toggle{border:1px solid var(--border);border-radius:var(--mantine-radius-md);color:var(--foreground);cursor:pointer;background:0 0;justify-content:center;align-items:center;padding:.375rem;transition:border-color .2s;display:none}.app-mobile-toggle:hover{border-color:var(--primary)}.app-mobile-backdrop{z-index:199;background:#0006;position:fixed;inset:60px 0 0}.app-mobile-menu{z-index:200;background:var(--card);border-bottom:1px solid var(--border);flex-direction:column;gap:.25rem;padding:.5rem;display:none;position:fixed;top:60px;left:0;right:0}.app-mobile-menu-item{border-radius:var(--mantine-radius-md);width:100%;color:var(--foreground);font-size:.875rem;font-family:var(--mantine-font-family-monospace);cursor:pointer;background:0 0;border:none;align-items:center;gap:.75rem;padding:.75rem 1rem;transition:background .15s;display:flex}.app-mobile-menu-item:hover{background:#ffffff0d}.app-mobile-user{border-bottom:1px solid var(--border);align-items:center;gap:.75rem;margin-bottom:.25rem;padding:.75rem 1rem;display:flex}.app-mobile-user-info{flex-direction:column;gap:.0625rem;min-width:0;display:flex}.app-mobile-user-name{color:var(--foreground);white-space:nowrap;text-overflow:ellipsis;font-size:.8125rem;font-weight:600;overflow:hidden}.app-mobile-user-email{color:var(--muted-foreground);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.app-mobile-sync{border-bottom:1px solid var(--border);margin-bottom:.25rem;padding:.5rem 1rem .75rem}.app-mobile-menu-item--upgrade{color:#fbbf24}.app-mobile-menu-item--upgrade:hover{background:#f59e0b1a}.app-mobile-menu-item--upgrade:disabled{opacity:.5;cursor:not-allowed}.app-mobile-menu-item--danger:hover{color:var(--destructive);background:#ef44441a}@media (width<=640px){.app-header-inner{padding:0 1rem}.app-back-bar{padding:.75rem 1rem 0}.app-header-actions{display:none}.app-mobile-toggle,.app-mobile-menu{display:flex}}.onboarding-card{background:var(--card);border:1px solid var(--border);width:340px;color:var(--foreground);border-radius:12px;padding:1.25rem;box-shadow:0 8px 32px #0006}.onboarding-card-header{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.onboarding-card-icon{font-size:1.25rem;line-height:1}.onboarding-card-title{color:var(--foreground);margin:0;font-size:1rem;font-weight:600}.onboarding-card-body{color:var(--muted-foreground);margin-bottom:1rem;font-size:.875rem;line-height:1.5}.onboarding-card-body p{margin:0}.onboarding-card-footer{justify-content:space-between;align-items:center;display:flex}.onboarding-card-counter{color:var(--muted-foreground);font-size:.75rem;font-weight:500}.onboarding-card-actions{gap:.5rem;display:flex}.onboarding-card-btn{cursor:pointer;border:none;border-radius:8px;padding:.375rem .875rem;font-size:.8125rem;font-weight:500;transition:background .15s,opacity .15s}.onboarding-card-btn--primary{background:var(--primary);color:var(--primary-foreground)}.onboarding-card-btn--primary:hover{opacity:.9}.onboarding-card-btn--secondary{background:var(--muted);color:var(--muted-foreground)}.onboarding-card-btn--secondary:hover{background:var(--card-hover);color:var(--foreground)}
