:root{--bg-primary:#f0f2f5;--bg-secondary:#fff;--text-primary:#1a1a1a;--text-secondary:#555;--primary-accent:#42a5f5;--secondary-accent:#20b2aa;--border-color:#e0e0e0;--message-sent-bg:#dcf8c6;--message-received-bg:#fff;--modal-bg:#fff;--button-hover-darken-factor:0.8;--link-color:#2196f3;--link-hover-color:#1976d2;--box-shadow-light:0 4px 8px #0000001a;--box-shadow-medium:0 2px 4px #0000001a}body.dark-mode{--bg-primary:#1a1a2e;--bg-secondary:#282c44;--text-primary:#f0f2f5;--text-secondary:#a0a3b2;--primary-accent:#6af;--secondary-accent:#20b2aa;--border-color:#3d405b;--message-sent-bg:#4a7c59;--message-received-bg:#3b3e5b;--modal-bg:#282c44;--button-hover-darken-factor:1.2;--link-color:#90caf9;--link-hover-color:#bbdefb;--box-shadow-light:0 4px 8px #0000004d;--box-shadow-medium:0 2px 4px #0003;.link-button,.policy-modal-content a,.privacy-policy-link-container a{color:#fff!important}}body{align-items:flex-start;background-color:#f0f2f5;background-color:var(--bg-primary);box-sizing:border-box;color:#1a1a1a;color:var(--text-primary);display:flex;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;justify-content:center;margin:0;min-height:100vh;padding:0;transition:background-color .3s ease,color .3s ease}.app-container{background-color:#fff;background-color:var(--bg-secondary);border-radius:8px;box-shadow:0 4px 8px #0000001a;box-shadow:var(--box-shadow-light);max-width:950px;overflow:hidden;padding:0;text-align:center;transition:background-color .3s ease,box-shadow .3s ease;width:100%}.app-header{background-color:#42a5f5;background-color:var(--primary-accent);border-top-left-radius:8px;border-top-right-radius:8px;box-shadow:0 2px 4px #0000001a;box-shadow:var(--box-shadow-medium);color:#1a1a1a;color:var(--text-primary);justify-content:center;padding:15px 20px;position:relative;transition:background-color .3s ease,box-shadow .3s ease}.app-header,.nav-container{align-items:center;display:flex}.nav-container{flex-direction:column;max-width:760px;width:100%}.bitwattr-link{color:#1a1a1a;color:var(--text-primary);font-size:1.1em;font-weight:700;margin-bottom:10px;text-decoration:none;transition:color .3s ease}.bitwattr-link:hover{color:#1976d2;color:var(--link-hover-color)}.app-title{align-items:center;display:flex;font-size:1.8em;gap:10px;margin:0}.chat-icon{font-size:1.2em}.theme-toggle{align-items:center;background-color:#20b2aa;background-color:var(--secondary-accent);border:none;border-radius:20px;color:#1a1a1a;color:var(--text-primary);cursor:pointer;display:flex;font-size:.9em;gap:5px;padding:8px 12px;position:absolute;right:20px;top:50%;transform:translateY(-50%);transition:background-color .3s ease,color .3s ease}.theme-toggle:hover{background-color:color-mix(in srgb,#20b2aa .8,#000);background-color:color-mix(in srgb,var(--secondary-accent) var(--button-hover-darken-factor),#000)}h1,h2,h3{color:#1a1a1a;color:var(--text-primary);transition:color .3s ease}h1{margin-bottom:30px}h2{margin-bottom:20px;margin-top:20px}.bitwattr-info-section,.demo-chat-container,.how-it-works-container,.how-it-works-section,.info-and-links-section,.more-about-bitwattr-container,.persona-selection,.run-locally-container,.run-locally-section,.upload-form-container{background-color:#fff;background-color:var(--bg-secondary);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;padding:20px;transition:background-color .3s ease,border-color .3s ease}.custom-file-upload{align-items:center;background-color:#42a5f5;background-color:var(--primary-accent);border:1px solid #42a5f5;border:1px solid var(--primary-accent);border-radius:5px;color:#1a1a1a;color:var(--text-primary);cursor:pointer;display:inline-block;display:inline-flex;gap:8px;justify-content:center;margin-bottom:15px;padding:10px 20px;transition:background-color .3s ease}.custom-file-upload:hover{background-color:color-mix(in srgb,#42a5f5 .8,#000);background-color:color-mix(in srgb,var(--primary-accent) var(--button-hover-darken-factor),#000)}.custom-file-upload input[type=file]{display:none}button{align-items:center;background-color:#42a5f5;background-color:var(--primary-accent);border:1px solid #42a5f5;border:1px solid var(--primary-accent);border-radius:5px;color:#1a1a1a;color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:16px;gap:8px;justify-content:center;margin:5px;padding:10px 20px;transition:background-color .3s ease,color .3s ease}button:hover:enabled{background-color:color-mix(in srgb,#42a5f5 .8,#000);background-color:color-mix(in srgb,var(--primary-accent) var(--button-hover-darken-factor),#000)}button:disabled{background-color:#e0e0e0;background-color:var(--border-color);cursor:not-allowed;opacity:.7}.message{color:#555;color:var(--text-secondary);font-size:14px;margin-top:15px}.chat-interface{margin-top:0;padding-bottom:20px}.persona-button{background-color:#20b2aa;background-color:var(--secondary-accent);margin:10px}.persona-button:hover:enabled{background-color:color-mix(in srgb,#20b2aa .8,#000);background-color:color-mix(in srgb,var(--secondary-accent) var(--button-hover-darken-factor),#000)}.upload-again-button{background-color:#6c757d;color:#fff;margin-top:20px}.upload-again-button:hover:enabled{background-color:#5a6268}.chat-container{background-color:#fff;background-color:var(--bg-secondary);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;flex-direction:column;height:80vh;margin:20px;max-height:900px;min-height:500px;overflow:hidden}.chat-container,.chat-header{display:flex;transition:background-color .3s ease,border-color .3s ease}.chat-header{align-items:center;background-color:#f0f2f5;background-color:var(--bg-primary);border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color);flex-wrap:wrap;justify-content:space-between;padding:15px}.chat-header h2{flex-grow:1;font-size:1.1em;margin:0;order:2;padding:5px 0;text-align:center}.back-button,.chat-header h2{color:#1a1a1a;color:var(--text-primary)}.back-button{background-color:#ffc107;font-size:14px;margin-right:10px;order:1;padding:8px 15px}.back-button:hover:enabled{background-color:color-mix(in srgb,#ffc107 .8,#000);background-color:color-mix(in srgb,#ffc107 var(--button-hover-darken-factor),#000)}.chat-messages{background-color:#fff;background-color:var(--bg-secondary);display:flex;flex-direction:column;flex-grow:1;gap:10px;overflow-y:auto;padding:15px;transition:background-color .3s ease}.message-bubble{word-wrap:break-word;border-radius:18px;box-shadow:0 1px 1px #0000000d;font-size:15px;line-height:1.4;max-width:80%;padding:10px 15px}.message-bubble.sent{align-self:flex-end;background-color:#dcf8c6;background-color:var(--message-sent-bg);border-bottom-right-radius:2px;color:#1a1a1a;color:var(--text-primary)}.message-bubble.received{align-self:flex-start;background-color:#fff;background-color:var(--message-received-bg);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-bottom-left-radius:2px;color:#1a1a1a;color:var(--text-primary)}.message-bubble strong{align-items:center;display:flex;font-weight:600;gap:5px}.message-sender-icon{color:#555;color:var(--text-secondary);font-size:1.1em}.typing-indicator{align-items:center;color:#555;color:var(--text-secondary);display:flex;font-style:italic;gap:5px}.typing-dot{animation:bounce 1.4s ease-in-out infinite;background-color:#555;background-color:var(--text-secondary);border-radius:50%;height:8px;width:8px}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-8px)}}.no-messages-hint{color:#555;color:var(--text-secondary);font-style:italic;margin-top:20px}.message-input-form{background-color:#f0f2f5;background-color:var(--bg-primary);border-top:1px solid #e0e0e0;border-top:1px solid var(--border-color);display:flex;gap:10px;padding:15px;transition:background-color .3s ease,border-color .3s ease}.message-input-form input{background-color:#fff;background-color:var(--bg-secondary);border:1px solid #e0e0e0;border:1px solid var(--border-color);box-shadow:inset 0 1px 2px #0000000d;flex-grow:1;font-size:16px;outline:none;transition:background-color .3s ease,border-color .3s ease,color .3s ease}.message-input-form button,.message-input-form input{border-radius:20px;color:#1a1a1a;color:var(--text-primary);padding:10px 15px}.message-input-form button{background-color:#42a5f5;background-color:var(--primary-accent)}.message-input-form button:hover:enabled{background-color:color-mix(in srgb,#42a5f5 .8,#000);background-color:color-mix(in srgb,var(--primary-accent) var(--button-hover-darken-factor),#000)}.spinner{animation:spin 1s linear infinite;border:4px solid color-mix(in srgb,#e0e0e0 50%,#0000);border-top:4px solid #42a5f5;border:4px solid color-mix(in srgb,var(--border-color) 50%,#0000);border-radius:50%;border-top-color:var(--primary-accent);height:24px;margin-right:10px;width:24px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-indicator{color:#555;color:var(--text-secondary);font-style:italic;padding:20px}.loading-indicator,.policy-modal-overlay{align-items:center;display:flex;justify-content:center}.policy-modal-overlay{background-color:#0009;height:100%;left:0;opacity:0;position:fixed;top:0;transition:opacity .3s ease,visibility .3s ease;visibility:hidden;width:100%;z-index:1000}.policy-modal-overlay.visible{opacity:1;visibility:visible}.policy-modal-content{-webkit-overflow-scrolling:touch;animation:fadeInScale .3s ease-out;background-color:#fff;background-color:var(--modal-bg);border-radius:10px;box-shadow:0 4px 8px #0000001a;box-shadow:var(--box-shadow-light);max-height:80vh;max-width:500px;overflow-y:auto;padding:30px;text-align:left;transition:background-color .3s ease,box-shadow .3s ease;width:90%}.policy-modal-content h2,.policy-modal-content h3{color:#42a5f5;color:var(--primary-accent);margin-bottom:20px;text-align:center;transition:color .3s ease}.policy-modal-content p{color:#555;color:var(--text-secondary);line-height:1.6;margin-bottom:15px;text-align:justify}.policy-modal-content ul{margin-bottom:15px;padding-left:20px;text-align:left}.policy-modal-content li{margin-bottom:8px}.policy-modal-content img{border-radius:5px;box-shadow:0 2px 4px #0000001a;box-shadow:var(--box-shadow-medium);display:block;height:auto;margin:10px auto;max-width:100%}@media (max-width:600px){.policy-modal-content{padding:20px;width:95%}.policy-modal-content p,.policy-modal-content ul{text-align:left}}.agree-button{background-color:#42a5f5;background-color:var(--primary-accent);font-size:1.1em;margin-top:20px;padding:12px 25px}.agree-button:hover{background-color:color-mix(in srgb,#42a5f5 .8,#000);background-color:color-mix(in srgb,var(--primary-accent) var(--button-hover-darken-factor),#000)}@keyframes fadeInScale{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@media (max-width:600px){body{padding:0}.app-container{border-radius:0;box-shadow:none;max-width:100%;min-height:100vh}.app-header{border-radius:0;padding:10px 15px}.nav-container{flex-direction:column;gap:5px}.app-title{font-size:1.5em;margin-top:5px}.bitwattr-link{margin-bottom:5px}.persona-selection,.upload-form-container{margin:15px;padding:15px}.chat-container{border-radius:0;margin:0;max-height:none;min-height:80vh}.chat-header{align-items:center;flex-direction:column;gap:10px}.chat-header h2{font-size:1em;margin-top:5px;text-align:center;width:100%}.back-button{margin-right:0;width:100%}.message-bubble{font-size:14px;max-width:90%}.message-input-form{flex-direction:row;gap:10px;padding:10px}.message-input-form input{margin-right:0}.message-input-form button{width:auto}.policy-modal-content{padding:20px;width:95%}.theme-toggle{align-self:flex-end;margin-top:10px;position:static;transform:none;width:-webkit-fit-content;width:fit-content}}.donate-page-container{background-color:#fff;background-color:var(--bg-secondary);border-radius:8px;box-shadow:0 4px 8px #0000001a;box-shadow:var(--box-shadow-light);margin:20px auto;max-width:800px;padding:30px;text-align:center;transition:background-color .3s ease,box-shadow .3s ease}.donate-page-container h2{color:#42a5f5;color:var(--primary-accent);margin-bottom:25px}.donate-page-container p{color:#555;color:var(--text-secondary);line-height:1.6;margin-bottom:15px}.game-showcase{background-color:color-mix(in srgb,#f0f2f5 80%,#0000);background-color:color-mix(in srgb,var(--bg-primary) 80%,#0000);border-radius:8px;box-shadow:inset 0 1px 3px #0000001a;margin-bottom:40px;margin-top:30px;padding:20px;transition:background-color .3s ease}.game-showcase h3{color:#42a5f5;color:var(--primary-accent);margin-bottom:20px}.game-embed{margin:0 auto;max-width:550px}.game-embed iframe{border:none;border-radius:5px;height:165px;width:100%}.embed-caption{color:#555;color:var(--text-secondary);font-size:.9em;margin-top:10px}.other-games-section{border-top:1px dashed #e0e0e0;border-top:1px dashed var(--border-color);margin-top:30px;padding-top:20px}.back-to-upload-button{background-color:#6c757d;color:#fff;margin-top:20px}.back-to-upload-button:hover:enabled{background-color:#5a6268}.persona-chat-layout{background:#fff;background:var(--bg-secondary);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;height:80vh;margin:20px;max-height:900px;min-height:500px;overflow:hidden}.persona-chat-layout,.persona-sidebar{display:flex;transition:background-color .3s ease,border-color .3s ease}.persona-sidebar{align-items:stretch;background:#f0f2f5;background:var(--bg-primary);border-right:1px solid #e0e0e0;border-right:1px solid var(--border-color);flex-direction:column;gap:10px;padding:20px 10px;width:260px}.persona-sidebar h2{color:#42a5f5;color:var(--primary-accent);font-size:1.1em;margin-bottom:15px;text-align:left}.persona-button.selected{background-color:#42a5f5;background-color:var(--primary-accent);color:#1a1a1a;color:var(--text-primary)}.persona-chat-main{background:#fff;background:var(--bg-secondary);display:flex;flex:1 1;flex-direction:column;min-width:0;transition:background-color .3s ease}.no-persona-selected{align-items:center;color:#555;color:var(--text-secondary);display:flex;font-size:1.2em;font-style:italic;height:100%;justify-content:center}@media (max-width:600px){.persona-chat-layout,.persona-chat-main,.persona-sidebar{display:none!important}.donate-page-container{border-radius:0;box-shadow:none;margin:0;padding:15px}.game-embed iframe{width:100%}.colorful-button{margin-bottom:10px;width:100%}}@media (min-width:768px){.upload-form-wrapper{display:flex;flex-wrap:wrap;gap:20px;justify-content:space-around;margin:20px}.bitwattr-info-section,.demo-chat-section,.how-it-works-section,.info-and-links-section,.run-locally-section,.upload-form-section{background-color:#fff;background-color:var(--bg-secondary);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;flex:1 1;margin-bottom:20px;min-width:300px;padding:20px;transition:background-color .3s ease,border-color .3s ease}.demo-chat-container,.upload-form-container{background-color:initial;border:none;margin:0;padding:0}.privacy-policy-link-container{align-items:flex-start;display:flex;flex-direction:column;gap:10px}.how-it-works-container,.more-about-bitwattr-container,.run-locally-container{background-color:#fff;background-color:var(--bg-secondary);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:8px;margin-bottom:20px;padding:20px;transition:background-color .3s ease,border-color .3s ease}.how-it-works-container ol{padding-left:25px}.how-it-works-container li{margin-bottom:10px}.demo-buttons{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.link-button{align-items:center;color:#2196f3;color:var(--link-color);display:flex;gap:8px;text-decoration:none;transition:color .3s ease}.link-button:hover{color:#1976d2;color:var(--link-hover-color)}.more-about-bitwattr-container a.visit-bitwattr-button,.run-locally-container a.visit-github-button,.run-locally-container button{display:inline-flex;margin-bottom:10px;margin-right:10px}}.model-select-container{margin-bottom:15px;position:relative;width:100%}.model-select-toggle{align-items:center;background-color:#fff;background-color:var(--bg-secondary);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:5px;box-shadow:inset 0 1px 2px #0000000d;color:#1a1a1a;color:var(--text-primary);cursor:pointer;display:flex;font-size:16px;justify-content:space-between;padding:10px 15px;transition:all .3s ease;width:100%}.model-select-toggle:hover{border-color:#42a5f5;border-color:var(--primary-accent)}.model-select-toggle:disabled{background-color:#e0e0e0;background-color:var(--border-color);cursor:not-allowed;opacity:.7}.model-select-toggle span{flex-grow:1;margin-left:10px;text-align:left}.model-options-dropdown{background-color:#fff;background-color:var(--bg-secondary);border:1px solid #e0e0e0;border:1px solid var(--border-color);border-radius:5px;box-shadow:0 2px 4px #0000001a;box-shadow:var(--box-shadow-medium);left:0;list-style:none;margin:5px 0 0;max-height:200px;overflow-y:auto;padding:0;position:absolute;top:100%;width:100%;z-index:10}.model-option-item{align-items:center;border-bottom:1px solid #e0e0e0;border-bottom:1px solid var(--border-color);cursor:pointer;display:flex;gap:10px;padding:10px 15px;transition:background-color .2s ease}.model-option-item:last-child{border-bottom:none}.model-option-item:hover{background-color:#f0f2f5;background-color:var(--bg-primary)}.model-option-item.selected{background-color:#42a5f5;background-color:var(--primary-accent)}.model-option-item.selected,.model-option-item.selected .model-option-description,.model-option-item.selected .model-option-icon{color:#1a1a1a;color:var(--text-primary)}.model-option-content{align-items:flex-start;display:flex;flex-grow:1;gap:10px}.model-option-icon{color:#42a5f5;color:var(--primary-accent);flex-shrink:0;font-size:1.5em}.model-option-item.selected .model-option-icon{color:#1a1a1a;color:var(--text-primary)}.model-option-text{display:flex;flex-direction:column;text-align:left}.model-option-name{color:#1a1a1a;color:var(--text-primary);font-weight:700}.model-option-description{color:#555;color:var(--text-secondary);font-size:.8em;line-height:1.3}.gemini-policy-heading{align-items:center;color:#2196f3;display:flex;gap:10px;justify-content:center;margin-bottom:15px!important;margin-top:30px!important}.gemini-policy-text{color:#555;color:var(--text-secondary);font-size:.95em;margin-bottom:10px;text-align:justify}.gemini-policy-link{color:#2196f3!important;text-decoration:underline}.gemini-policy-link:hover{color:#1976d2!important}body.dark-mode .gemini-policy-heading{color:#ffab91!important}body.dark-mode .gemini-policy-link{color:#90caf9!important}
/*# sourceMappingURL=main.bf7844b0.css.map*/