*{margin:0;padding:0;box-sizing:border-box}:root{--color-bg: #0f0f0f;--color-bg-secondary: #1a1a1a;--color-bg-elevated: #252525;--color-bg-header: #000000;--color-text: #ffffff;--color-text-muted: #888888;--color-border: #333333;--accent: #9a6dd7;--accent-secondary: #e066a0;--accent-dim: rgba(154, 109, 215, .15);--accent-glow: rgba(154, 109, 215, .4);--gradient-cta: linear-gradient(135deg, #6b4a9e 0%, #8b3d6e 100%);--gradient-cta-hover: linear-gradient(135deg, #7d5ab0 0%, #a04d82 100%);--space-xs: 8px;--space-sm: 12px;--space-md: 16px;--space-lg: 24px;--space-xl: 48px;--content-max-width: 480px;--padding-page: 24px;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--font-body: "IBM Plex Mono", "Menlo", "Consolas", "Monaco", monospace;font-family:var(--font-body);line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}@media(max-width:479px){:root{--text-xs: .6875rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.0625rem;--text-xl: 1.1875rem;--text-2xl: 1.375rem}}@media(min-width:768px){:root{--content-max-width: 520px;--padding-page: 40px}}.login-prompt{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);border-radius:12px;background:var(--color-bg-elevated)}.login-prompt__text{color:var(--color-text);font-size:var(--text-sm);line-height:1.4}.login-prompt__btn.btn{flex-shrink:0;border:1px solid var(--color-border);border-radius:12px;background:#ffffff0d;color:var(--color-text);font-weight:400;box-shadow:0 0 0 1px var(--color-border)}@media(hover:hover){.login-prompt__btn:hover{background:#ffffff1a;border-color:var(--color-text-muted)}}body{min-height:100vh;overflow-y:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-lg)}.modal{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:12px;padding:var(--space-lg);max-width:440px;width:100%;position:relative;display:flex;flex-direction:column;gap:var(--space-md)}.modal__close{position:absolute;top:var(--space-sm);right:var(--space-sm);background:none;border:none;color:var(--color-text-muted);font-size:var(--text-xl);cursor:pointer;line-height:1;padding:4px 8px}.modal__close:hover{color:var(--color-text)}.modal__title{font-size:var(--text-lg);font-weight:600;color:var(--color-text);padding-right:var(--space-lg)}.modal__text{color:var(--color-text-muted);font-size:var(--text-sm);line-height:1.6}.modal__highlight{text-decoration:underline;text-underline-offset:3px;font-weight:inherit}.modal__success{color:#4ade80}.modal__actions{display:flex;flex-direction:column;gap:var(--space-sm)}.modal__actions .btn{width:100%}.modal__login-btn{background:var(--gradient-cta);border:none;border-radius:12px;padding:12px 28px;font-size:var(--text-base);font-weight:600;color:var(--color-text);cursor:pointer;transition:transform .2s ease,box-shadow .3s ease,background .3s ease}@media(hover:hover){.modal__login-btn:hover{transform:translateY(-3px);background:var(--gradient-cta-hover);box-shadow:0 12px 28px #6b4a9e66,0 0 20px #8b3d6e4d}}.app{min-height:100vh}.loading-fallback{display:flex;align-items:center;justify-content:center;min-height:100vh}.loading-fallback__spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-xs);border:none;border-radius:12px;font-family:inherit;font-weight:600;line-height:1.4;cursor:pointer;transition:transform .2s ease,box-shadow .3s ease,background .3s ease,color .2s ease}.btn--primary{background:var(--gradient-cta);color:var(--color-text)}.btn--primary:active{transform:translateY(0)}.btn--success{background:#22a05a33;color:#4ade80;border:1px solid rgba(34,160,90,.4)}.btn--danger{background:#c8323226;color:#f87171;border:1px solid rgba(200,50,50,.3)}.btn:disabled{background:var(--color-border);color:var(--color-text-muted);cursor:default;transform:none;box-shadow:none}.btn--ghost{background:transparent;color:var(--color-text-muted);border-radius:8px}.btn--outline{background:transparent;color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:12px}@media(hover:hover){.btn--primary:hover{transform:translateY(-3px);background:var(--gradient-cta-hover);box-shadow:0 12px 28px #6b4a9e66,0 0 20px #8b3d6e4d}.btn--success:hover{background:#22a05a4d;color:#6ee7a0;border-color:#22a05a99}.btn--danger:hover{background:#c8323240;color:#fca5a5;border-color:#c8323280}.btn--ghost:hover{color:var(--color-text)}.btn--outline:hover{color:var(--color-text);border-color:var(--color-text-muted)}}.btn--md{padding:14px 24px;font-size:var(--text-lg)}.btn--sm{padding:12px 24px;font-size:var(--text-base)}.cookie-banner{position:fixed;left:var(--space-sm);right:var(--space-sm);bottom:calc(var(--space-sm) + env(safe-area-inset-bottom,0));z-index:250;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:16px;padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md);box-shadow:0 -8px 24px #0006}.cookie-banner__content{display:flex;flex-direction:column;gap:var(--space-sm);min-width:0}.cookie-banner__text{margin:0;font-size:var(--text-xs);line-height:1.45;color:var(--color-text-muted);text-align:left}.cookie-banner__text a{color:var(--color-text-muted);text-decoration:underline}.cookie-banner__highlight{color:var(--accent);font-weight:700;font-size:var(--text-sm)}.cookie-banner__error{margin:0;font-size:var(--text-xs);line-height:1.4;color:#f87171;text-align:left}.cookie-banner__actions{display:flex;gap:var(--space-sm);justify-content:stretch}.cookie-banner__actions>*{flex:1}@media(min-width:640px){.cookie-banner{flex-direction:row;align-items:center;justify-content:space-between;max-width:960px;margin:0 auto;left:var(--space-md);right:var(--space-md);bottom:calc(var(--space-md) + env(safe-area-inset-bottom,0))}.cookie-banner__actions{flex:0 0 auto}.cookie-banner__actions>*{flex:0 0 auto;min-width:140px}}.consent-renew{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:var(--space-md)}.consent-renew__backdrop{position:absolute;inset:0;background:#000000b3}.consent-renew__dialog{position:relative;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:16px;padding:var(--space-lg);max-width:440px;width:100%;display:flex;flex-direction:column;gap:var(--space-md);max-height:calc(100vh - var(--space-md) * 2);overflow-y:auto}.consent-renew__title{margin:0;font-size:var(--text-lg);font-weight:700}.consent-renew__text{margin:0;font-size:var(--text-sm);line-height:1.5;color:var(--color-text)}.consent-renew__text a{color:var(--accent);text-decoration:underline}.consent-renew__changes{margin:0;padding-left:var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs);font-size:var(--text-sm);line-height:1.5;color:var(--color-text-muted)}.consent-renew__error{margin:0;font-size:var(--text-xs);line-height:1.4;color:#f87171}.consent-renew__actions{display:flex;gap:var(--space-sm);justify-content:flex-end;flex-wrap:wrap}
