.toast{display:flex;align-items:center;justify-content:space-between;min-width:300px;max-width:500px;padding:12px 16px;margin-bottom:12px;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideIn .3s ease-out;position:relative;z-index:1000}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-content{display:flex;align-items:center;flex:1;gap:12px}.toast-icon{font-size:20px;font-weight:700;flex-shrink:0}.toast-message{flex:1;font-size:14px;line-height:1.4}.toast-close{background:none;border:none;font-size:24px;cursor:pointer;padding:0;margin-left:12px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .2s;flex-shrink:0}.toast-close:hover{opacity:1}.toast-close:focus{outline:2px solid currentColor;outline-offset:2px;border-radius:4px}.toast-success{background-color:#d4edda;color:#155724;border-left:4px solid #28a745}.toast-success .toast-icon{color:#28a745}.toast-error{background-color:#f8d7da;color:#721c24;border-left:4px solid #dc3545}.toast-error .toast-icon{color:#dc3545}.toast-warning{background-color:#fff3cd;color:#856404;border-left:4px solid #ffc107}.toast-warning .toast-icon{color:#ffc107}.toast-info{background-color:#d1ecf1;color:#0c5460;border-left:4px solid #17a2b8}.toast-info .toast-icon{color:#17a2b8}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;align-items:flex-end}@media (max-width: 768px){.toast-container{top:10px;right:10px;left:10px}.toast{min-width:auto;max-width:100%}}.spinner-wrapper{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.spinner-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#ffffffe6;z-index:9998;min-height:100vh}.spinner{display:inline-block;position:relative}.spinner-circle{border:3px solid var(--border-light, #e0e0e0);border-top:3px solid var(--accent-blue, #667eea);border-radius:50%;animation:spin 1s linear infinite}.spinner-small{width:20px;height:20px}.spinner-small .spinner-circle{width:20px;height:20px;border-width:2px}.spinner-medium,.spinner-medium .spinner-circle{width:40px;height:40px}.spinner-large{width:60px;height:60px}.spinner-large .spinner-circle{width:60px;height:60px;border-width:4px}.spinner-message{color:var(--text-secondary, #666);font-size:14px;margin:0;text-align:center}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:40px 20px}.error-boundary-content{max-width:600px;text-align:center;padding:40px;background:#fff;border-radius:12px;box-shadow:0 4px 12px #0000001a}.error-boundary-title{font-size:32px;font-weight:700;color:#dc3545;margin:0 0 16px}.error-boundary-message{font-size:16px;color:#666;margin:0 0 24px;line-height:1.6}.error-boundary-details{text-align:left;margin:24px 0;padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e0e0e0}.error-boundary-details summary{cursor:pointer;font-weight:600;color:#333;margin-bottom:12px;-webkit-user-select:none;user-select:none}.error-boundary-details summary:hover{color:#667eea}.error-boundary-stack{font-size:12px;color:#721c24;background:#fff;padding:12px;border-radius:4px;overflow-x:auto;white-space:pre-wrap;word-break:break-word;margin:0;font-family:Monaco,Menlo,Ubuntu Mono,monospace}.error-boundary-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.error-boundary-button{padding:12px 24px;font-size:16px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s;background:#667eea;color:#fff}.error-boundary-button:hover{background:#5568d3;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.error-boundary-button:active{transform:translateY(0)}.error-boundary-button:focus{outline:2px solid #667eea;outline-offset:2px}.error-boundary-button-secondary{background:#6c757d}.error-boundary-button-secondary:hover{background:#5a6268;box-shadow:0 4px 8px #6c757d4d}@media (max-width: 768px){.error-boundary-content{padding:24px}.error-boundary-title{font-size:24px}.error-boundary-actions{flex-direction:column}.error-boundary-button{width:100%}}.btn{border-radius:8px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;font-family:inherit;position:relative;overflow:hidden}.btn:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--gradient-primary);color:#fff;border:none;position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.btn-primary:hover:not(:disabled):before{left:100%}.btn-primary:hover:not(:disabled){background:var(--gradient-primary-hover);transform:translateY(-2px);box-shadow:0 12px 28px #3b82f673,0 4px 12px #3b82f64d}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:0 4px 12px #3b82f64d}.btn-secondary{background:var(--bg-primary);border:1px solid var(--border-light);color:var(--text-secondary);position:relative;overflow:hidden}.btn-secondary:before{content:"";position:absolute;top:0;left:0;width:0;height:100%;background:var(--gradient-primary);opacity:.1;transition:width .3s ease;z-index:0}.btn-secondary:hover:not(:disabled):before{width:100%}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent-blue);color:var(--accent-blue);transform:translateY(-1px);box-shadow:0 6px 16px #3b82f633,0 2px 6px #3b82f61a}.btn-secondary:active:not(:disabled){transform:translateY(0)}.btn-secondary>*{position:relative;z-index:1}.btn-success{background:var(--success);color:#fff;border:none}.btn-success:hover:not(:disabled){background:var(--success-hover);transform:translateY(-2px);box-shadow:0 8px 25px #28a7454d}.btn-error{background:var(--error);color:#fff;border:none}.btn-error:hover:not(:disabled){background:#dc2626;transform:translateY(-1px);box-shadow:0 6px 16px #ef44444d}.btn-error:active:not(:disabled){transform:translateY(0)}.btn-small{padding:8px 16px;font-size:14px}.btn-medium{padding:12px 24px;font-size:16px}.btn-large{padding:16px 32px;font-size:16px}.header{background-color:#fffc;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:100;box-shadow:0 1px #0000000d;transition:all .3s ease}.header-container{max-width:1280px;margin:0 auto;padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:64px}.logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:inherit;transition:all .3s ease}.logo:hover{opacity:.8;transform:translateY(-1px)}.logo:hover .logo-icon{transform:rotate(5deg) scale(1.05);transition:transform .3s ease}.logo-icon{width:32px;height:32px;display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr);gap:0;padding:0;overflow:hidden;border-radius:4px}.logo-square{width:100%;height:100%;border-radius:0}.logo-text{font-size:20px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;line-height:1;display:flex;align-items:center}.nav{display:flex;align-items:center;gap:32px}.nav-links{display:flex;align-items:center;gap:24px;list-style:none;margin:0;padding:0}.nav-link{color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:15px;transition:all .3s ease;padding:8px 12px;border-radius:6px;position:relative}.nav-link:after{content:"";position:absolute;bottom:4px;left:0;right:0;transform:scaleX(0);width:100%;height:2px;background:var(--gradient-primary);border-radius:1px;transition:transform .3s ease;transform-origin:center}.nav-link:hover{color:var(--accent-blue);background:#3b82f60d}.nav-link:hover:after{transform:scaleX(1)}.nav-link.active{color:var(--accent-blue);font-weight:600;background:#3b82f614}.nav-link.active:after{transform:scaleX(1)}.auth-buttons{display:flex;align-items:center;gap:12px}.auth-buttons a{text-decoration:none}.synesthesia-dropdown{position:relative}.synesthesia-menu-button{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text-secondary);font-size:15px;font-weight:500;cursor:pointer;padding:8px 12px;border-radius:6px;transition:all .2s ease}.synesthesia-menu-button:hover{color:var(--text-primary);background-color:var(--bg-secondary)}.user-dropdown{position:relative}.user-menu-button{display:flex;align-items:center;gap:8px;background:none;border:none;color:var(--text-secondary);font-size:15px;font-weight:500;cursor:pointer;padding:8px 12px;border-radius:6px;transition:all .2s ease}.user-menu-button:hover{color:var(--text-primary);background-color:var(--bg-secondary)}.dropdown-chevron{width:6px;height:6px;border-right:1.5px solid var(--text-secondary);border-bottom:1.5px solid var(--text-secondary);transform:rotate(45deg);transition:all .3s cubic-bezier(.4,0,.2,1);display:inline-block;margin-left:6px;margin-bottom:2px}.dropdown-chevron.open{transform:rotate(225deg);margin-bottom:-2px}.synesthesia-menu-button:hover .dropdown-chevron,.user-menu-button:hover .dropdown-chevron{border-color:var(--text-primary)}.synesthesia-menu-button .dropdown-chevron,.user-menu-button .dropdown-chevron{border-color:var(--text-secondary)}.user-menu-button:hover .dropdown-chevron{border-color:var(--text-primary)}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-primary);border:1px solid var(--border-light);border-radius:8px;box-shadow:0 4px 12px #0000001a;min-width:180px;z-index:1000;overflow:hidden}.dropdown-item{display:block;width:100%;padding:12px 16px;text-align:left;color:var(--text-primary);text-decoration:none;font-size:15px;font-weight:500;background:none;border:none;cursor:pointer;transition:background-color .2s ease}.dropdown-item:hover{background-color:var(--bg-secondary)}.dropdown-divider{height:1px;background-color:var(--border-light);margin:4px 0}.mobile-menu-backdrop{display:none;transition:opacity .3s ease}.mobile-menu-backdrop:active{opacity:.5}.hamburger-button{display:none;flex-direction:column;justify-content:space-around;width:32px;height:32px;background:transparent;border:none;cursor:pointer;padding:0;z-index:1001;position:relative}.hamburger-line{width:100%;height:2.5px;background-color:var(--text-primary);border-radius:2px;transition:all .3s cubic-bezier(.4,0,.2,1);transform-origin:center}.hamburger-button:hover .hamburger-line{background-color:var(--accent-blue)}.hamburger-line.open:nth-child(1){transform:rotate(45deg) translate(7px,7px)}.hamburger-line.open:nth-child(2){opacity:0;transform:translate(-10px)}.hamburger-line.open:nth-child(3){transform:rotate(-45deg) translate(7px,-7px)}@media (max-width: 768px){.header-container{padding:0 20px;position:relative}.hamburger-button{display:flex;order:2;margin-left:auto;min-width:44px;min-height:44px;padding:6px;align-items:center}.logo{order:1;flex:1}.mobile-menu-backdrop{display:block;position:fixed;top:64px;left:0;right:0;bottom:0;background:#0000004d;z-index:999;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.nav{position:fixed;top:64px;left:0;right:0;background:var(--bg-primary);border-bottom:1px solid var(--border-light);box-shadow:0 4px 12px #0000001a;flex-direction:column;align-items:stretch;gap:0;padding:20px;max-height:0;overflow:hidden;opacity:0;visibility:hidden;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1000}.nav.mobile-open{max-height:calc(100vh - 64px);opacity:1;visibility:visible;overflow-y:auto;-webkit-overflow-scrolling:touch}body.mobile-menu-open{overflow:hidden}.nav-links{flex-direction:column;gap:0;width:100%;margin-bottom:20px}.nav-links li{width:100%}.nav-link{display:block;width:100%;padding:14px 16px;font-size:16px;border-radius:8px;margin-bottom:4px;text-align:left;min-height:44px;display:flex;align-items:center}.nav-link:after{display:none}.nav-link:hover{background:#3b82f614;color:var(--accent-blue)}.auth-buttons{flex-direction:column;gap:12px;width:100%;align-items:stretch;margin-top:8px}.auth-buttons a{width:100%;display:block}.auth-buttons .button{width:100%;justify-content:center}.auth-buttons .user-dropdown,.synesthesia-dropdown,.user-dropdown{width:100%}.synesthesia-menu-button,.user-menu-button{width:100%;justify-content:space-between;padding:14px 16px;font-size:16px;text-align:left;min-height:44px;display:flex;align-items:center}.synesthesia-menu-button:hover,.user-menu-button:hover{background:#3b82f614;color:var(--accent-blue)}.dropdown-menu{position:static;width:100%;margin-top:8px;margin-bottom:12px;box-shadow:0 2px 8px #00000014;border:1px solid var(--border-light);border-radius:8px;background:var(--bg-secondary)}.dropdown-item{padding:14px 16px;font-size:15px;min-height:44px;display:flex;align-items:center}.dropdown-item:hover{background:#3b82f61a;color:var(--accent-blue)}.dropdown-item.disabled{opacity:.6;cursor:not-allowed}.dropdown-item.disabled:hover{background:transparent;color:var(--text-secondary)}.logo-text{font-size:18px}.logo-icon{width:28px;height:28px}.nav-links li:not(:last-child){margin-bottom:4px}.synesthesia-dropdown .dropdown-menu,.user-dropdown .dropdown-menu{animation:slideDown .2s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}}@media (max-width: 1024px) and (min-width: 769px){.header-container{padding:0 24px}.nav{gap:24px}.nav-links{gap:16px}.logo-text{font-size:19px}}.footer{background-color:var(--bg-primary);border-top:1px solid var(--border-light);margin-top:auto;padding:40px 0;position:relative}.footer:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:100px;height:1px;background:var(--gradient-primary);opacity:.3}.footer-container{max-width:1280px;margin:0 auto;padding:0 32px}.footer-bottom{display:flex;justify-content:center;align-items:center}.footer-copyright{color:var(--text-secondary);font-size:14px;font-weight:400;text-align:center;line-height:1.5}.footer-link{color:var(--text-secondary);text-decoration:none;transition:all .3s ease;position:relative;padding:2px 4px;border-radius:4px}.footer-link:after{content:"";position:absolute;bottom:0;left:0;right:0;transform:scaleX(0);width:100%;height:1.5px;background:var(--gradient-primary);border-radius:1px;transition:transform .3s ease;transform-origin:center}.footer-link:hover{color:var(--accent-blue);background:#3b82f60d}.footer-link:hover:after{transform:scaleX(1)}@media (max-width: 768px){.footer{padding:24px 0}.footer-container{padding:0 24px}.footer-copyright{font-size:12px}}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1}*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f8f9fa;--bg-input: #f9fafb;--bg-input-focus: #ffffff;--text-primary: #111827;--text-secondary: #6b7280;--text-tertiary: #9ca3af;--text-muted: #d1d5db;--border-light: #e5e7eb;--border-medium: #d1d5db;--border-dark: #d1d5db;--accent-blue: #3b82f6;--accent-blue-hover: #2563eb;--accent-purple: #8b5cf6;--success: #10b981;--error: #ef4444;--warning: #f59e0b;--error-bg: #f8d7da;--error-text: #721c24;--gradient-primary: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);--gradient-primary-hover: linear-gradient(135deg, #2563eb 0%, #7c3aed 100%);--gradient-secondary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-text: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;font-size:16px;font-weight:400;min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.011em}#root{min-height:100vh;display:flex;flex-direction:column}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.fade-in{animation:fadeIn .3s ease-out}.slide-up{animation:slideUp .3s ease-out}.slide-down{animation:slideDown .3s ease-out}.scale-in{animation:scaleIn .3s ease-out}a,button,input,select,textarea{transition:all .2s ease}*:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px;border-radius:4px}.skip-to-main{position:absolute;top:-40px;left:0;background:var(--accent-blue);color:#fff;padding:8px 16px;text-decoration:none;z-index:10000;border-radius:0 0 4px 4px}.skip-to-main:focus{top:0}
