*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--tg-theme-bg-color, #ffffff);color:var(--tg-theme-text-color, #000000)}#root{width:100%;min-height:100vh}button{font-family:inherit}a{color:var(--tg-theme-link-color, #0088cc)}.forbidden-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center}.forbidden-page h1{font-size:6rem;margin:0;opacity:.3}.forbidden-page p{margin:.5rem 0;opacity:.7}.landing-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.landing-content{max-width:600px;text-align:center}.landing-quote-container{margin-bottom:3rem}.landing-quote{margin:0;padding:0}.landing-quote-text{font-size:1.75rem;font-weight:300;line-height:1.5;color:#fff;font-style:italic;margin-bottom:1.5rem}.landing-quote-author{font-size:1.1rem;color:#ffffffb3;font-style:normal}.landing-status{margin-bottom:2.5rem}.landing-status-badge{display:inline-block;padding:.5rem 1.25rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:999px;color:#fffc;font-size:.875rem;letter-spacing:.05em}.landing-cta{margin-top:2rem}.landing-login-button{display:inline-block;padding:1rem 2rem;background:#08c;color:#fff;text-decoration:none;border-radius:8px;font-size:1rem;font-weight:500;transition:background-color .2s ease,transform .2s ease}.landing-login-button:hover{background:#0077b5;transform:translateY(-2px)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)}.login-container{background:#fffffff2;padding:2.5rem;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:400px;width:100%;text-align:center}.login-container h1{font-size:1.75rem;font-weight:600;color:#1a1a2e;margin-bottom:.75rem}.login-container>p{color:#666;font-size:.95rem;margin-bottom:2rem}.loading-state{padding:1rem;color:#666}.loading-state p{margin:0;font-size:.95rem}.error-message{background:#fff2f0;border:1px solid #ffccc7;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.error-message p{margin:0;color:#cf1322;font-size:.9rem}.loading-container{min-height:100vh;display:flex;align-items:center;justify-content:center}.loading-container p{color:#666;font-size:1rem}.landing-login-corner{position:absolute;top:1.5rem;right:1.5rem;display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}.landing-login-loading{color:#ffffffb3;font-size:.875rem}.landing-login-error{color:#ff6b6b;font-size:.75rem;background:#ff6b6b1a;padding:.25rem .5rem;border-radius:4px}.logout-button{display:block;width:100%;margin-top:24px;padding:12px 16px;background:transparent;border:1px solid var(--tg-theme-destructive-text-color, #ff3b30);border-radius:8px;color:var(--tg-theme-destructive-text-color, #ff3b30);font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.logout-button:hover{background:#ff3b301a}
