:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.auth-loading,.auth-error{display:flex;justify-content:center;align-items:center;height:100vh}.auth-error{flex-direction:column}.auth-error h2{margin-bottom:1rem;color:#dc3545}.auth-error p{margin-bottom:1rem;color:#6c757d}.auth-dashboard{display:flex;flex-direction:column;align-items:center;padding:2rem;max-width:800px;margin:0 auto}.auth-dashboard h1{margin-bottom:2rem;color:#333}.user-info-card,.tokens-card{background:#f5f5f5;padding:1rem;border-radius:8px;margin-bottom:1rem;width:100%}.tokens-card{background:#f0f0f0}.user-info-card h3,.tokens-card h3{margin-top:0;margin-bottom:1rem;color:#333}.user-info-card pre{font-size:14px;overflow:auto;margin:0;background:transparent}.tokens-section{font-size:12px;word-break:break-all}.tokens-section p{margin:1rem 0 .5rem;font-weight:700}.tokens-section p:first-child{margin-top:0}.token-display{background:#fff;padding:.5rem;border-radius:4px;overflow:auto;margin-bottom:1rem;font-family:Courier New,monospace;font-size:11px;border:1px solid #ddd}.auth-buttons{display:flex;gap:1rem;margin-top:1rem}.auth-login{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.auth-login h1{margin-bottom:1rem;font-size:3rem;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.auth-login p{margin-bottom:2rem;font-size:1.2rem;opacity:.9}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .2s ease;text-decoration:none;display:inline-block;text-align:center}.btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0003}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover{background-color:#545b62}.btn-light{background-color:#f8f9fa;color:#333;border:1px solid #dee2e6}.btn-light:hover{background-color:#e2e6ea}@media (max-width: 768px){.auth-dashboard{padding:1rem}.auth-login h1{font-size:2rem}.auth-buttons{flex-direction:column;width:100%;max-width:300px}.btn{width:100%}}.logout-button-primary{padding:12px 24px;font-size:16px;font-weight:600;background-color:#0d80f2;color:#fff;border:none;border-radius:8px;cursor:pointer;margin:8px;transition:all .2s ease}.logout-button-primary:hover{background-color:#0b6bd1;transform:translateY(-1px);box-shadow:0 4px 12px #0d80f24d}.logout-button-primary:active{transform:translateY(0);box-shadow:0 2px 6px #0d80f233}.logout-button-secondary{padding:12px 24px;font-size:16px;font-weight:500;background-color:transparent;color:#0d80f2;border:2px solid #0D80F2;border-radius:8px;cursor:pointer;margin:8px;transition:all .2s ease}.logout-button-secondary:hover{background-color:#0d80f20a;transform:translateY(-1px);box-shadow:0 4px 12px #0d80f226}.logout-button-secondary:active{background-color:#0d80f214;transform:translateY(0);box-shadow:0 2px 6px #0d80f21a}@media (max-width: 599px){.logout-button-primary,.logout-button-secondary{width:100%;margin:4px 0}}@media (min-width: 600px){.logout-button-primary,.logout-button-secondary{min-width:140px}}#root{width:100%;margin:0;padding:0}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
