.message-list{flex:1;padding:20px;display:flex;flex-direction:column;gap:15px;overflow-y:auto;scroll-behavior:smooth;position:relative}.welcome-message{text-align:center;max-width:600px;margin:auto;padding:var(--space-xl);background-color:var(--light-color);border-radius:8px}.welcome-message h2{color:var(--primary-color);margin-bottom:var(--space-sm)}.welcome-message ul{text-align:left;margin-top:var(--space-md);padding-left:1.5rem}.welcome-message li{margin-bottom:var(--space-sm);font-style:italic}.message{max-width:80%;padding:12px 16px;border-radius:12px;position:relative}.user-message{align-self:flex-end;background-color:#722f37;color:#fff;border-bottom-right-radius:4px}.assistant-message{align-self:flex-start;background-color:#f0f0f0;color:#333;border-bottom-left-radius:4px}.message-content{margin-bottom:4px;line-height:1.5}.message-timestamp{font-size:.75em;opacity:.7;text-align:right}.streaming-content{position:relative;white-space:pre-wrap;word-wrap:break-word}.streaming-cursor{display:inline-block;background-color:var(--primary-color);width:2px;height:1.2em;margin-left:2px;animation:cursor-blink 1s infinite;vertical-align:baseline}@keyframes cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}.thinking-bubble{padding:.75rem 1rem;min-width:60px;background-color:#f0f0f0;display:flex;align-items:center;justify-content:center}.thinking-dots{display:flex;align-items:center;gap:4px}.thinking-dots span{display:inline-block;width:8px;height:8px;border-radius:50%;background-color:#722f37;opacity:.7;animation:thinking-animation 1.4s infinite}.thinking-dots span:nth-child(1){animation-delay:0s}.thinking-dots span:nth-child(2){animation-delay:.2s}.thinking-dots span:nth-child(3){animation-delay:.4s}@keyframes thinking-animation{0%,to{transform:translateY(0);opacity:.7}50%{transform:translateY(-5px);opacity:1}}.markdown-content{line-height:1.6}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{margin-top:1rem;margin-bottom:.5rem;font-weight:600}.markdown-content h1{font-size:1.5rem}.markdown-content h2{font-size:1.3rem}.markdown-content h3{font-size:1.2rem}.markdown-content p{margin-bottom:.75rem}.markdown-content ul,.markdown-content ol{padding-left:1.5rem;margin-bottom:.75rem}.markdown-content li{margin-bottom:.25rem}.markdown-content code{background-color:#0000000d;border-radius:3px;padding:.2em .4em;font-family:monospace;font-size:.85em;word-break:break-all}.markdown-content pre{background-color:#0000000d;border-radius:3px;padding:.75rem;overflow-x:auto;margin-bottom:.75rem;max-width:100%}.markdown-content pre code{font-size:.85em;padding:0;background-color:transparent}.markdown-content blockquote{border-left:4px solid var(--primary-color);padding-left:1rem;margin-left:0;margin-right:0;font-style:italic}.markdown-content a{color:var(--accent-color);text-decoration:underline;word-break:break-all}.markdown-content img{max-width:100%;height:auto;margin:.5rem 0;display:block}.markdown-content table{border-collapse:collapse;width:100%;margin-bottom:1rem;font-size:.9em;overflow-x:auto;display:block}.markdown-content th,.markdown-content td{border:1px solid #ccc;padding:.5rem;text-align:left}.markdown-content th{background-color:#0000000d}.markdown-content p:last-child{margin-bottom:0}@media(max-width:480px){.message-list{padding:var(--space-sm);gap:var(--space-sm)}.welcome-message{padding:var(--space-lg)}.message-bubble{max-width:90%;padding:.5rem .75rem}.thinking-bubble{padding:.5rem .75rem;background-color:#f0f0f0;min-width:50px}.thinking-dots span{width:6px;height:6px}.markdown-content img{max-width:100%;height:auto}.markdown-content pre{padding:.5rem}.markdown-content h1{font-size:1.3rem}.markdown-content h2{font-size:1.2rem}.markdown-content h3{font-size:1.1rem}}@media(max-height:480px)and (orientation:landscape){.message-list{padding:var(--space-xs) var(--space-sm)}.welcome-message{padding:var(--space-md)}.welcome-message h2{margin-bottom:var(--space-sm)}}.message-input{display:flex;gap:10px;padding:20px;background-color:#fff;border-top:1px solid #e0e0e0}.message-input input{flex:1;padding:12px;border:1px solid #e0e0e0;border-radius:4px;font-size:1em}.message-input input:focus{outline:none;border-color:#722f37}.message-input button{padding:12px 24px;background-color:#722f37;color:#fff;border:none;border-radius:4px;font-size:1em;cursor:pointer;transition:background-color .2s ease}.message-input button:hover:not(:disabled){background-color:#5a252c}.message-input button:disabled{background-color:#ccc;cursor:not-allowed}.message-input .share-button{background-color:#3a7a9f}.message-input .share-button:hover:not(:disabled){background-color:#2a6080}@media(max-width:480px){.message-input{padding:var(--space-sm)}.message-input input{padding:.5rem .75rem;font-size:var(--font-size-base);min-height:40px}.message-input button{min-width:60px;padding:0 .75rem;height:40px}.message-input .share-button{padding:0 .5rem}}@media(max-height:480px)and (orientation:landscape){.message-input{padding:var(--space-xs) var(--space-sm)}.message-input input{min-height:36px;max-height:80px}.message-input button{height:36px}}.example-questions{margin-bottom:15px}.example-questions h3{color:#722f37;margin-bottom:10px;font-size:1em}.questions-list{display:flex;flex-wrap:wrap;gap:8px}.example-question{background-color:#f9f7f3;border:1px solid #e0e0e0;border-radius:16px;padding:6px 12px;font-size:.9em;color:#333;cursor:pointer;transition:all .2s ease;white-space:nowrap}.example-question:hover{background-color:#722f37;color:#fff;border-color:#722f37;transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.example-question:active{transform:translateY(0);box-shadow:none}@media(max-width:480px){.example-questions{margin-bottom:10px}.example-question{padding:4px 10px;font-size:.85em}}.snackbar-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.snackbar{pointer-events:auto;min-width:300px;max-width:500px;border-radius:8px;box-shadow:0 4px 20px #00000026;animation:snackbar-enter .3s ease-out;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.snackbar-content{display:flex;align-items:center;padding:12px 16px;gap:12px}.snackbar-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.snackbar-message{flex:1;font-size:14px;font-weight:500;line-height:1.4}.snackbar-close{flex-shrink:0;background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .2s ease}.snackbar-close:hover{opacity:1}.snackbar-success{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.snackbar-success .snackbar-close:hover{background:#ffffff1a}.snackbar-error{background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff}.snackbar-error .snackbar-close:hover{background:#ffffff1a}.snackbar-warning{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.snackbar-warning .snackbar-close:hover{background:#ffffff1a}.snackbar-info{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff}.snackbar-info .snackbar-close:hover{background:#ffffff1a}@keyframes snackbar-enter{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes snackbar-exit{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@media(max-width:600px){.snackbar-container{top:10px;right:10px;left:10px}.snackbar{min-width:auto;max-width:none}.snackbar-content{padding:10px 12px}.snackbar-message{font-size:13px}}@media(prefers-color-scheme:dark){.snackbar{box-shadow:0 4px 20px #0000004d}}@media(prefers-contrast:high){.snackbar{border:2px solid currentColor}}@media(prefers-reduced-motion:reduce){.snackbar{animation:none}@keyframes snackbar-enter{0%,to{opacity:1;transform:translate(0)}}}.bottom-banner{position:fixed;bottom:0;left:0;right:0;z-index:1000;animation:bottom-banner-enter .3s ease-out}.bottom-banner-content{display:flex;align-items:center;padding:12px 16px;gap:12px;min-height:48px}.bottom-banner-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.bottom-banner-message{flex:1;font-size:14px;font-weight:500;line-height:1.4;text-align:center}.bottom-banner-close{flex-shrink:0;background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;opacity:.8;transition:opacity .2s ease}.bottom-banner-close:hover{opacity:1}.bottom-banner-error{background:linear-gradient(135deg,#f44336,#d32f2f);color:#fff}.bottom-banner-error .bottom-banner-close:hover{background:#ffffff1a}.bottom-banner-warning{background:linear-gradient(135deg,#ff9800,#f57c00);color:#fff}.bottom-banner-warning .bottom-banner-close:hover{background:#ffffff1a}.bottom-banner-info{background:linear-gradient(135deg,#2196f3,#1976d2);color:#fff}.bottom-banner-info .bottom-banner-close:hover{background:#ffffff1a}.bottom-banner-success{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.bottom-banner-success .bottom-banner-close:hover{background:#ffffff1a}.bottom-banner-message.html-content{line-height:1.5}.bottom-banner-message.html-content p{margin:.25em 0}.bottom-banner-message.html-content a{color:inherit;text-decoration:underline;font-weight:600}.bottom-banner-message.html-content a:hover{opacity:.8}.bottom-banner-message.html-content strong{font-weight:700}.bottom-banner-message.html-content em{font-style:italic}.bottom-banner-message.html-content br{line-height:1.5}@keyframes bottom-banner-enter{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes bottom-banner-exit{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(100%)}}@media(max-width:600px){.bottom-banner-content{padding:10px 12px;gap:8px}.bottom-banner-message{font-size:13px}}@media(prefers-color-scheme:dark){.bottom-banner{box-shadow:0 -2px 10px #0000004d}}@media(prefers-contrast:high){.bottom-banner{border-top:2px solid currentColor}}@media(prefers-reduced-motion:reduce){.bottom-banner{animation:none}@keyframes bottom-banner-enter{0%,to{opacity:1;transform:translateY(0)}}}.chat-interface{display:flex;flex-direction:column;width:100%;max-width:900px;margin:0 auto;height:100%;background-color:#f9f7f3;border-radius:8px;box-shadow:0 2px 10px #0000001a;overflow:hidden;position:relative}.chat-content{flex:1;display:flex;flex-direction:column;padding:0;scroll-behavior:smooth;overflow-y:auto}.chat-input-section{background-color:#fff;border-top:1px solid #e0e0e0;padding:20px;position:sticky;bottom:0;z-index:10}.connection-status{position:absolute;top:0;left:0;right:0;padding:8px;background-color:#fc0;color:#333;text-align:center;font-size:14px;z-index:100}.connection-status a{color:#722f37;text-decoration:underline;font-weight:500}.connection-status a:hover{color:#5a252c}.error-message{margin:10px 0;padding:10px;background-color:#ffebee;color:#d32f2f;border-radius:4px;font-size:14px}.error-message.html-content{line-height:1.5}.error-message.html-content p{margin:.5em 0}.error-message.html-content a{color:#d32f2f;text-decoration:underline}.error-message.html-content a:hover{color:#b71c1c}.error-message.html-content strong{font-weight:700}.error-message.html-content em{font-style:italic}.error-message.html-content ul,.error-message.html-content ol{margin:.5em 0;padding-left:1.5em}.error-message.html-content li{margin:.25em 0}.error-message.html-content br{line-height:1.5}@media(max-width:900px){.chat-interface{border-radius:0;box-shadow:none;height:100%}}@media(max-width:480px){.chat-interface{width:100%;height:100%;margin:0}.chat-input-section{padding:10px}}@media(max-height:480px)and (orientation:landscape){.chat-interface{height:100%}.chat-input-section{padding:8px}}.token-form{max-width:500px;margin:2rem auto;padding:2rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a}.token-form h2{color:var(--primary-color);margin-bottom:1rem;text-align:center}.token-form p{margin-bottom:1.5rem;text-align:center;color:var(--text-color)}.token-form .form-group{margin-bottom:1.5rem}.token-form label{display:block;margin-bottom:.5rem;font-weight:500}.token-form input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.token-form input:focus{border-color:var(--accent-color);outline:none}.token-form button{width:100%;padding:.75rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s}.token-form button:hover{background-color:var(--secondary-color)}.token-form button:disabled{background-color:#ccc;cursor:not-allowed}.token-form .error-message{color:#d32f2f;margin-bottom:1rem;padding:.5rem;background-color:#ffebee;border-radius:4px;text-align:center}@media(max-width:600px){.token-form{padding:1.5rem;margin:1rem;width:calc(100% - 2rem)}}.token-form .token-display{margin:1.5rem 0;padding:1rem;background-color:#f9f7f3;border-radius:8px;border:1px dashed #ccc;text-align:center}.token-form .token{font-size:28px;font-weight:700;letter-spacing:3px;color:#722f37;margin:1rem 0;padding:.5rem}.token-form .token-warning{color:#e53935;font-weight:700;margin-top:1rem;font-size:.9rem}.scroll-to-bottom-button-container{position:relative}.scroll-to-bottom-button{position:absolute;bottom:10px;right:20px;width:48px;height:48px;background-color:#722f37;color:#fff;border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #0003;transition:all .2s ease;z-index:10}.scroll-to-bottom-button:hover{background-color:#5a252c;transform:translateY(-2px);box-shadow:0 4px 12px #00000040}.scroll-to-bottom-button:active{transform:translateY(0);box-shadow:0 2px 8px #0003}.scroll-to-bottom-button svg{pointer-events:none}@media(max-width:480px){.scroll-to-bottom-button{width:44px;height:44px;bottom:40px;right:15px}.scroll-to-bottom-button svg{width:18px;height:18px}}@media(max-height:480px)and (orientation:landscape){.scroll-to-bottom-button{bottom:80px}}.user-profile{position:relative;display:flex;align-items:center}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;text-transform:uppercase;cursor:pointer;transition:all .2s ease;border:2px solid rgba(255,255,255,.2)}.user-avatar:hover{transform:scale(1.05);border-color:#fff6;box-shadow:0 2px 8px #00000026}.user-menu{position:absolute;top:100%;right:0;margin-top:8px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;min-width:240px;z-index:1000;animation:slideDown .2s ease-out;border:1px solid rgba(0,0,0,.1)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.menu-header{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid rgba(0,0,0,.05)}.menu-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;text-transform:uppercase;flex-shrink:0}.menu-user-info{display:flex;flex-direction:column;gap:4px;min-width:0}.menu-user-name{font-weight:600;color:#333;font-size:14px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-user-email{color:#666;font-size:12px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.menu-user-role{background:var(--accent-color);color:#fff;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600;text-transform:uppercase;align-self:flex-start;margin-top:2px}.menu-divider{height:1px;background:#0000000d;margin:0}.menu-logout-button{width:100%;padding:12px 16px;background:none;color:var(--accent-color);border:none;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease;text-align:left;border-radius:0 0 12px 12px}.menu-logout-button:hover:not(:disabled){background:#a4243b1a}.menu-logout-button:disabled{opacity:.7;cursor:not-allowed}.menu-admin-button{width:100%;padding:12px 16px;background:none;color:#2c3e50;border:none;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease;text-align:left}.menu-admin-button:hover{background:#2c3e501a}@media(max-width:768px){.user-menu{right:-10px;min-width:220px}.menu-header{padding:12px}.menu-avatar{width:40px;height:40px;font-size:16px}.menu-user-name{font-size:13px}.menu-user-email{font-size:11px}}.session-list-sidebar{width:280px;height:100%;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;box-shadow:2px 0 4px #0000001a;transition:transform .3s ease;position:relative}.session-list-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #e0e0e0;background:#f8f9fa}.session-list-header-actions{display:flex;align-items:center;gap:8px}.session-list-header h3{margin:0;font-size:16px;font-weight:600;color:#333}.hide-button{background:none;border:none;font-size:20px;color:#666;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s}.new-conversation-button{background:none;border:none;color:#666;cursor:pointer;padding:6px 8px;border-radius:4px;transition:all .2s ease;display:flex;align-items:center;gap:4px;font-size:12px;font-weight:500;text-decoration:none}.new-conversation-button:hover{background-color:#e9ecef;color:#333}.new-conversation-text{display:none}.hide-button:hover{background-color:#e9ecef;color:#333}.session-list-content{flex:1;overflow-y:auto;padding:8px}.session-list-loading,.session-list-error,.session-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;color:#666;text-align:center}.session-list-error{color:#dc3545}.retry-button{background:#007bff;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;margin-top:8px;font-size:14px}.retry-button:hover{background:#0056b3}.new-chat-button{background:var(--primary-color);color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;margin-top:12px;font-size:14px;font-weight:500;text-decoration:none;display:inline-block}.new-chat-button:hover{background:var(--secondary-color)}.sessions-container{display:flex;flex-direction:column;gap:4px}.session-item{padding:12px;border-radius:8px;cursor:pointer;transition:all .2s ease;border:1px solid transparent;display:flex;align-items:center;justify-content:space-between;gap:8px}.session-content{flex:1;min-width:0}.session-item:hover{background-color:#f8f9fa;border-color:#e9ecef}.session-item.active{background-color:#e3f2fd;border-color:#2196f3}.session-title{font-weight:500;color:#333;margin-bottom:4px;line-height:1.3}.session-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:#666}.session-date{color:#888}.session-count{background:#f0f0f0;padding:2px 6px;border-radius:10px;font-size:11px}.session-delete-button{background:none;border:none;color:#999;cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease;opacity:0;display:flex;align-items:center;justify-content:center}.session-delete-button:hover{background-color:#ffebee;color:#d32f2f;opacity:1}.session-item:hover .session-delete-button{opacity:.7}.session-item:hover .session-delete-button:hover{opacity:1}@media(min-width:1024px){.new-conversation-text{display:inline}.new-conversation-button{padding:6px 12px}}@media(max-width:768px){.session-list-sidebar{position:fixed;top:0;left:0;z-index:1000;height:100vh;transform:translate(-100%)}.session-list-sidebar.visible{transform:translate(0)}.session-list-header{padding:12px}.session-list-header h3{font-size:14px}.session-item{padding:10px}.session-title{font-size:14px}.session-meta{font-size:11px}}@media(max-width:480px){.session-list-sidebar{width:260px}.session-list-header{padding:10px}.session-item{padding:8px}.session-delete-button{opacity:.7}}.app-main-container{flex:1;display:flex;overflow:hidden}.app-content{flex:1;display:flex;padding:var(--space-md);overflow:hidden;transition:margin-left .3s ease}.app-content.with-sidebar{margin-left:0}@media(min-width:769px){.session-list-sidebar{transform:translate(0)}.session-list-sidebar:not(.visible){transform:translate(-100%)}}.sidebar-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:999}.hamburger-button{display:none;flex-direction:column;background:none;border:none;cursor:pointer;padding:4px;margin-right:12px}.hamburger-button span{width:20px;height:2px;background-color:#fff;margin:2px 0;transition:.3s}@media(max-width:768px){.hamburger-button{display:flex}.app-content{padding:var(--space-sm)}}.show-sidebar-button{position:fixed;left:0;top:10%;background:var(--primary-color);color:#fff;border:none;border-radius:0 8px 8px 0;padding:12px 8px;cursor:pointer;font-size:18px;box-shadow:2px 0 4px #0000001a;z-index:100;transition:all .2s ease}.show-sidebar-button:hover{background:#0056b3;padding-left:12px}.show-sidebar-button span{display:block;transform:rotate(0);transition:transform .2s ease}@media(max-width:480px){.app-content{padding:var(--space-sm)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);padding:20px}.login-container{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;padding:40px;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:30px}.login-header h1{margin:0 0 10px;color:#333;font-size:28px;font-weight:600}.login-header p{margin:0;color:#666;font-size:16px}.login-form{margin-bottom:30px}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #722f3766}.login-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-footer{text-align:center;color:#666;font-size:14px}.login-footer p{margin:8px 0}.login-footer a{color:var(--primary-color);text-decoration:none;font-weight:500}.login-footer a:hover{text-decoration:underline}@media(max-width:480px){.login-container{padding:30px 20px}.login-header h1{font-size:24px}}.signup-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);padding:20px}.signup-container{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;padding:40px;width:100%;max-width:450px}.signup-header{text-align:center;margin-bottom:30px}.signup-header h1{margin:0 0 10px;color:#333;font-size:28px;font-weight:600}.signup-header p{margin:0;color:#666;font-size:16px}.signup-form{margin-bottom:30px}.signup-button{width:100%;padding:14px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.signup-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #722f3766}.signup-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.signup-footer{text-align:center;color:#666;font-size:14px}.signup-footer p{margin:8px 0}.signup-footer a{color:var(--primary-color);text-decoration:none;font-weight:500}.signup-footer a:hover{text-decoration:underline}@media(max-width:480px){.signup-container{padding:30px 20px}.signup-header h1{font-size:24px}}.invitation-request-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);padding:20px}.invitation-request-container{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0000001a;padding:40px;width:100%;max-width:450px}.invitation-request-header{text-align:center;margin-bottom:30px}.invitation-request-header h1{margin:0 0 10px;color:#333;font-size:28px;font-weight:600}.invitation-request-header p{margin:0;color:#666;font-size:16px}.invitation-request-form{margin-bottom:30px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .3s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:var(--primary-color)}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.request-button{width:100%;padding:14px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.request-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 5px 15px #722f3766}.request-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.error-message{background-color:#fee;color:#c33;padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px;border:1px solid #fcc}.success-message{background-color:#efe;color:#363;padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px;border:1px solid #cfc}.invitation-result{margin-bottom:30px}.invitation-code-display{text-align:center;margin-bottom:30px}.invitation-code-display h3{margin:0 0 20px;color:#333;font-size:20px;font-weight:600}.code{background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);color:#fff;padding:20px;border-radius:8px;font-size:24px;font-weight:700;font-family:Courier New,monospace;letter-spacing:2px;margin-bottom:15px;box-shadow:0 4px 15px #722f374d}.code-warning{color:#c33;font-size:14px;font-weight:500;margin:0}.invitation-actions{display:flex;gap:15px;justify-content:center}.copy-button{padding:12px 24px;background:var(--accent-color);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background-color .2s ease}.copy-button:hover{background:var(--primary-color)}.signup-link{padding:12px 24px;background:linear-gradient(135deg,var(--primary-color) 0%,var(--accent-color) 100%);color:#fff;text-decoration:none;border-radius:6px;font-size:14px;font-weight:600;transition:transform .2s ease,box-shadow .2s ease}.signup-link:hover{transform:translateY(-2px);box-shadow:0 5px 15px #722f3766}.invitation-request-footer{text-align:center;color:#666;font-size:14px}.invitation-request-footer p{margin:8px 0}.invitation-request-footer a{color:var(--primary-color);text-decoration:none;font-weight:500}.invitation-request-footer a:hover{text-decoration:underline}@media(max-width:480px){.invitation-request-container{padding:30px 20px}.invitation-request-header h1{font-size:24px}.code{font-size:20px;padding:15px}.invitation-actions{flex-direction:column}}.session-management{padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.session-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #e0e0e0}.session-header h3{margin:0;color:#333;font-size:18px}.header-actions{display:flex;gap:10px;align-items:center}.batch-delete-button{background:#f44336;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s}.batch-delete-button:hover:not(:disabled){background:#d32f2f}.batch-delete-button:disabled{background:#ccc;cursor:not-allowed}.session-list{overflow-x:auto;border-radius:4px;border:1px solid #e0e0e0}.session-table{width:100%;border-collapse:collapse;font-size:14px;min-width:800px}.session-table th,.session-table td{padding:12px 8px;text-align:left;border-bottom:1px solid #e0e0e0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-table th{background:#f5f5f5;font-weight:600;color:#333;position:sticky;top:0;z-index:10}.session-table tr:hover{background:#f9f9f9}.checkbox-column{width:40px;text-align:center}.session-id-column{width:180px;max-width:180px}.user-id-column{width:120px;max-width:120px}.title-column{width:200px;max-width:200px}.message-count-column{width:80px;text-align:center}.action-column{width:80px;text-align:center}.session-table input[type=checkbox]{width:16px;height:16px;cursor:pointer}.session-table code{background:#f0f0f0;padding:2px 4px;border-radius:3px;font-family:Courier New,monospace;font-size:12px;color:#333}.session-id-column{white-space:normal;word-break:break-all;overflow-wrap:break-word}.session-id-column code{white-space:normal;word-break:break-all;overflow-wrap:break-word;display:inline-block;max-width:100%}.message-count{font-weight:600;color:#2196f3}.delete-button{background:#f44336;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:12px;transition:background-color .3s}.delete-button:hover:not(:disabled){background:#d32f2f}.delete-button:disabled{background:#ccc;cursor:not-allowed}.loading,.error,.no-sessions{text-align:center;padding:40px;color:#666}@media(max-width:768px){.session-management{padding:10px}.session-header{flex-direction:column;gap:10px;align-items:flex-start}.header-actions{width:100%;justify-content:space-between}.session-table{font-size:12px;min-width:600px}.session-table th,.session-table td{padding:8px 4px}.session-id-column{width:120px;max-width:120px}.user-id-column{width:80px;max-width:80px}.title-column{width:120px;max-width:120px}.date-column{width:100px;max-width:100px}}.user-management{padding:20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.user-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #e0e0e0}.user-header h3{margin:0;color:#333;font-size:18px}.refresh-button{background:#4caf50;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .3s}.refresh-button:hover{background:#45a049}.user-list{overflow-x:auto;border-radius:4px;border:1px solid #e0e0e0;margin-bottom:20px}.user-table{width:100%;border-collapse:collapse;font-size:14px;min-width:900px}.user-table th,.user-table td{padding:12px 8px;text-align:left;border-bottom:1px solid #e0e0e0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-table th{background:#f5f5f5;font-weight:600;color:#333;position:sticky;top:0;z-index:10}.user-table tr:hover{background:#f9f9f9}.user-id-column,.username-column{width:150px;max-width:150px}.email-column{width:180px;max-width:180px}.name-column{width:120px;max-width:120px}.role-column,.status-column{width:80px;text-align:center}.date-column{width:140px;max-width:140px}.user-table code{background:#f0f0f0;padding:2px 4px;border-radius:3px;font-family:Courier New,monospace;font-size:12px;color:#333}.user-id-column{white-space:normal;word-break:break-all;overflow-wrap:break-word}.user-id-column code{white-space:normal;word-break:break-all;overflow-wrap:break-word;display:inline-block;max-width:100%}.status-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:uppercase}.status-badge.active{background:#e8f5e8;color:#2e7d32}.status-badge.inactive{background:#ffebee;color:#c62828}.role-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.role-badge.admin{background:#e3f2fd;color:#1565c0}.role-badge.user{background:#f3e5f5;color:#7b1fa2}.loading,.error,.no-users{text-align:center;padding:40px;color:#666}.error{color:#f44336}.retry-button{background:#2196f3;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;margin-top:10px}.retry-button:hover{background:#1976d2}.user-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-top:20px}.stat-card{background:#f8f9fa;padding:20px;border-radius:8px;text-align:center;border:1px solid #e0e0e0}.stat-card h4{margin:0 0 10px;color:#666;font-size:14px;font-weight:500}.stat-number{margin:0;font-size:24px;font-weight:600;color:#2196f3}@media(max-width:768px){.user-management{padding:10px}.user-header{flex-direction:column;gap:10px;align-items:flex-start}.user-table{font-size:12px;min-width:700px}.user-table th,.user-table td{padding:8px 4px}.user-id-column,.username-column,.email-column{width:120px;max-width:120px}.name-column{width:80px;max-width:80px}.date-column{width:100px;max-width:100px}.user-stats{grid-template-columns:repeat(2,1fr);gap:10px}.stat-card{padding:15px}.stat-number{font-size:20px}}.admin-page{min-height:100vh;display:flex;flex-direction:column;background-color:#f5f5f5}.admin-header{background-color:#2c3e50;color:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a}.admin-header .header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto}.admin-header h1{margin:0;font-size:1.5rem}.admin-header h2{margin:0;font-size:1.2rem;font-weight:400;opacity:.9}.admin-content{flex:1;max-width:1200px;margin:0 auto;padding:2rem;width:100%}.admin-tabs{display:flex;gap:1rem;margin-bottom:2rem;border-bottom:2px solid #e0e0e0}.tab-button{padding:.75rem 1.5rem;border:none;background:none;font-size:1rem;cursor:pointer;border-bottom:3px solid transparent;transition:all .3s ease;color:#666}.tab-button:hover{color:#2c3e50;background-color:#f8f9fa}.tab-button.active{color:#2c3e50;border-bottom-color:#3498db;font-weight:600}.tab-content{background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.admin-footer{background-color:#2c3e50;color:#fff;text-align:center;padding:1rem;margin-top:auto}.admin-footer p{margin:0;opacity:.8}@media(max-width:768px){.admin-header .header-content{flex-direction:column;gap:.5rem;text-align:center}.admin-content{padding:1rem}.admin-tabs{flex-direction:column;gap:.5rem}.tab-button{text-align:left;border-bottom:none;border-left:3px solid transparent}.tab-button.active{border-left-color:#3498db;border-bottom-color:transparent}}.app{display:flex;flex-direction:column;height:100%;width:100%;overflow:hidden}.app-header{background-color:var(--primary-color);color:#fff;padding:var(--space-md);box-shadow:0 2px 4px #0000001a;flex-shrink:0;z-index:10}.header-content{display:flex;justify-content:space-between;align-items:center;max-width:1200px;margin:0 auto;width:100%}.app-header h1{font-size:var(--font-size-xl);margin:0}.app-footer{background-color:var(--secondary-color);color:#fff;text-align:center;padding:var(--space-sm);font-size:var(--font-size-small);flex-shrink:0;z-index:10}@media(max-width:768px){.app-header{padding:var(--space-sm)}.header-content{max-width:none;margin:0}.app-header h1{font-size:var(--font-size-large)}.app-footer{padding:var(--space-xs) var(--space-sm);font-size:.75rem}}@media(max-width:480px){.app-header{padding:var(--space-sm)}.app-header h1{font-size:var(--font-size-large)}.app-content{padding:var(--space-sm)}.app-footer{padding:var(--space-xs) var(--space-sm);font-size:.75rem}}@media(max-height:480px)and (orientation:landscape){.app-header{padding:var(--space-xs)}.app-header h1{font-size:var(--font-size-large)}.app-footer{padding:var(--space-xs)}}:root{--primary-color: #722f37;--secondary-color: #3f0d12;--accent-color: #a4243b;--background-color: #f9f7f3;--text-color: #333;--light-color: #e8e4e1;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--font-size-small: .875rem;--font-size-base: 1rem;--font-size-large: 1.25rem;--font-size-xl: 1.5rem;--font-size-xxl: 2rem}html{box-sizing:border-box;height:100%;font-size:16px}*,*:before,*:after{box-sizing:inherit;margin:0;padding:0}body{font-family:Roboto,-apple-system,BlinkMacSystemFont,Segoe UI,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background-color);color:var(--text-color);line-height:1.6;height:100%;width:100%;overflow-x:hidden;position:fixed}#root{display:flex;flex-direction:column;height:100%;width:100%}h1{font-size:var(--font-size-xxl)}h2{font-size:var(--font-size-xl)}h3{font-size:var(--font-size-large)}p,li,input,textarea,button{font-size:var(--font-size-base)}@media(max-width:480px){html{font-size:14px}:root{--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem}}@media(min-width:481px)and (max-width:768px){html{font-size:15px}}@media(min-width:769px){html{font-size:16px}}
