#root{margin:0;padding:0;width:100%;min-height:100vh}.app-container{display:flex;flex-direction:column;min-height:100vh;width:100%;background-color:#f5f5f5}main{flex:1;display:flex;justify-content:center;align-items:center;padding:2rem;background:linear-gradient(0deg,#17408B 0%,#C9082A 100%);margin-top:60px}.mode-toggle-bar{position:fixed;top:0;left:0;right:0;z-index:1000;background:white;border-bottom:2px solid #17408B;padding:15px;display:flex;justify-content:center;align-items:center;box-shadow:0 2px 4px #0000001a}.mode-slider{display:flex;background-color:#f0f0f0;border-radius:8px;padding:4px;border:2px solid #ddd}.mode-option{padding:6px 12px;font-size:12px;font-weight:700;border:none;border-radius:4px;cursor:pointer;background-color:transparent;color:#666;transition:all .3s;flex:1;min-width:70px;white-space:nowrap}.mode-option.active{background-color:#17408b;color:#fff;box-shadow:0 2px 4px #0003}.mode-option:not(.active):hover{background-color:#e0e0e0}.app-footer{text-align:center;padding:1rem;background-color:#17408b;color:#fff;font-size:.8rem}.loading-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(0deg,#17408B 0%,#C9082A 100%)}.loading-spinner{width:50px;height:50px;border:5px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.basketball-spinner{width:50px;height:50px;background-image:url(/basketball.svg);background-size:contain;background-repeat:no-repeat;background-position:center;animation:spin-bounce 1.5s infinite ease-in-out}@keyframes spin-bounce{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(.9)}to{transform:rotate(360deg) scale(1)}}.app-layout{display:grid;grid-template-columns:300px 1fr;gap:20px;width:100%;max-width:1200px;margin:0 auto;padding:20px;background:transparent}.data-sidebar{display:flex;flex-direction:column;gap:20px}.info-card,.example-queries-card{background:white;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:15px}.info-card h3,.example-queries-card h3{margin-top:0;color:#17408b;font-size:16px}.info-card ul{margin:0;padding-left:20px;font-size:14px;color:#555}.info-card li{margin-bottom:8px}.query-chip{background-color:#e9eef9;border:1px solid #17408B;color:#17408b;padding:8px 12px;border-radius:15px;font-size:14px;cursor:pointer;white-space:normal;margin-bottom:12px;display:block;width:100%;text-align:left;line-height:1.4;min-height:40px}.query-chip:hover{background-color:#d0d9ec}.app-layout.voice-mode{grid-template-columns:1fr;grid-template-rows:auto 1fr;max-width:800px}.app-layout.voice-mode .data-sidebar{grid-row:1;flex-direction:row;gap:20px;justify-content:center}.app-layout.voice-mode .info-card{flex:1;max-width:400px;text-align:center}.app-layout.voice-mode .example-queries-card{display:none}.desktop-only{display:block}@media (max-width: 768px){.desktop-only{display:none!important}.app-layout,.app-layout.voice-mode{grid-template-columns:1fr;padding:0;gap:0}.mode-toggle-bar{position:relative;margin-top:0;padding:10px 15px;background:#17408B;border-bottom:none;box-shadow:none}.mode-slider{background-color:#ffffff1a;border:1px solid rgba(255,255,255,.3)}.mode-option{color:#fffc;font-size:14px;padding:8px 16px}.mode-option.active{background-color:#fff;color:#17408b}.mode-option:not(.active):hover{background-color:#fff3}main{margin-top:0;padding:0;background:white}}.chatbot-container{display:flex;flex-direction:column;width:100%;height:auto;min-height:70vh;max-height:90vh;margin:0 auto;border-radius:8px;box-shadow:0 4px 12px #00000026;background-color:#fff;overflow:hidden}.chatbot-header{background-color:#17408b;color:#fff;padding:15px;text-align:center;display:flex;align-items:center;justify-content:center}.chatbot-header img{height:30px;margin-right:10px;filter:brightness(0) invert(1)}.chatbot-header h2{margin:0;font-size:1.2rem}.chatbot-messages{flex:1;padding:15px;overflow-y:auto;display:flex;flex-direction:column;gap:10px;background-color:#f9f9f9;min-height:300px}.message{padding:10px 15px;border-radius:18px;max-width:75%;word-break:break-word;position:relative}.message-cost{font-size:10px;opacity:.7;text-align:right;margin-top:4px;font-style:italic}.user-message{align-self:flex-end;background-color:#c9082a;color:#fff}.bot-message{align-self:flex-start;background-color:#17408b;color:#fff}.chatbot-input{display:flex;padding:10px;border-top:1px solid #eee;background-color:#fff;gap:10px}.chatbot-input input{flex:1;padding:10px;border:1px solid #ddd;border-radius:4px}.input-buttons{display:flex;gap:5px;align-items:center}.chatbot-input button{padding:10px 15px;background-color:#c9082a;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:700}.chatbot-input button:disabled{background-color:#e57f8c;cursor:not-allowed}.voice-button{background-color:#17408b!important;padding:8px 12px!important;font-size:16px;min-width:40px}.voice-button.listening{background-color:#c9082a!important;animation:pulse 1.5s infinite}.stop-speaking-button{background-color:#ff6b35!important;padding:8px 12px!important;font-size:16px;min-width:40px}.voice-conversation-button{background-color:#28a745!important;padding:8px 12px!important;font-size:16px;min-width:40px}.voice-conversation-button.connecting{background-color:#ffc107!important}.voice-conversation-button.connected{background-color:#dc3545!important;animation:pulse 2s infinite}.replay-audio-button{background-color:transparent!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important;padding:4px 8px!important;font-size:12px!important;margin-top:5px!important;border-radius:12px!important}.replay-audio-button:hover{background-color:#ffffff1a!important}@media (max-width: 768px){.voice-button,.stop-speaking-button{display:none!important}}.voice-conversation-button{display:flex!important}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.loading{padding:15px}.typing-indicator{display:flex;align-items:center;gap:5px}.typing-indicator span{width:10px;height:10px;background-image:url(/basketball.svg);background-size:contain;background-repeat:no-repeat;background-position:center;animation:bounce 1.5s infinite ease-in-out}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0) rotate(0)}30%{transform:translateY(-5px) rotate(30deg)}}.user-info{display:flex;align-items:center;justify-content:space-between;padding:10px 15px;background-color:#f1f1f1;border-bottom:1px solid #ddd}.user-name{font-weight:500;color:#333}.action-buttons{display:flex;gap:10px}.logout-button,.reset-button{background-color:transparent;border-radius:4px;cursor:pointer;font-size:14px;padding:5px 10px}.logout-button{color:#c9082a;border:1px solid #C9082A}.logout-button:hover{background-color:#f9e9eb}.reset-button{color:#17408b;border:1px solid #17408B}.reset-button:hover{background-color:#e9eef9}.total-cost{font-size:12px;color:#666;text-align:center;padding:5px;background-color:#f5f5f5;border-top:1px solid #eee}.error-message{margin:10px;padding:12px;border-radius:6px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center}.error-message p{margin:0;font-weight:500}.error-message button{padding:6px 12px;background-color:#17408b;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:700}.error-message.throttling{background-color:#fff3cd;border:1px solid #ffeeba;color:#856404}.error-message.dependency_failure{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.error-message.network{background-color:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.error-message.authentication{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.error-message.unknown{background-color:#e2e3e5;border:1px solid #d6d8db;color:#383d41}.error-message.voice{background-color:#fff3cd;border:1px solid #ffeeba;color:#856404}.message:has(.replay-audio-button){display:flex;flex-direction:column;align-items:flex-start}.voice-mode-container{padding:15px;background-color:#f0f8ff;border:2px solid #17408B;border-radius:8px;margin:10px;min-height:120px;display:flex;flex-direction:column;justify-content:center}.voice-status{text-align:center}.voice-active{color:#17408b;font-size:16px}.voice-connecting{color:#666;font-size:16px}.mode-toggle{padding:10px;text-align:center;border-top:1px solid #eee;background-color:#f9f9f9}.mode-toggle-button{padding:12px 24px;font-size:16px;font-weight:700;border:none;border-radius:6px;cursor:pointer;transition:all .3s}.mode-toggle-button.text-mode{background-color:#17408b;color:#fff}.mode-toggle-button.voice-mode{background-color:#c9082a;color:#fff}.mode-toggle-button:hover{transform:translateY(-1px);box-shadow:0 4px 8px #0003}.push-to-talk-container{margin-top:15px;text-align:center}.push-to-talk-button{padding:15px 30px;font-size:16px;font-weight:700;border:3px solid #17408B;border-radius:50px;background-color:#fff;color:#17408b;cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.push-to-talk-button:hover{background-color:#f0f8ff}.push-to-talk-button.recording{background-color:#c9082a;color:#fff;border-color:#c9082a;animation:pulse 1s infinite}.push-to-talk-button.recording:before{content:"";display:inline-block;width:8px;height:8px;background-color:#fff;border-radius:50%;margin-right:8px}.push-to-talk-button:disabled{opacity:.5;cursor:not-allowed}.recording-indicator{display:flex;align-items:center;gap:10px}.waveform{display:flex;align-items:center;gap:2px}.waveform .bar{width:3px;background-color:#fff;border-radius:2px;animation:waveform 1.2s ease-in-out infinite}.waveform .bar:nth-child(1){height:10px;animation-delay:0s}.waveform .bar:nth-child(2){height:15px;animation-delay:.1s}.waveform .bar:nth-child(3){height:20px;animation-delay:.2s}.waveform .bar:nth-child(4){height:15px;animation-delay:.3s}.waveform .bar:nth-child(5){height:10px;animation-delay:.4s}@keyframes waveform{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}.processing-indicator{display:flex;align-items:center;gap:10px;margin-top:10px;color:#17408b;font-weight:700}.spinner{width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #17408B;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chatbot-container.mobile{height:100vh;max-height:100vh;border-radius:0;box-shadow:none}.mobile-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:#17408b;color:#fff;position:sticky;top:0;z-index:100}.mobile-header-center{display:flex;align-items:center;gap:8px;flex:1;justify-content:center}.mobile-header-center img{height:20px;filter:brightness(0) invert(1)}.mobile-header h2{margin:0;font-size:1.1rem;font-weight:600}.hamburger-menu{background:none;border:none;cursor:pointer;padding:4px;display:flex;flex-direction:column;gap:3px;width:24px;height:24px}.hamburger-menu span{display:block;height:2px;width:100%;background-color:#fff;border-radius:1px;transition:all .3s ease}.voice-toggle-mobile{background:none;border:1px solid rgba(255,255,255,.3);color:#fff;padding:6px 12px;border-radius:4px;font-size:12px;font-weight:600;letter-spacing:.5px;cursor:pointer;transition:all .2s;min-width:50px}.voice-toggle-mobile:hover{background-color:#ffffff1a;border-color:#ffffff80}.mobile-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:1000;display:flex;align-items:flex-start;justify-content:flex-start}.mobile-menu{background-color:#fff;width:280px;height:100vh;box-shadow:2px 0 10px #0000001a;display:flex;flex-direction:column}.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;padding:16px;background-color:#17408b;color:#fff}.mobile-menu-header h3{margin:0;font-size:1.2rem}.close-menu{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:4px}.mobile-menu-content{flex:1;padding:20px;display:flex;flex-direction:column;gap:20px}.user-info-mobile{background-color:#f8f9fa;padding:16px;border-radius:8px;border-left:4px solid #17408B}.user-info-mobile p{margin:8px 0;font-size:14px}.available-data-mobile{background-color:#f8f9fa;padding:16px;border-radius:8px;border-left:4px solid #C9082A}.available-data-mobile h4{margin:0 0 12px;font-size:16px;color:#333;font-weight:600}.available-data-mobile ul{margin:0;padding-left:20px;list-style-type:disc}.available-data-mobile li{margin:6px 0;font-size:14px;color:#555;line-height:1.4}.mobile-menu-actions{display:flex;flex-direction:column;gap:12px}.menu-button{padding:12px 16px;border:1px solid #ddd;border-radius:8px;background-color:#fff;color:#333;font-size:16px;cursor:pointer;transition:all .2s;text-align:left;display:flex;align-items:center;gap:8px}.menu-button:hover{background-color:#f8f9fa;border-color:#17408b}.menu-button.logout{color:#c9082a;border-color:#c9082a}.menu-button.logout:hover{background-color:#fdf2f2}.chatbot-container.mobile .voice-mode-container{margin:0;border-radius:0;border-left:none;border-right:none;background-color:#f0f8ff;min-height:140px;position:sticky;bottom:0;z-index:50}.chatbot-container.mobile .push-to-talk-button{padding:20px 40px;font-size:18px;border-width:4px}.chatbot-container.mobile .chatbot-messages{flex:1;padding:12px 12px 160px}.chatbot-container.mobile .message{max-width:85%;font-size:16px;line-height:1.4}.chatbot-container.mobile .total-cost{display:none}.chatbot-container.mobile .chatbot-messages{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.chatbot-container.mobile .message{animation:none;transition:none}.chatbot-container.mobile .loading{position:sticky;bottom:0;background-color:#f9f9f9f2;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);margin:0 -12px;padding:12px}@media (max-width: 480px){.mobile-menu{width:100vw}.chatbot-container.mobile .message{max-width:90%;font-size:15px}.chatbot-container.mobile .push-to-talk-button{padding:18px 35px;font-size:16px}}.chatbot-container.desktop .mode-toggle{display:block}.chatbot-container.mobile .mode-toggle{display:none}.voice-error-actions{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}.voice-error-actions button{padding:8px 16px;border:none;border-radius:6px;background-color:#17408b;color:#fff;cursor:pointer;font-size:.9rem;transition:background-color .2s}.voice-error-actions button:hover{background-color:#0f2d5c}.voice-error-actions button:active{transform:translateY(1px)}@media (max-width: 768px){.voice-error-actions{flex-direction:column}.voice-error-actions button{width:100%;padding:12px;font-size:1rem}}.safari-voice-setup{text-align:center;padding:20px}.safari-voice-setup p{margin-bottom:15px;color:#666;font-size:.95rem}.start-voice-button{background:linear-gradient(135deg,#17408B,#1a4a9e);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #17408b4d;min-width:160px}.start-voice-button:hover{background:linear-gradient(135deg,#1a4a9e,#1e52b1);transform:translateY(-1px);box-shadow:0 4px 12px #17408b66}.start-voice-button:active{transform:translateY(0);box-shadow:0 2px 6px #17408b4d}@media (max-width: 768px){.safari-voice-setup{padding:15px}.start-voice-button{width:100%;padding:14px 24px;font-size:1.1rem}}.feedback-button{background-color:#28a745;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease;box-shadow:0 2px 4px #28a74533}.feedback-button:hover{background-color:#218838;transform:translateY(-1px);box-shadow:0 4px 8px #28a7454d}.feedback-button:active{transform:translateY(0);box-shadow:0 2px 4px #28a74533}.menu-button.feedback{background-color:#28a745;color:#fff}.menu-button.feedback:hover{background-color:#218838}@media (max-width: 768px){.action-buttons{flex-wrap:wrap;gap:8px}.feedback-button{font-size:.85rem;padding:6px 12px}}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(0deg,#17408B 0%,#C9082A 100%);padding:20px}.login-card{background-color:#fff;border-radius:10px;box-shadow:0 10px 25px #0003;padding:30px;width:100%;max-width:400px}.login-header{display:flex;flex-direction:column;align-items:center;margin-bottom:30px}.nba-logo{width:80px;height:auto;margin-bottom:15px}.login-header h1{color:#17408b;font-size:24px;margin:0}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.form-group input{width:100%;padding:12px;border:1px solid #ddd;border-radius:4px;font-size:16px}.login-button{width:100%;padding:12px;background-color:#c9082a;color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s}.login-button:hover{background-color:#a00622}.login-button:disabled{background-color:#e57f8c;cursor:not-allowed}.error-message{background-color:#ffebee;color:#c62828;padding:10px;border-radius:4px;margin-bottom:20px;font-size:14px}.auth-switch{text-align:center;margin-top:20px;color:#666}.link-button{background:none;border:none;color:#c9082a;cursor:pointer;text-decoration:underline;font-size:inherit}.link-button:hover{color:#a00622}.password-input-container{position:relative}.password-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#999}.password-toggle:hover{color:#666}.password-input-container input{padding-right:40px}.change-password-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#17408B 0%,#C9082A 100%)}.change-password-card{background-color:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;padding:30px;width:100%;max-width:400px}.change-password-card h2{color:#17408b;margin-top:0;text-align:center}.change-password-card p{color:#666;margin-bottom:20px;text-align:center}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#333}.form-group input{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:16px}.error-message{background-color:#ffebee;color:#c9082a;padding:10px;border-radius:4px;margin-bottom:15px;text-align:center}.submit-button{width:100%;padding:12px;background-color:#17408b;color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:700;cursor:pointer;margin-top:10px}.submit-button:hover{background-color:#0d2b5e}.submit-button:disabled{background-color:#9eb3d9;cursor:not-allowed}: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}}
