: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}html,body{margin:0;padding:0;width:100%;height:100%;overflow-x:hidden;-webkit-overflow-scrolling:touch}body{min-width:320px;min-height:100vh;min-height:100dvh;margin:0;padding:0;overflow-x:hidden;position:relative}#root{width:100%;height:100%;min-height:100vh;min-height:100dvh;margin:0;padding:0;overflow-x:hidden;position:relative}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-container{display:flex;justify-content:center;align-items:flex-start;min-height:100vh;min-height:100dvh;width:100%;padding:1rem;background:linear-gradient(135deg,#667eea,#764ba2);position:relative;overflow-x:hidden;overflow-y:auto;box-sizing:border-box;-webkit-overflow-scrolling:touch}.auth-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:float 20s ease-in-out infinite}@keyframes float{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(30px,-30px) rotate(120deg)}66%{transform:translate(-20px,20px) rotate(240deg)}}.auth-card{background:#ffffff40;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:20px;padding:2.5rem;border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 32px #1f26875e,inset 0 1px #ffffff4d;width:100%;max-width:400px;box-sizing:border-box;position:relative;z-index:1;transition:transform .3s ease,box-shadow .3s ease}.auth-card:hover{transform:translateY(-2px);box-shadow:0 12px 40px #1f268773,inset 0 1px #fff6}@media(max-width:768px){.auth-container{padding:0;min-height:100vh;min-height:100dvh;align-items:flex-start;overflow-y:auto;overflow-x:hidden}.auth-card{border-radius:0;padding:2rem 1.5rem;max-width:100%;min-height:auto;height:auto;display:flex;flex-direction:column;justify-content:flex-start;margin:0;flex-shrink:0}.auth-card h2{font-size:1.75rem}.auth-subtitle{font-size:.9rem}.form-group{margin-bottom:1.25rem}.form-group input{font-size:16px}.switch-form{margin-top:1.5rem;padding-bottom:2rem}}@media(max-width:480px){.auth-container{padding:0}.auth-card{padding:1.5rem 1rem;min-height:auto}.auth-card h2{font-size:1.5rem;margin-bottom:.75rem}.auth-header{margin-bottom:1.5rem}.maash-logo-container{margin-bottom:1rem}.switch-form{margin-top:1rem;padding-bottom:1.5rem}}.auth-back-button{position:absolute;top:1rem;left:1rem;background:#fff3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fffffff2;border:1px solid rgba(255,255,255,.3);border-radius:8px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease;z-index:10;text-decoration:none;display:inline-flex;align-items:center;gap:.25rem}.auth-back-button:hover{background:#ffffff4d;border-color:#ffffff80;transform:translate(-2px)}.auth-back-button:active{transform:translate(-1px)}@media(max-width:768px){.auth-back-button{top:.75rem;left:.75rem;padding:.5rem .875rem;font-size:.8125rem}}.maash-logo-container{text-align:center;margin-bottom:1.5rem;display:flex;justify-content:center;align-items:center}.maash-logo{height:40px;width:auto;filter:brightness(0) invert(1);opacity:.95;transition:opacity .3s ease}.maash-logo:hover{opacity:1}.auth-header{text-align:center;margin-bottom:2rem}.auth-card h2{margin:0 0 .5rem;color:#fffffff2;font-size:2rem;text-align:center;text-shadow:0 2px 10px rgba(0,0,0,.1);font-weight:600;letter-spacing:-.5px}.auth-subtitle{margin:0;color:#fffc;font-size:.95rem;font-weight:400}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#ffffffe6;font-weight:500;text-shadow:0 1px 3px rgba(0,0,0,.1)}.form-group input{width:100%;padding:.75rem;background:#fff3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:12px;font-size:1rem;color:#fffffff2;transition:all .3s ease;box-sizing:border-box;box-shadow:inset 0 1px 2px #fff3,0 2px 8px #0000001a}.form-group input::placeholder{color:#fff9}.form-group input:focus{outline:none;border-color:#ffffff80;background:#ffffff4d;box-shadow:inset 0 1px 2px #ffffff4d,0 4px 12px #667eea4d}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{padding-right:3rem}.password-toggle{position:absolute;right:.75rem;background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem;display:flex;align-items:center;justify-content:center;color:#666;transition:color .2s;z-index:1}.password-toggle:hover{color:#667eea}.password-toggle:focus{outline:2px solid #667eea;outline-offset:2px;border-radius:4px}.password-hint{display:block;margin-top:.5rem;color:#666;font-size:.85rem;line-height:1.4}.auth-button{width:100%;padding:.75rem;background:#ffffff4d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-bottom:1rem;box-shadow:0 4px 16px #1f26874d,inset 0 1px #fff6;text-shadow:0 1px 2px rgba(0,0,0,.1)}.auth-button:hover:not(:disabled){transform:translateY(-2px);background:#fff6;box-shadow:0 8px 24px #1f268766,inset 0 1px #ffffff80;border-color:#ffffff80}.auth-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #1f26874d,inset 0 1px #ffffff4d}.auth-button:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#dc354533;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fffffff2;padding:.75rem;border-radius:12px;margin-bottom:1rem;border:1px solid rgba(220,53,69,.3);box-shadow:0 2px 8px #dc354533}.success-message{background:#28a74533;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fffffff2;padding:.75rem;border-radius:12px;margin-bottom:1rem;border:1px solid rgba(40,167,69,.3);box-shadow:0 2px 8px #28a74533}.switch-form{text-align:center;color:#fffc;margin-top:1rem}.link-button{background:none;border:none;color:#fffffff2;cursor:pointer;font-weight:600;text-decoration:underline;text-decoration-color:#ffffff80;padding:0;font-size:inherit;transition:all .2s ease}.link-button:hover{color:#fff;text-decoration-color:#fffc}@media(prefers-color-scheme:dark){.auth-card{background:#1a1a1a;color:#ffffffde}.auth-card h2{color:#ffffffde}.auth-subtitle{color:#fff9}.form-group label{color:#ffffffb3}.form-group input{background:#2a2a2a;border-color:#444;color:#ffffffde}.form-group input:focus{border-color:#667eea}.password-toggle{color:#fff9}.password-toggle:hover{color:#667eea}.password-hint{color:#ffffff80}.switch-form{color:#fff9}}.chatbot-container{display:flex;flex-direction:column;height:100vh;height:100dvh;width:100%;background:linear-gradient(135deg,#667eea,#764ba2);position:fixed;inset:0;box-sizing:border-box;overflow:hidden;margin:0;padding:0;align-items:stretch;justify-content:flex-start}.chatbot-header{background:#ffffff26;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#fff;padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.2);box-shadow:0 2px 20px #1f268733;z-index:150;position:relative;flex-shrink:0;flex-grow:0;min-height:60px;height:60px;width:100%;box-sizing:border-box;order:1;display:flex;align-items:center;visibility:visible;opacity:1}.chatbot-header h2{margin:0;font-size:1.5rem;font-weight:600}.chatbot-header .maash-logo-container{display:flex;align-items:center;justify-content:center;height:100%}.chatbot-header .maash-logo{height:28px;width:auto;filter:brightness(0) invert(1);opacity:.95;transition:opacity .3s ease;margin:0}.chatbot-header .maash-logo:hover{opacity:1}.chatbot-messages{flex:1 1 0;overflow-y:auto;overflow-x:hidden;padding:1.5rem;display:flex;flex-direction:column;gap:1rem;background:transparent;position:relative;z-index:1;min-height:0;order:2;-webkit-overflow-scrolling:touch}.chatbot-messages::-webkit-scrollbar{width:8px}.chatbot-messages::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}.chatbot-messages::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px;border:1px solid rgba(255,255,255,.1)}.chatbot-messages::-webkit-scrollbar-thumb:hover{background:#ffffff80}.chatbot-welcome{text-align:center;padding:2rem;color:#ffffffe6;font-size:1.1rem;text-shadow:0 2px 10px rgba(0,0,0,.1)}.message-date-divider{text-align:center;margin:1.5rem 0;padding:.5rem 1rem;color:#ffffffb3;font-size:.875rem;font-weight:500;text-transform:capitalize;position:relative}.message-date-divider:before,.message-date-divider:after{content:"";position:absolute;top:50%;width:30%;height:1px;background:#fff3}.message-date-divider:before{left:0}.message-date-divider:after{right:0}.load-older-messages-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;min-height:200px;cursor:pointer;transition:background-color .3s ease,opacity .2s ease;border-radius:12px;margin-bottom:1rem;border:1px dashed rgba(255,255,255,.2);background:#ffffff05}.load-older-messages-zone:hover{background:#ffffff0d}.load-older-messages-zone.loading{cursor:wait;opacity:.6;pointer-events:none}.load-older-messages-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#fff3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:24px;color:#fffffff2;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #1f268733,inset 0 1px #fff3}.load-older-messages-button:hover:not(:disabled){background:#ffffff4d;border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 8px 24px #1f26874d,inset 0 1px #ffffff4d}.load-older-messages-button:active:not(:disabled){transform:translateY(0)}.load-older-messages-button:disabled{opacity:.5;cursor:not-allowed}.load-older-messages-hint{margin-top:1rem;font-size:.875rem;color:#fff9;text-align:center;line-height:1.4}.load-older-messages-button svg{width:18px;height:18px}.loading-older-messages{display:flex;justify-content:center;align-items:center;padding:1rem;color:#ffffffb3}.loading-older-messages-top{display:flex;justify-content:center;align-items:center;padding:1rem;position:sticky;top:0;z-index:10;background:#667eea1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);margin-bottom:.5rem}.loading-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.2);border-top-color:#ffffffe6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.message{display:flex;margin-bottom:.5rem;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{justify-content:flex-end}.message.bot{justify-content:flex-start}.message-content{max-width:70%;padding:.75rem 1rem;border-radius:18px;position:relative;word-wrap:break-word}.message-text{white-space:pre-wrap;line-height:1.5}.message-text span{display:inline}.message-text-html{white-space:normal;line-height:1.5}.message-text-html p{margin:0 0 .5rem}.message-text-html p:last-child{margin-bottom:0}.message-text-html ul,.message-text-html ol{margin:.5rem 0 .75rem 1.5rem;padding-left:1.25rem}.message-text-html li{margin-bottom:.35rem}.message-text-html li:last-child{margin-bottom:0}.message.user .message-content{background:#ffffff4d;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#fff;border:1px solid rgba(255,255,255,.3);border-bottom-right-radius:4px;box-shadow:0 4px 16px #1f26874d,inset 0 1px #ffffff4d}.message.bot .message-content{background:#ffffff40;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#fffffff2;border:1px solid rgba(255,255,255,.2);border-bottom-left-radius:4px;box-shadow:0 4px 16px #1f268733,inset 0 1px #fff3}.message-content p{margin:0 0 .25rem;line-height:1.5}.message-time{font-size:.75rem;opacity:.7;display:block;margin-top:.25rem}.message.user .message-time{color:#fffc}.message.bot .message-time{color:#999}.message.error .message-content{background:#dc354540;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(220,53,69,.3);color:#fffffff2;box-shadow:0 4px 16px #dc354533,inset 0 1px #fff3}.message.typing .message-content{background:#ffffff40;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 16px #1f268733,inset 0 1px #fff3;padding:1rem 1.25rem}.typing-cursor{display:inline-block;animation:blink 1s infinite;margin-left:2px;color:#fffffff2}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.message.loading .message-content{background:#ffffff40;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 16px #1f268733,inset 0 1px #fff3;padding:1rem 1.25rem}.loading-dots{display:flex;gap:.5rem;align-items:center}.loading-dots span{width:8px;height:8px;border-radius:50%;background:#fffc;animation:loadingDot 1.4s infinite ease-in-out;box-shadow:0 2px 4px #0003}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}.loading-dots span:nth-child(3){animation-delay:0s}@keyframes loadingDot{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1);opacity:1}}.chatbot-input-container{display:flex;gap:.5rem;padding:1rem 1.5rem;background:#ffffff26;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid rgba(255,255,255,.2);box-shadow:0 -2px 20px #1f268733;position:relative;z-index:100;flex-shrink:0;flex-grow:0;min-height:fit-content;width:100%;box-sizing:border-box;order:3}.chatbot-input{flex:1;padding:.75rem 1rem;background:#ffffff40;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:24px;font-size:1rem;font-family:inherit;color:#fffffff2;outline:none;transition:all .3s ease;box-shadow:inset 0 1px 2px #fff3,0 2px 8px #0000001a;resize:none;overflow-y:auto;max-height:150px;min-height:48px;line-height:1.5;box-sizing:border-box}.chatbot-input::-webkit-scrollbar{width:6px}.chatbot-input::-webkit-scrollbar-track{background:transparent}.chatbot-input::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:3px}.chatbot-input::-webkit-scrollbar-thumb:hover{background:#ffffff80}.chatbot-input::placeholder{color:#fff9}.chatbot-input:focus{border-color:#ffffff80;background:#ffffff59;box-shadow:inset 0 1px 2px #ffffff4d,0 4px 12px #667eea4d}.chatbot-input:disabled{background:#ffffff1a;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);cursor:not-allowed;opacity:.6}.chatbot-send-button{width:56px;height:56px;min-width:56px;min-height:56px;border-radius:50%;background:#ffffff4d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;border:1px solid rgba(255,255,255,.4);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0;box-shadow:0 4px 16px #1f26874d,inset 0 1px #fff6}.chatbot-send-button svg{width:18px;height:18px;min-width:18px;min-height:18px}.chatbot-send-button:hover:not(:disabled){transform:translateY(-2px);background:#fff6;box-shadow:0 8px 24px #1f268766,inset 0 1px #ffffff80;border-color:#ffffff80}.chatbot-send-button:active:not(:disabled){transform:translateY(0)}.chatbot-send-button:disabled{opacity:.5;cursor:not-allowed}.chatbot-voice-button{width:56px;height:56px;min-width:56px;min-height:56px;border-radius:50%;background:#ffffff40;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fffffff2;border:1px solid rgba(255,255,255,.3);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;flex-shrink:0;box-shadow:0 4px 16px #1f268733,inset 0 1px #fff3}.chatbot-voice-button svg{width:18px;height:18px;min-width:18px;min-height:18px}.chatbot-voice-button:hover:not(:disabled){background:#ffffff59;color:#fff;border-color:#ffffff80;transform:translateY(-2px);box-shadow:0 8px 24px #1f26874d,inset 0 1px #ffffff4d}.chatbot-voice-button:active:not(:disabled){transform:translateY(0)}.chatbot-voice-button:disabled{opacity:.5;cursor:not-allowed}.chatbot-voice-button.recording{background:#dc354566;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;border-color:#dc354580;animation:pulse 1.5s infinite;box-shadow:0 4px 16px #dc35454d,inset 0 1px #fff3}.chatbot-voice-button.unavailable{opacity:.4;cursor:not-allowed;background:#f5f5f5;color:#999}.chatbot-voice-button.unavailable:hover{background:#f5f5f5;color:#999;transform:none;box-shadow:none}@keyframes pulse{0%,to{box-shadow:0 0 #dc3545b3}50%{box-shadow:0 0 0 10px #dc354500}}.transcription-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.transcription-modal{background:#ffffff40;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:20px;padding:1.5rem;max-width:500px;width:90%;border:1px solid rgba(255,255,255,.18);box-shadow:0 8px 32px #1f26875e,inset 0 1px #ffffff4d;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.transcription-modal h3{margin:0 0 1rem;color:#fffffff2;font-size:1.25rem;text-shadow:0 2px 10px rgba(0,0,0,.1)}.transcription-textarea{width:100%;padding:.75rem;background:#fff3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:12px;font-size:1rem;font-family:inherit;resize:vertical;min-height:100px;margin-bottom:1rem;outline:none;transition:all .3s ease;box-sizing:border-box;color:#fffffff2;box-shadow:inset 0 1px 2px #fff3,0 2px 8px #0000001a}.transcription-textarea::placeholder{color:#fff9}.transcription-textarea:focus{border-color:#ffffff80;background:#ffffff4d;box-shadow:inset 0 1px 2px #ffffff4d,0 4px 12px #667eea4d}.transcription-modal-buttons{display:flex;gap:.75rem;justify-content:flex-end}.transcription-button{padding:.5rem 1rem;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.transcription-button.cancel{background:#fff3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#ffffffe6;border:1px solid rgba(255,255,255,.3);box-shadow:0 2px 8px #1f268733,inset 0 1px #fff3}.transcription-button.cancel:hover{background:#ffffff4d;border-color:#fff6;box-shadow:0 4px 12px #1f26874d,inset 0 1px #ffffff4d}.transcription-button.confirm{background:#ffffff4d;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;border:1px solid rgba(255,255,255,.4);box-shadow:0 4px 16px #1f26874d,inset 0 1px #fff6;text-shadow:0 1px 2px rgba(0,0,0,.1)}.transcription-button.confirm:hover:not(:disabled){transform:translateY(-2px);background:#fff6;box-shadow:0 8px 24px #1f268766,inset 0 1px #ffffff80;border-color:#ffffff80}.transcription-button.confirm:disabled{opacity:.5;cursor:not-allowed}@media(prefers-color-scheme:dark){.chatbot-container,.chatbot-messages{background:#1a1a1a}.chatbot-welcome{color:#fff9}.message.bot .message-content{background:#2a2a2a;color:#ffffffde;border-color:#444}.message.typing .message-content,.message.loading .message-content{background:#2a2a2a;border-color:#444}.chatbot-input-container{background:#1a1a1a;border-top-color:#444}.chatbot-input{background:#2a2a2a;border-color:#444;color:#ffffffde}.chatbot-input:focus{border-color:#667eea}.chatbot-input:disabled{background:#1a1a1a}.chatbot-voice-button{background:#2a2a2a;border-color:#444;color:#667eea}.chatbot-voice-button:hover:not(:disabled){background:#667eea;color:#fff}.transcription-modal{background:#1a1a1a;color:#ffffffde}.transcription-modal h3{color:#ffffffde}.transcription-textarea{background:#2a2a2a;border-color:#444;color:#ffffffde}.transcription-textarea:focus{border-color:#667eea}.transcription-button.cancel{background:#2a2a2a;color:#ffffffb3}.transcription-button.cancel:hover{background:#333}}@media(max-width:768px){.chatbot-container{height:100vh;height:100dvh;position:fixed;inset:0}.chatbot-header{padding:.75rem 1rem;position:sticky;top:0;z-index:100;flex-shrink:0}.chatbot-header h2{font-size:1.25rem}.chatbot-messages{padding:1rem;flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.message-content{max-width:85%;padding:.625rem .875rem;font-size:.95rem}.message-content p{font-size:.95rem;line-height:1.4}.chatbot-input-container{padding:.75rem 1rem;position:sticky;bottom:0;z-index:100;background:#ffffff26;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);flex-shrink:0;margin-top:auto}.chatbot-input{font-size:16px;padding:.625rem .875rem;max-height:120px;min-height:44px}.chatbot-voice-button,.chatbot-send-button{width:56px;height:56px;min-width:56px;min-height:56px}.chatbot-voice-button svg,.chatbot-send-button svg{width:18px;height:18px;min-width:18px;min-height:18px}.chatbot-welcome{padding:1.5rem 1rem;font-size:1rem}.transcription-modal{width:95%;max-width:95%;padding:1.25rem;margin:1rem}.transcription-modal h3{font-size:1.1rem}.transcription-textarea{font-size:16px;min-height:80px}.transcription-modal-buttons{flex-direction:column;gap:.5rem}.transcription-button{width:100%}}@media(max-width:480px){.chatbot-header{padding:.625rem .875rem}.chatbot-header h2{font-size:1.1rem}.chatbot-messages{padding:.75rem}.message-content{max-width:90%;padding:.5rem .75rem;font-size:.9rem}.message-time{font-size:.7rem}.chatbot-input-container{padding:.625rem .875rem;gap:.375rem}.chatbot-input{padding:.5rem .75rem;font-size:16px;max-height:120px;min-height:44px}.chatbot-voice-button,.chatbot-send-button{width:56px;height:56px;min-width:56px;min-height:56px}.chatbot-voice-button svg,.chatbot-send-button svg{width:18px;height:18px;min-width:18px;min-height:18px}.chatbot-welcome{padding:1rem;font-size:.95rem}.transcription-modal{width:100%;max-width:100%;border-radius:12px 12px 0 0;margin:0;padding:1rem}}.dashboard-container{display:flex;flex-direction:column;height:100vh;height:100dvh;width:100%;position:relative;overflow:hidden;box-sizing:border-box;margin:0;padding:0}.signout-button{position:absolute;top:1rem;right:1rem;padding:.5rem 1rem;background:#dc35454d;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:#fff;border:1px solid rgba(220,53,69,.4);border-radius:12px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;z-index:200;box-shadow:0 4px 16px #dc35454d,inset 0 1px #fff3;text-shadow:0 1px 2px rgba(0,0,0,.1)}.signout-button:hover{background:#dc354566;transform:translateY(-2px);border-color:#dc354580;box-shadow:0 8px 24px #dc354566,inset 0 1px #ffffff4d}.signout-button:active:not(:disabled){transform:translateY(0)}.signout-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.signout-button:disabled:hover{background:#dc3545;transform:none;box-shadow:0 2px 8px #00000026}@media(max-width:768px){.dashboard-container{height:100vh;height:100dvh;position:fixed;inset:0}.signout-button{top:.5rem;right:.5rem;padding:.4rem .75rem;font-size:.8rem;z-index:1000}}@media(max-width:480px){.signout-button{top:.375rem;right:.375rem;padding:.35rem .625rem;font-size:.75rem}}.notification-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px;width:100%;pointer-events:none}.notification{background:#fff3;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-radius:16px;padding:16px;border:1px solid rgba(255,255,255,.3);box-shadow:0 8px 32px #1f26875e,inset 0 1px #fff6;pointer-events:all;animation:slideInRight .3s ease-out;overflow:hidden;position:relative}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.notification-content{display:flex;align-items:flex-start;gap:12px;position:relative;z-index:1}.notification-icon{font-size:20px;flex-shrink:0;line-height:1}.notification-text{flex:1;min-width:0}.notification-title{font-weight:600;font-size:.95rem;margin-bottom:4px;color:#fffffff2;text-shadow:0 1px 2px rgba(0,0,0,.1)}.notification-message{font-size:.875rem;line-height:1.4;color:#ffffffe6;text-shadow:0 1px 2px rgba(0,0,0,.1)}.notification-close{background:none;border:none;color:#fffc;font-size:24px;line-height:1;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease;flex-shrink:0}.notification-close:hover{color:#fff;background:#ffffff1a}.notification-close:active{transform:scale(.9)}.notification-progress-container{position:absolute;bottom:0;left:0;right:0;height:3px;background:#ffffff1a;border-radius:0 0 16px 16px;overflow:hidden}.notification-progress-bar{height:100%;background:#fff9;transition:width .05s linear;border-radius:0 0 16px 16px;box-shadow:0 0 10px #ffffff4d}.notification-success{background:#28a74533;border-color:#28a74566;box-shadow:0 8px 32px #28a74533,inset 0 1px #fff6}.notification-success .notification-progress-bar{background:#28a745cc}.notification-error{background:#dc354533;border-color:#dc354566;box-shadow:0 8px 32px #dc354533,inset 0 1px #fff6}.notification-error .notification-progress-bar{background:#dc3545cc}.notification-warning{background:#ffc10733;border-color:#ffc10766;box-shadow:0 8px 32px #ffc10733,inset 0 1px #fff6}.notification-warning .notification-progress-bar{background:#ffc107cc}.notification-info{background:#17a2b833;border-color:#17a2b866;box-shadow:0 8px 32px #17a2b833,inset 0 1px #fff6}.notification-info .notification-progress-bar{background:#17a2b8cc}@media(max-width:768px){.notification-container{top:10px;right:10px;left:10px;max-width:none}.notification{padding:14px;border-radius:12px}.notification-title{font-size:.9rem}.notification-message{font-size:.85rem}.notification-icon{font-size:18px}}#root{width:100%;height:100%;margin:0;padding:0}.error-container{width:100%;min-height:100vh;min-height:100dvh;display:flex;justify-content:center;align-items:center;padding:20px;background-color:#f5f5f5;box-sizing:border-box}.error-card{width:100%;max-width:600px;padding:30px;background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;box-sizing:border-box}.error-title{color:#d32f2f;margin-top:0;font-size:1.5rem}.error-text{font-size:1rem;margin:.75rem 0}.error-code{background-color:#f5f5f5;padding:15px;border-radius:4px;overflow:auto;margin:10px 0;font-size:.875rem}.error-footer{margin-bottom:0;font-size:14px;color:#666}@media(max-width:768px){#root{width:100%;height:100%;padding:0}.error-container{padding:10px}.error-card{padding:20px;border-radius:0}.error-title{font-size:1.25rem}.error-text{font-size:.9rem}.error-code{font-size:.75rem;padding:10px}.error-footer{font-size:.8rem}}@media(max-width:480px){.error-container{padding:0}.error-card{padding:1.5rem 1rem;border-radius:0}.error-title{font-size:1.1rem}.error-text{font-size:.85rem}.error-code{font-size:.7rem;padding:8px}.error-footer{font-size:.75rem}}.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}
