:root{--bg:#0a0e17;--bg-elevated:#111827;--surface:#151d2e;--surface-hover:#1a2438;--border:#243044;--border-subtle:#1c2738;--text:#f1f5f9;--text-muted:#94a3b8;--text-faint:#64748b;--accent:#3b82f6;--accent-hover:#2563eb;--accent-soft:#3b82f61f;--success:#22c55e;--success-soft:#22c55e1f;--warning:#f59e0b;--warning-soft:#f59e0b1f;--danger:#ef4444;--danger-soft:#ef44441f;--radius:12px;--radius-sm:8px;--shadow:0 1px 2px #00000040, 0 8px 24px #0003;--sidebar-width:240px;--content-max:880px;font-family:Inter,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;margin:0;line-height:1.6}a:not(.ui-btn){color:var(--accent);text-decoration:none}a:not(.ui-btn):hover{color:var(--accent-hover)}a.ui-btn{text-decoration:none;display:inline-flex}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.app-shell{grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh;display:grid}.sidebar{background:var(--bg-elevated);border-right:1px solid var(--border-subtle);flex-direction:column;gap:1.5rem;height:100vh;padding:1.5rem 1rem;display:flex;position:sticky;top:0}.brand{color:var(--text);letter-spacing:-.02em;font-size:1.05rem;font-weight:700}.sidebar-nav{flex-direction:column;gap:.25rem;display:flex}.sidebar-nav a{color:var(--text-muted);border-radius:var(--radius-sm);padding:.55rem .75rem;font-size:.925rem;font-weight:500}.sidebar-nav a:hover{background:var(--surface);color:var(--text)}.sidebar-nav a.active{background:var(--accent-soft);color:var(--accent)}.sidebar-footer{margin-top:auto}.shell-main{flex-direction:column;min-width:0;display:flex}.mobile-topbar{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;gap:1rem;padding:1rem 1.25rem;display:none}.mobile-topbar nav{gap:1rem;font-size:.875rem;display:flex}.shell-content{max-width:calc(var(--content-max) + 5rem);flex:1;padding:2rem 2.5rem 3rem}.shell-content-narrow{max-width:480px;margin:0 auto;padding:2rem 1.25rem 3rem}.page-stack{flex-direction:column;gap:1.25rem;display:flex}.page-header{margin-bottom:.5rem}.page-header h1{letter-spacing:-.03em;margin:0 0 .35rem;font-size:1.75rem;font-weight:700}.page-subtitle{color:var(--text-muted);max-width:52ch;margin:0;font-size:.95rem}.ui-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem}.ui-section-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.ui-section-header h2{margin:0 0 .25rem;font-size:1.05rem;font-weight:600}.ui-hint{color:var(--text-muted);margin:0;font-size:.875rem;line-height:1.5}.ui-error{color:var(--danger);margin:.35rem 0 0;font-size:.875rem}.ui-field{margin-bottom:1rem}.ui-field label{color:var(--text);margin-bottom:.4rem;font-size:.875rem;font-weight:500;display:block}.ui-input{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);padding:.65rem .85rem;font-size:.925rem;transition:border-color .15s}.ui-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft);outline:none}.ui-field-error .ui-input{border-color:var(--danger)}.ui-btn{border-radius:var(--radius-sm);cursor:pointer;border:1px solid #0000;justify-content:center;align-items:center;gap:.35rem;padding:.6rem 1rem;font-size:.875rem;font-weight:600;transition:background .15s,border-color .15s;display:inline-flex}.ui-btn:disabled{opacity:.55;cursor:not-allowed}.ui-btn-primary{background:var(--accent);color:#fff}.ui-btn-primary:hover:not(:disabled){background:var(--accent-hover)}.ui-btn-secondary{background:var(--surface-hover);border-color:var(--border);color:var(--text)}.ui-btn-secondary:hover:not(:disabled){background:var(--border)}.ui-btn-ghost{border-color:var(--border);color:var(--text-muted);background:0 0}.ui-btn-ghost:hover:not(:disabled){background:var(--surface-hover);color:var(--text)}.ui-btn-danger{color:#fca5a5;background:0 0;border-color:#ef444459}.ui-btn-danger:hover:not(:disabled){background:var(--danger-soft)}.ui-badge{letter-spacing:.01em;border-radius:999px;align-items:center;padding:.2rem .55rem;font-size:.75rem;font-weight:600;display:inline-flex}.ui-badge-default{background:var(--accent-soft);color:var(--accent)}.ui-badge-success{background:var(--success-soft);color:var(--success)}.ui-badge-warning{background:var(--warning-soft);color:var(--warning)}.ui-badge-muted{color:var(--text-muted);background:#94a3b81f}.ui-alert{border-radius:var(--radius-sm);border:1px solid;padding:.85rem 1rem;font-size:.875rem}.ui-alert-error{background:var(--danger-soft);color:#fecaca;border-color:#ef44444d}.ui-alert-success{background:var(--success-soft);color:#bbf7d0;border-color:#22c55e4d}.ui-alert-info{background:var(--accent-soft);color:#bfdbfe;border-color:#3b82f64d}.ui-empty{text-align:center;border:1px dashed var(--border);border-radius:var(--radius);background:#00000026;padding:2.5rem 1.5rem}.ui-empty h3{margin:0 0 .5rem;font-size:1rem}.ui-empty p{color:var(--text-muted);margin:0 0 1.25rem;font-size:.9rem}.ui-checkbox-row{cursor:pointer;align-items:flex-start;gap:.75rem;padding:.75rem 0;display:flex}.ui-checkbox-row input{accent-color:var(--accent);margin-top:.2rem}.ui-checkbox-label{color:var(--text);font-size:.925rem;font-weight:500;display:block}.ui-checkbox-row .ui-hint{margin-top:.25rem;display:block}.ui-codeblock{border:1px solid var(--border);border-radius:var(--radius-sm);background:#070b12;position:relative;overflow:hidden}.ui-codeblock pre{max-width:100%;margin:0;padding:1rem 3.5rem 1rem 1rem;overflow-x:auto}.ui-codeblock code{white-space:pre-wrap;word-break:break-all;color:#cbd5e1;font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:.8rem;line-height:1.55}.ui-copy-btn{position:absolute;top:.5rem;right:.5rem;padding:.35rem .65rem!important;font-size:.75rem!important}.ui-toast-stack{z-index:1000;flex-direction:column;gap:.5rem;display:flex;position:fixed;bottom:1.25rem;right:1.25rem}.ui-toast{border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:.75rem 1rem;font-size:.875rem;font-weight:500;animation:.2s toast-in}.ui-toast-success{color:#bbf7d0;background:#14532d;border:1px solid #166534}.ui-toast-error{color:#fecaca;background:#450a0a;border:1px solid #991b1b}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.hero-card{padding:2rem}.hero-card h1{letter-spacing:-.04em;margin:0 0 .75rem;font-size:2rem}.hero-lead{color:var(--text-muted);max-width:52ch;margin:0 0 1.5rem;font-size:1.05rem}.cta-row{flex-wrap:wrap;gap:.75rem;margin-bottom:2rem;display:flex}.steps-grid{grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:1rem;display:grid}.step-card{background:var(--bg);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:1rem}.step-num{background:var(--accent-soft);width:1.75rem;height:1.75rem;color:var(--accent);border-radius:999px;justify-content:center;align-items:center;margin-bottom:.65rem;font-size:.8rem;font-weight:700;display:inline-flex}.step-card h3{margin:0 0 .35rem;font-size:.925rem}.step-card p{color:var(--text-muted);margin:0;font-size:.85rem}.account-summary{align-items:center;gap:1rem;display:flex}.account-avatar{background:var(--accent-soft);width:3rem;height:3rem;color:var(--accent);border-radius:999px;justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;display:flex}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;display:grid}.project-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);flex-direction:column;gap:.75rem;padding:1.25rem;transition:border-color .15s;display:flex}.project-card:hover{border-color:var(--accent)}.project-card h3{margin:0;font-size:1rem}.project-card-meta{color:var(--text-faint);font-family:ui-monospace,monospace;font-size:.8rem}.overview-row{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.callback-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.callback-row{background:var(--bg);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.callback-row code{word-break:break-all;color:var(--text-muted);font-family:ui-monospace,monospace;font-size:.8rem}.callback-form{gap:.75rem;margin-top:1rem;display:flex}.callback-form .ui-input{flex:1}.oauth-grid{grid-template-columns:repeat(2,1fr);gap:1rem;display:grid}.oauth-provider-card{background:var(--bg);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);padding:1.25rem}.oauth-provider-card h3{margin:0 0 .5rem;font-size:1rem}.oauth-provider-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.oauth-actions{flex-wrap:wrap;gap:.5rem;margin-top:1rem;display:flex}.example-list{margin:.75rem 0 0;padding-left:0;list-style:none}.example-list li{color:var(--text-faint);padding:.25rem 0;font-family:ui-monospace,monospace;font-size:.8rem}.auth-page{max-width:420px;margin:0 auto}.auth-form .ui-btn-primary{width:100%;margin-top:.5rem;padding:.75rem}.tabs{gap:.35rem;margin-bottom:1.25rem;display:flex}.tabs button{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;flex:1;padding:.55rem;font-size:.875rem;font-weight:500}.tabs button.active{background:var(--accent-soft);color:var(--text);border-color:var(--accent)}.tabs button:focus-visible{outline:2px solid var(--accent)}.oauth-row{flex-direction:column;gap:.5rem;margin-bottom:1.25rem;display:flex}.oauth-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;padding:.65rem;font-weight:500}.oauth-btn:hover{background:var(--surface-hover)}.form-footer{text-align:center;color:var(--text-muted);margin-top:1.25rem;font-size:.875rem}.loading-state{color:var(--text-muted);padding:2rem 0}@media (width<=768px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.mobile-topbar{display:flex}.shell-content{padding:1.25rem 1rem 2rem}.steps-grid,.oauth-grid{grid-template-columns:1fr}.callback-row{flex-direction:column;align-items:stretch}.callback-form,.ui-section-header{flex-direction:column}}
