.conversation-sidebar{width:280px;background:#46433a;border-right:2px solid #474745;display:flex;flex-direction:column;height:100%;overflow:hidden}.sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#46433a;border-bottom:2px solid #474745;flex-shrink:0}.sidebar-search{position:relative;padding:8px 1rem;border-bottom:1px solid #474745;background:#0000001a;flex-shrink:0}.sidebar-search-input{width:100%;padding:8px 32px 8px 8px;background:#2e2c29;border:1px solid #474745;color:#ffcf3f;font-size:16px;border-radius:0;outline:none}.sidebar-search-input:focus{border-color:#e6a519;box-shadow:0 0 4px #e6a5194d}.sidebar-search-input::placeholder{color:#a0a0a0;opacity:.6}.sidebar-search-clear{position:absolute;right:1.5rem;top:50%;transform:translateY(-50%);width:24px;height:24px;background:transparent;border:none;color:#a0a0a0;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;padding:0}.sidebar-search-clear:hover{color:#ffcf3f}.sidebar-empty-state{padding:2rem 1rem;text-align:center;color:#a0a0a0;font-size:.9rem;font-style:italic}.sidebar-title{margin:0;font-size:1rem;color:#ffcf3f;text-shadow:1px 1px 0 #0F0F0F;font-weight:700;font-family:MedievalSharp,"Exo 2",monospace;letter-spacing:1px;text-transform:uppercase}.new-conversation-btn{width:32px;height:32px;background:#694d23;color:#ffcf3f;border:2px solid #474745;border-radius:0;cursor:pointer;font-size:1.5rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .2s;text-shadow:1px 1px 0 #0F0F0F;line-height:1;padding:0}.new-conversation-btn:hover{background:#382d1a;border-color:#e6a519;box-shadow:0 0 8px #e6a5194d;transform:translateY(-1px);transition:all .2s ease}.conversation-list{flex:1;overflow-y:auto;min-height:0}.conversation-item{position:relative;padding:.75rem 1rem;padding-right:36px;cursor:pointer;transition:background .2s;border:none;border-bottom:1px solid #474745;text-align:left;display:flex;flex-direction:column;align-items:flex-start;width:100%;background:transparent;font:inherit}.conversation-item:hover{background:#694d234d}.conversation-item.active{background:#694d23;border-left:3px solid #E6A519;padding-left:calc(1rem - 3px)}.conversation-title{color:#ffcf3f;font-size:.9rem;font-weight:600;margin-bottom:.25rem;text-shadow:1px 1px 0 #0F0F0F;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-timestamp{color:#a0a0a0;font-size:.75rem;font-style:italic}.conversation-list::-webkit-scrollbar{width:8px}.conversation-list::-webkit-scrollbar-track{background:#2e2c29}.conversation-list::-webkit-scrollbar-thumb{background:#694d23;border-radius:0;border:1px solid #474745}.conversation-list::-webkit-scrollbar-thumb:hover{background:#e6a519}.sidebar-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:102;background:#694d23;color:#ffcf3f;border:2px solid #474745;border-radius:0;width:44px;height:44px;font-size:1.5rem;cursor:pointer;text-shadow:1px 1px 0 #0F0F0F;transition:all .2s;padding:0;line-height:1}.sidebar-toggle:hover{background:#382d1a;border-color:#e6a519;box-shadow:0 0 8px #e6a5194d}.sidebar-backdrop{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#0009;z-index:99}@media(max-width:768px){.sidebar-toggle{display:flex;align-items:center;justify-content:center}.sidebar-backdrop{display:block}.conversation-sidebar{width:280px;position:fixed;top:0;left:-280px;z-index:101;box-shadow:2px 0 8px #00000080;transition:left .3s ease-in-out}.conversation-sidebar.mobile-open{left:0}.delete-modal-actions{flex-direction:column}.delete-modal-cancel,.delete-modal-confirm{min-height:44px}}.delete-conversation-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:24px;height:24px;background:transparent;color:#a0a0a0;border:none;cursor:pointer;opacity:0;transition:all .2s;font-size:1.1rem;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}.conversation-item:hover .delete-conversation-btn{opacity:1}.delete-conversation-btn:hover{color:#f44;background:#ff44441a}.delete-modal-backdrop{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000b3;z-index:199}.delete-conversation-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:360px;background:#46433a;border:3px solid #8B0000;padding:1.5rem;z-index:200;box-shadow:0 0 20px #8b000080}.delete-modal-title{margin:0 0 1rem;font-size:1.25rem;color:#f44;text-shadow:1px 1px 0 #0F0F0F;font-weight:700;text-transform:uppercase;letter-spacing:1px;text-align:center}.delete-modal-description{color:#ffcf3f;font-size:.95rem;margin:0 0 .75rem;text-shadow:1px 1px 0 #0F0F0F;text-align:center}.delete-modal-warning{color:#f44;font-size:.95rem;font-weight:700;margin:0 0 1.5rem;text-shadow:1px 1px 0 #0F0F0F;text-align:center}.delete-modal-actions{display:flex;gap:1rem}.delete-modal-cancel{flex:1;padding:.75rem 1rem;background:#694d23;color:#ffcf3f;border:2px solid #474745;border-radius:0;cursor:pointer;font-weight:600;transition:all .2s;text-shadow:1px 1px 0 #0F0F0F}.delete-modal-cancel:hover:not(:disabled){background:#382d1a;border-color:#e6a519;box-shadow:0 0 8px #e6a5194d}.delete-modal-cancel:disabled{opacity:.5;cursor:not-allowed}.delete-modal-confirm{flex:1;padding:.75rem 1rem;background:#8b0000;color:#ffcf3f;border:2px solid #FF4444;border-radius:0;cursor:pointer;font-weight:600;transition:all .2s;text-shadow:1px 1px 0 #0F0F0F}.delete-modal-confirm:hover:not(:disabled){background:#a00;box-shadow:0 0 12px #ff444480}.delete-modal-confirm:disabled{opacity:.7;cursor:not-allowed}.sidebar-footer{padding:.75rem 1rem;border-top:1px solid #474745;flex-shrink:0}.delete-all-btn{width:100%;background:transparent;color:#a0a0a0;border:1px dashed #5C5846;padding:.5rem 1rem;font-size:.85rem;cursor:pointer;transition:all .2s;text-shadow:1px 1px 0 #0F0F0F}.delete-all-btn:hover{color:#f44;border-color:#f44;background:#ff44441a}.delete-all-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:400px;background:#46433a;border:4px solid #8B0000;padding:1.5rem;z-index:200;box-shadow:0 0 20px #8b000080}.delete-all-warning{color:#f44;font-weight:700;text-align:center;padding:.5rem;background:#8b000033;border-radius:4px;margin:1rem 0 1.5rem;text-shadow:1px 1px 0 #0F0F0F}.app{display:flex;flex-direction:column;height:100%;background:var(--bg-primary)}.header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--bg-panel);border-bottom:3px solid var(--border-primary);color:var(--text-primary);box-shadow:0 2px 8px var(--shadow-box)}.header-content{display:flex;align-items:center;gap:1rem}.logo{width:40px;height:40px;filter:drop-shadow(2px 2px 2px var(--shadow-box))}.header h1{margin:0;font-size:1.5rem;color:var(--text-primary);text-shadow:2px 2px 0 var(--shadow-text);font-weight:700;font-family:MedievalSharp,"Exo 2",monospace;letter-spacing:2px;text-transform:uppercase}.logout-button{padding:.5rem 1.5rem;background:var(--bg-button);color:var(--text-primary);border:2px solid var(--border-primary);border-radius:0;cursor:pointer;font-weight:600;transition:all .2s;text-shadow:1px 1px 0 var(--shadow-text)}.logout-button:hover{background:var(--bg-button-hover);border-color:var(--border-gold);box-shadow:0 0 8px var(--shadow-glow);transform:translateY(-1px);transition:all .2s ease}.header-actions{display:flex;align-items:center;gap:.75rem}.user-info{color:var(--text-gold);font-size:.9rem;margin-right:.5rem}.settings-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--bg-button);border:2px solid var(--border-primary);color:var(--text-primary);text-decoration:none;transition:all .2s}.settings-link:hover{background:var(--bg-button-hover);border-color:var(--border-gold)}.settings-icon{font-size:1.25rem}.main-content{display:flex;flex:1;overflow:hidden}.chat-container{display:flex;flex-direction:column;flex:1;overflow:hidden}.messages{flex:1;overflow-y:auto;min-height:0;padding:clamp(16px,2vw,32px);display:flex;flex-direction:column;gap:16px}.welcome-message{text-align:center;color:var(--text-gold);padding:32px;font-style:normal;text-shadow:1px 1px 0 var(--shadow-text);font-size:1.1rem;letter-spacing:.5px}.welcome-prompts{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;justify-content:center}.prompt-chip{padding:8px 16px;background:var(--bg-button, #694D23);color:var(--text-gold, #FFCF3F);border:2px solid var(--border-primary, #474745);border-radius:0;cursor:pointer;font-size:.85rem;font-family:"Exo 2",sans-serif;text-shadow:1px 1px 0 var(--shadow-text, #0F0F0F);transition:background .2s ease,border-color .2s ease,box-shadow .2s ease,transform .2s ease}.prompt-chip:hover{background:var(--bg-button-hover, #382D1A);border-color:var(--border-gold, #E6A519);box-shadow:0 0 8px var(--shadow-glow, rgba(230, 165, 25, .3));transform:translateY(-2px)}.message{max-width:min(70%,600px);padding:1rem;border:2px solid var(--border-primary);border-radius:0;word-wrap:break-word}.message.user{align-self:flex-end;background:var(--bg-message-user);color:var(--text-cyan);margin-left:auto;text-shadow:1px 1px 0 var(--shadow-text);border:2px solid var(--border-user)}.message.assistant{align-self:flex-start;background:var(--bg-message-assistant);color:var(--text-primary);margin-right:auto;text-shadow:1px 1px 0 var(--shadow-text);border:2px solid var(--border-assistant)}.message-content{margin:0;line-height:1.35!important;white-space:normal!important}.message-content p{margin:0 0 .4em}.message-content p:last-child{margin-bottom:0}.message-content ol,.message-content ul{margin:.2em 0 .4em;padding-left:1.2em;list-style-position:outside}.message-content li{margin:0;padding:.05em 0}.message-content li p{margin:0;display:inline}.message-content li>ul,.message-content li>ol{margin:.1em 0 0}.message-content strong{color:var(--text-gold)}.message-content em{font-style:italic;color:var(--text-highlight)}.message-content code{background:#0000004d;padding:.1rem .3rem;border-radius:2px;font-family:monospace;font-size:.9em}.message-content h2{color:var(--text-gold);margin:.75em 0 .35em;font-size:1.1em;text-shadow:1px 1px 0 var(--shadow-text)}.message-content h3{color:var(--text-gold);margin:.6em 0 .25em;font-size:1em;text-shadow:1px 1px 0 var(--shadow-text)}.message-content h1,.message-content h4{color:var(--text-gold);margin:.5em 0 .25em;text-shadow:1px 1px 0 var(--shadow-text)}.message-content h1:first-child,.message-content h2:first-child,.message-content h3:first-child,.message-content h4:first-child{margin-top:0}.citations{margin-top:12px;padding-top:12px;border-top:1px solid rgba(71,71,69,.5)}.citations h4{margin:0 0 8px;font-size:.85rem;color:var(--text-gold);text-transform:uppercase;letter-spacing:.5px}.citations ul{margin:0;padding-left:20px;list-style:none}.citations li{margin-bottom:4px}.citations a{color:var(--text-cyan);text-decoration:none;font-size:.9rem;transition:all .2s}.citations a:hover{color:var(--text-gold);text-shadow:0 0 4px var(--shadow-glow)}.wiki-link{color:var(--text-cyan);text-decoration:none;transition:all .2s}.wiki-link:hover{color:var(--text-gold);text-shadow:0 0 4px var(--shadow-glow)}.token-stats{margin-top:8px;padding-top:8px;border-top:1px solid rgba(71,71,69,.3);font-size:.75rem;color:var(--text-muted);font-style:italic;text-shadow:none}.knowledge-indicator{color:var(--text-muted, #A0A0A0);font-size:.85rem;font-style:italic;margin-top:8px}.loading-dots span{animation:blink 1.4s infinite;opacity:0}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,to{opacity:0}50%{opacity:1}}.input-container{padding:16px 24px;background:var(--bg-panel);border-top:3px solid var(--border-primary);display:flex;gap:16px;flex-shrink:0;z-index:10;position:relative}.input-container textarea{flex:1;padding:.75rem;border:2px solid var(--border-primary);border-radius:0;background:var(--bg-input);color:var(--text-primary);font-size:1rem;font-family:inherit;resize:none}.input-container textarea::placeholder{color:var(--text-placeholder)}.input-container textarea:focus{outline:none;border-color:var(--border-gold);box-shadow:0 0 8px var(--shadow-glow)}.input-container textarea:disabled{opacity:.5;cursor:not-allowed}.input-container button{padding:.75rem 2rem;background:var(--bg-button);color:var(--text-primary);border:2px solid var(--border-primary);border-radius:0;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-shadow:1px 1px 0 var(--shadow-text)}.input-container button:hover:not(:disabled){background:var(--bg-button-hover);border-color:var(--border-gold);box-shadow:0 0 8px var(--shadow-glow);transform:translateY(-1px);transition:all .2s ease}.input-container button:disabled{opacity:.5;cursor:not-allowed}.messages::-webkit-scrollbar{width:8px}.messages::-webkit-scrollbar-track{background:var(--scrollbar-track)}.messages::-webkit-scrollbar-thumb{background:var(--scrollbar-thumb);border-radius:0;border:1px solid var(--border-primary)}.messages::-webkit-scrollbar-thumb:hover{background:var(--scrollbar-thumb-hover)}.streaming-cursor{display:inline-block;animation:cursor-blink .8s infinite;color:var(--cursor-color);font-weight:700;margin-left:2px}@keyframes cursor-blink{0%,50%{opacity:1}51%,to{opacity:0}}.streaming-status{color:var(--text-muted);font-style:italic;animation:cursor-blink 1.2s infinite}@media(prefers-reduced-motion:reduce){.streaming-cursor,.streaming-status{animation:none}}.thinking-indicator{display:flex;align-items:center;gap:8px;padding:16px;color:var(--text-muted);font-style:italic;background:var(--bg-message-assistant);border:2px solid var(--border-assistant);margin-bottom:16px}.thinking-text{font-size:.95rem}.thinking-dots{display:inline-flex;gap:2px}.thinking-dots span{animation:thinking-blink 1.4s infinite;opacity:0}.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-blink{0%,to{opacity:0}50%{opacity:1}}.stream-error{background:#8b000033;border:2px solid var(--text-error);padding:16px;margin-bottom:16px}.stream-error-message{color:var(--text-error);margin:0 0 12px;font-size:.95rem}.stream-error-retry{background:var(--bg-button);color:var(--text-primary);border:2px solid var(--border-primary);padding:.5rem 1rem;cursor:pointer;font-size:.9rem;font-weight:600;transition:background .2s ease,border-color .2s ease}.stream-error-retry:hover:not(:disabled){background:var(--bg-button-hover);border-color:var(--border-gold)}.stream-error-retry:disabled{opacity:.5;cursor:not-allowed}.input-container button.stop-button{background:linear-gradient(180deg,#8b0000,#5c0000);border-color:#f44;color:#fcc}.input-container button.stop-button:hover:not(:disabled){background:linear-gradient(180deg,#a00,#6c0000);border-color:#f66;box-shadow:0 0 15px #f446}.connection-status{position:absolute;top:8px;right:8px;z-index:5}.connection-badge{display:inline-block;padding:4px 8px;font-size:.7rem;font-weight:600;text-transform:uppercase;border:1px solid;border-radius:2px;letter-spacing:.5px}.connection-badge--ws,.connection-badge--sse{background:#e6a5191a;color:var(--text-gold);border-color:var(--text-gold)}.connection-badge--connecting{background:#8080801a;color:var(--text-muted);border-color:var(--border-primary)}.elapsed-time{position:absolute;top:-24px;left:24px;font-size:.75rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.button-spinner{display:inline-block;width:12px;height:12px;margin-right:6px;vertical-align:middle}.button-spinner-ring{display:block;width:12px;height:12px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:button-spinner-rotate .8s linear infinite}@keyframes button-spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.thinking-dots span{animation:none;opacity:1}.button-spinner-ring{animation:none;border:2px solid currentColor}}@media(max-width:768px){.header{padding:.75rem 1rem .75rem 4rem}.header h1{font-size:1.25rem}.logo{width:32px;height:32px}.logout-button{padding:.5rem 1rem;font-size:.9rem;min-height:44px}.messages{padding:16px}.message{max-width:85%;padding:.75rem}.input-container{padding:12px 16px;gap:12px}.input-container button{padding:.6rem 1.25rem;min-height:44px}.chat-container .search-viz-container{max-height:240px}.chat-container .search-viz-layout{height:180px}}@media(max-width:480px){.header{padding:.5rem .75rem .5rem 4rem}.header h1{font-size:1rem;letter-spacing:1px}.header-content{gap:.5rem}.logo{width:28px;height:28px}.logout-button{padding:.5rem .75rem;font-size:.85rem;min-height:44px}.messages{padding:12px;gap:12px}.message{max-width:90%;padding:.6rem;font-size:.95rem}.welcome-message{padding:20px;font-size:1rem}.prompt-chip{font-size:.8rem;padding:6px 12px}.input-container{padding:10px 12px;gap:8px;flex-direction:column}.input-container textarea{font-size:16px}.input-container button{width:100%;padding:.75rem;min-height:44px}.chat-container .search-viz-container{max-height:180px}.chat-container .search-viz-layout{height:140px;gap:16px}.chat-container .tool-card-container{font-size:.85rem;padding:8px 12px}.chat-container .tool-card-item{padding:6px 0}.connection-status{display:none}.elapsed-time{top:-20px;left:12px;font-size:.7rem}}.settings-page{display:flex;flex-direction:column;height:100%;background:var(--bg-primary)}.settings-header{display:flex;align-items:center;gap:1rem;padding:1rem 2rem;background:var(--bg-panel);border-bottom:3px solid var(--border-primary)}.settings-header h1{margin:0;font-size:1.5rem;color:var(--text-primary);text-shadow:2px 2px 0 var(--shadow-text);font-family:MedievalSharp,"Exo 2",monospace}.back-link{color:var(--text-cyan);text-decoration:none;font-size:.9rem;padding:.5rem 1rem;background:var(--bg-button);border:2px solid var(--border-primary);transition:all .2s}.back-link:hover{background:var(--bg-button-hover);border-color:var(--border-gold);color:var(--text-gold)}.settings-layout{display:flex;flex:1;overflow:hidden}.settings-sidebar{width:200px;background:var(--bg-panel-dark);border-right:2px solid var(--border-primary);padding:1rem 0;display:flex;flex-direction:column;gap:.25rem}.settings-tab{display:block;width:100%;padding:.75rem 1.5rem;text-align:left;background:transparent;border:none;color:var(--text-primary);font-size:.95rem;cursor:pointer;transition:all .2s}.settings-tab:hover{background:var(--bg-panel)}.settings-tab.active{background:var(--bg-button);border-left:3px solid var(--border-gold)}.settings-content{flex:1;padding:2rem;overflow-y:auto}.settings-section h2{color:var(--text-gold);margin:0 0 1rem;font-size:1.25rem;text-shadow:1px 1px 0 var(--shadow-text)}.settings-section p{color:var(--text-primary);margin:0}@media(max-width:768px){.settings-sidebar{width:160px}.settings-content{padding:1.5rem}}@media(max-width:480px){.settings-layout{flex-direction:column}.settings-sidebar{width:100%;flex-direction:row;overflow-x:auto;border-right:none;border-bottom:2px solid var(--border-primary);padding:0}.settings-tab{padding:.75rem 1rem;white-space:nowrap}.settings-tab.active{border-left:none;border-bottom:3px solid var(--border-gold)}.settings-content{padding:1rem}}.settings-tab-content{max-width:600px}.settings-group{margin-bottom:2rem}.settings-group h3{color:var(--text-gold);margin:0 0 .5rem;font-size:1.1rem}.settings-description{color:var(--text-muted);font-size:.9rem;margin:0 0 1rem}.theme-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.theme-card{background:var(--bg-panel);border:2px solid var(--border-primary);padding:.75rem;cursor:pointer;transition:all .2s;text-align:left;position:relative}.theme-card:hover{border-color:var(--text-gold)}.theme-card.selected{border-color:var(--text-gold);background:var(--bg-button)}.theme-preview{height:60px;border-radius:2px;margin-bottom:.5rem;overflow:hidden}.theme-preview-default{background:#2e2c29}.theme-preview-default .preview-header{background:#46433a;height:12px;border-bottom:2px solid #474745}.theme-preview-default .preview-message{background:#46433a;height:8px;margin:6px;width:60%}.theme-preview-default .preview-message.alt{background:#694d23;width:70%}.theme-preview-dark{background:#1a1917}.theme-preview-dark .preview-header{background:#252321;height:12px;border-bottom:2px solid #3a3632}.theme-preview-dark .preview-message{background:#252321;height:8px;margin:6px;width:60%}.theme-preview-dark .preview-message.alt{background:#3d3529;width:70%}.theme-preview-ancient-magicks{background:#1a0a2e}.theme-preview-ancient-magicks .preview-header{background:#2d1b4e;height:12px;border-bottom:2px solid #4a3870}.theme-preview-ancient-magicks .preview-message{background:#2d1b4e;height:8px;margin:6px;width:60%}.theme-preview-ancient-magicks .preview-message.alt{background:#4a2882;width:70%}.theme-info{display:flex;flex-direction:column;gap:.25rem}.theme-name{color:var(--text-primary);font-weight:600;font-size:.9rem}.theme-desc{color:var(--text-muted);font-size:.75rem}.theme-check{position:absolute;top:.5rem;right:.5rem;color:var(--text-gold);font-size:1rem}.font-size-options{display:flex;gap:1rem}.font-size-btn{background:var(--bg-panel);border:2px solid var(--border-primary);padding:1rem;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:80px}.font-size-btn:hover{border-color:var(--text-gold)}.font-size-btn.selected{border-color:var(--text-gold);background:var(--bg-button)}.font-size-preview{color:var(--text-primary);font-weight:600}.font-small{font-size:14px}.font-medium{font-size:16px}.font-large{font-size:18px}.font-size-name{color:var(--text-muted);font-size:.75rem}.settings-value{color:var(--text-primary);background:var(--bg-panel);padding:.75rem 1rem;border:2px solid var(--border-primary);margin:0}.settings-input{width:100%;max-width:300px;padding:.75rem 1rem;background:var(--bg-input);color:var(--text-primary);border:2px solid var(--border-primary);font-size:1rem;transition:border-color .2s}.settings-input:focus{outline:none;border-color:var(--text-gold)}.settings-input.warning{border-color:orange}.settings-input::placeholder{color:var(--text-placeholder)}.rsn-input-wrapper{display:flex;align-items:center;gap:.75rem}.input-status{font-size:.85rem}.input-status.validating{color:var(--text-muted)}.input-status.valid{color:#0f0}.input-status.warning{color:orange}.validation-message{color:var(--text-muted);font-size:.85rem;margin:.5rem 0 0}.settings-select{padding:.75rem 1rem;background:var(--bg-input);color:var(--text-primary);border:2px solid var(--border-primary);font-size:1rem;cursor:pointer;min-width:200px}.settings-select:focus{outline:none;border-color:var(--text-gold)}.settings-select option{background:var(--bg-panel);color:var(--text-primary)}.bug-report-form{display:flex;flex-direction:column;gap:1rem;max-width:600px}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{color:var(--text-primary);font-size:.9rem;font-weight:600}.form-group .required{color:var(--text-error)}.form-group textarea,.form-group input{background:var(--bg-input);color:var(--text-primary);border:2px solid var(--border-primary);padding:.75rem;font-size:1rem;font-family:inherit;resize:vertical}.form-group textarea:focus,.form-group input:focus{outline:none;border-color:var(--text-gold)}.form-group textarea::placeholder,.form-group input::placeholder{color:var(--text-placeholder)}.form-group textarea:disabled,.form-group input:disabled{opacity:.6;cursor:not-allowed}.char-count{font-size:.75rem;color:var(--text-muted);align-self:flex-end}.form-hint{font-size:.8rem;color:var(--text-muted);margin:0}.form-row{display:flex;gap:1rem}.form-group.half{flex:1}.submit-button{background:var(--bg-button);color:var(--text-primary);border:2px solid var(--border-primary);padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;align-self:flex-start}.submit-button:hover:not(:disabled){background:var(--bg-button-hover);border-color:var(--text-gold)}.submit-button:disabled{opacity:.5;cursor:not-allowed}.feedback-success{background:#00800033;border:2px solid #00FF00;padding:1rem;margin-bottom:1rem}.feedback-success p{color:#0f0;margin:0 0 .5rem}.issue-link{color:var(--text-cyan);text-decoration:none}.issue-link:hover{color:var(--text-gold)}.feedback-error{background:#f003;border:2px solid var(--text-error);padding:1rem;margin-bottom:1rem}.feedback-error p{color:var(--text-error);margin:0}@media(max-width:480px){.form-row{flex-direction:column}}.privacy-option{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg-panel);border:2px solid var(--border-primary);margin-bottom:.75rem;gap:1rem}.privacy-option-info{display:flex;flex-direction:column;gap:.25rem;flex:1}.privacy-option-label{color:var(--text-primary);font-weight:600}.privacy-option-desc{color:var(--text-muted);font-size:.85rem}.toggle-switch{position:relative;display:inline-block;width:48px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--border-primary);transition:.3s;border-radius:24px}.toggle-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:var(--text-primary);transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--text-gold)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch.disabled .toggle-slider{opacity:.5;cursor:not-allowed}@media(max-width:480px){.privacy-option{flex-direction:column;align-items:flex-start;gap:.75rem}}.bug-report-link{font-size:.75rem;color:var(--text-muted);text-decoration:none;padding:.25rem .5rem;transition:color .2s}.bug-report-link:hover{color:var(--text-cyan)}.danger-zone{margin-top:2rem;padding-top:1.5rem;border-top:2px dashed var(--text-error)}.danger-zone h3{color:var(--text-error)}.danger-button{background:linear-gradient(180deg,#8b0000,#5c0000);border:2px solid #FF4444;color:#fcc;padding:.75rem 1.5rem;font-family:MedievalSharp,serif;font-size:1rem;cursor:pointer;text-shadow:1px 1px 2px #000;transition:all .2s ease}.danger-button:hover{background:linear-gradient(180deg,#a00,#6c0000);border-color:#f66;box-shadow:0 0 15px #f446;transform:translateY(-1px)}.danger-button:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.reset-success{background:#00800033;border:2px solid #00FF00;padding:1rem;margin-bottom:1rem}.reset-success p{color:#0f0;margin:0}.reset-error{background:#f003;border:2px solid var(--text-error);padding:1rem;margin-bottom:1rem}.reset-error p{color:var(--text-error);margin:0}.modal-overlay{position:fixed;inset:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:linear-gradient(180deg,#3a3530,#2a2520);border:3px solid var(--border-gold);max-width:420px;padding:1.5rem;position:relative;box-shadow:0 0 30px #000c,inset 0 0 60px #0000004d}.modal-content.danger{border-color:#f44;box-shadow:0 0 30px #8b000080}.modal-title{font-family:MedievalSharp,serif;font-size:1.5rem;color:var(--text-primary);margin:0 0 1rem;text-transform:uppercase;letter-spacing:1px}.modal-content.danger .modal-title{color:#f66}.modal-message{color:var(--text-muted);line-height:1.6;margin:0 0 1.5rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end}.modal-cancel{background:transparent;border:2px solid var(--border-primary);color:var(--text-muted);padding:.5rem 1rem;cursor:pointer;font-size:.95rem;transition:all .2s}.modal-cancel:hover:not(:disabled){border-color:var(--text-gold);color:var(--text-primary)}.modal-cancel:disabled{opacity:.5;cursor:not-allowed}.modal-confirm{background:var(--bg-button);border:2px solid var(--border-gold);color:var(--text-primary);padding:.5rem 1rem;cursor:pointer;font-size:.95rem;transition:all .2s}.modal-confirm:hover:not(:disabled){background:var(--bg-button-hover)}.modal-confirm.danger{background:linear-gradient(180deg,#8b0000,#5c0000);border-color:#f44;color:#fcc}.modal-confirm.danger:hover:not(:disabled){background:linear-gradient(180deg,#a00,#6c0000);border-color:#f66}.modal-confirm:disabled{opacity:.5;cursor:not-allowed}@media(max-width:480px){.modal-content{margin:1rem;max-width:calc(100% - 2rem)}.modal-actions{flex-direction:column-reverse}.modal-cancel,.modal-confirm{width:100%;padding:.75rem}}.tool-card-container{padding:12px;margin:8px 0;background:var(--bg-panel);border:2px solid var(--search-stone-border);box-shadow:inset 1px 1px #706b5a80,inset -1px -1px #3a362680,2px 2px #2a262080}.tool-card-list-wrapper{position:relative;max-height:200px}.tool-card-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px;max-height:200px;overflow-y:auto}.tool-card-fade-indicator{position:absolute;bottom:0;left:0;right:0;height:32px;background:linear-gradient(to bottom,transparent,var(--bg-panel));pointer-events:none;transition:opacity .2s ease}.tool-card-item{background:#00000026;border:1px solid rgba(0,0,0,.2);animation:tool-card-slide-in .3s ease-out}@keyframes tool-card-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.tool-card-header{display:flex;align-items:center;gap:8px;padding:8px 12px}.tool-card-icon{display:flex;align-items:center;justify-content:center;width:16px;height:16px;flex-shrink:0}.tool-card-name{font-family:MedievalSharp,cursive;font-size:.9rem;color:var(--text-gold);text-shadow:1px 1px 0 var(--shadow-text)}.tool-card-page{font-size:.85rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.tool-card-checkmark{display:inline-block;color:var(--text-gold);font-size:14px;font-weight:700}.tool-card-spinner{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.tool-card-spinner-ring{width:14px;height:14px;border:2px solid var(--spinner-track);border-top-color:var(--spinner-active);border-radius:50%;animation:tool-card-spinner-rotate .8s linear infinite}@keyframes tool-card-spinner-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tool-card-expand{margin-left:auto;padding:4px 8px;min-width:44px;min-height:44px;background:none;border:none;color:var(--text-muted);font-size:1rem;cursor:pointer;touch-action:manipulation;transition:color .2s ease}.tool-card-expand:hover{color:var(--text-gold)}.tool-card-expand:focus-visible{outline:2px solid var(--border-gold);outline-offset:2px}.tool-card-expand:focus:not(:focus-visible){outline:none}.tool-card-details{max-height:0;overflow:hidden;padding:0 12px;transition:max-height .3s ease,padding .3s ease}.tool-card-details.tool-card-details--expanded{max-height:500px;overflow:auto;padding:0 12px 12px}.tool-card-json{background:var(--bg-input);border:1px solid var(--border-primary);padding:12px;margin:0;font-family:monospace;font-size:12px;color:var(--text-muted);overflow-y:auto;max-height:200px;white-space:pre-wrap;word-break:break-word}.tool-card-no-inputs{font-size:.85rem;color:var(--text-muted);font-style:italic;margin:0}@media(prefers-reduced-motion:reduce){.tool-card-item,.tool-card-spinner-ring{animation:none!important}.tool-card-details{transition-duration:.01ms!important}}@media(max-width:768px){.tool-card-container{padding:10px;margin:6px 0}.tool-card-header{padding:6px 10px}.tool-card-name{font-size:.85rem}.tool-card-page{font-size:.8rem}.tool-card-json{font-size:11px;padding:10px}}:root{--bg-primary: #2E2C29;--bg-panel: #46433A;--bg-panel-dark: #3a3832;--bg-input: #2E2C29;--bg-button: #694D23;--bg-button-hover: #382D1A;--bg-message-user: #46433A;--bg-message-assistant: #694D23;--bg-root: #0d0d0d;--text-primary: #FFCF3F;--text-gold: #E6A519;--text-cyan: #00FFFF;--text-muted: #A0A0A0;--text-placeholder: #694D23;--text-error: #FF0000;--text-highlight: #FFDB70;--border-primary: #474745;--border-gold: #E6A519;--border-user: #694D23;--border-assistant: #E6A519;--border-root: #5a4a3a;--shadow-text: #0F0F0F;--shadow-box: rgba(0, 0, 0, .5);--shadow-glow: rgba(230, 165, 25, .3);--scrollbar-track: #2E2C29;--scrollbar-thumb: #694D23;--scrollbar-thumb-hover: #E6A519;--cursor-color: #E6A519;--spinner-track: #474745;--spinner-active: #E6A519;--search-bookshelf-bg: linear-gradient(180deg, #5a4a3a 0%, #3a2a1a 100%);--search-book-spine: #694D23;--search-magnifier-glow: rgba(230, 165, 25, .6);--search-rune-glow: rgba(230, 165, 25, .4);--search-stone-border: #5c5544;--search-parchment-bg: #d4c9a8;--search-parchment-text: #2a2620}[data-theme=dark]{--bg-primary: #1a1917;--bg-panel: #252321;--bg-panel-dark: #1f1d1b;--bg-input: #1a1917;--bg-button: #3d3529;--bg-button-hover: #2a241c;--bg-message-user: #252321;--bg-message-assistant: #3d3529;--bg-root: #0a0908;--text-primary: #E6A519;--text-gold: #FFCF3F;--text-cyan: #00DDDD;--text-muted: #888888;--text-placeholder: #4a4033;--text-highlight: #FFD966;--border-primary: #3a3632;--border-gold: #FFCF3F;--border-user: #4a4033;--border-assistant: #FFCF3F;--border-root: #3a3632;--shadow-text: #000000;--shadow-box: rgba(0, 0, 0, .7);--shadow-glow: rgba(255, 207, 63, .2);--scrollbar-track: #1a1917;--scrollbar-thumb: #3d3529;--scrollbar-thumb-hover: #FFCF3F;--cursor-color: #FFCF3F;--spinner-track: #3a3632;--spinner-active: #FFCF3F;--search-bookshelf-bg: linear-gradient(180deg, #3a3530 0%, #2a2520 100%);--search-book-spine: #3d3529;--search-magnifier-glow: rgba(255, 207, 63, .5);--search-rune-glow: rgba(255, 207, 63, .3);--search-stone-border: #3a3632;--search-parchment-bg: #c4b898;--search-parchment-text: #1a1a18}[data-theme=ancient-magicks]{--bg-primary: #1a0a2e;--bg-panel: #2d1b4e;--bg-panel-dark: #231540;--bg-input: #1a0a2e;--bg-button: #4a2882;--bg-button-hover: #351d5e;--bg-message-user: #2d1b4e;--bg-message-assistant: #4a2882;--bg-root: #0f051a;--text-primary: #9370DB;--text-gold: #DDA0DD;--text-cyan: #00CED1;--text-muted: #8B7B8B;--text-placeholder: #6B5B7B;--text-highlight: #E6E6FA;--text-error: #FF6B6B;--border-primary: #4a3870;--border-gold: #DDA0DD;--border-user: #5a4880;--border-assistant: #DDA0DD;--border-root: #4a3870;--shadow-text: #0a0515;--shadow-box: rgba(10, 5, 30, .7);--shadow-glow: rgba(148, 112, 219, .4);--scrollbar-track: #1a0a2e;--scrollbar-thumb: #4a2882;--scrollbar-thumb-hover: #9370DB;--cursor-color: #DDA0DD;--spinner-track: #4a3870;--spinner-active: #DDA0DD;--search-bookshelf-bg: linear-gradient(180deg, #2d1b4e 0%, #1a0a2e 100%);--search-book-spine: #4a2882;--search-magnifier-glow: rgba(148, 112, 219, .6);--search-rune-glow: rgba(148, 112, 219, .5);--search-stone-border: #4a3870;--search-parchment-bg: #c8bda8;--search-parchment-text: #1a1028}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:MedievalSharp,"Exo 2",Courier New,monospace;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;display:flex;justify-content:center;align-items:center;min-height:100vh}#root{width:100%;max-width:1200px;height:90vh;border:3px solid var(--border-root);background-color:var(--bg-root);display:flex;flex-direction:column;overflow:hidden;border-radius:5px;box-shadow:0 0 10px var(--shadow-box)}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--bg-primary);position:fixed;inset:0}.login-box{background:var(--bg-panel);padding:2rem;border:3px solid var(--border-primary);border-radius:0;box-shadow:inset 0 0 0 1px var(--shadow-box),0 4px 16px #000c;width:100%;max-width:400px;text-align:center}.login-logo{width:80px;height:80px;margin-bottom:1rem;filter:drop-shadow(2px 2px 2px var(--shadow-box))}.login-box h1{color:var(--text-primary);margin-bottom:.5rem;text-shadow:2px 2px 0 var(--shadow-text);font-weight:700;font-family:MedievalSharp,"Exo 2",monospace;letter-spacing:1px}.login-subtitle{color:var(--text-gold);margin-bottom:2rem;text-shadow:1px 1px 0 var(--shadow-text);font-size:.95rem;letter-spacing:.5px}.password-input{width:100%;padding:.75rem;background:var(--bg-input);color:var(--text-primary);border:2px solid var(--border-primary);border-radius:0;font-size:1rem;margin-bottom:1rem;transition:border-color .2s}.password-input:focus{outline:none;border-color:var(--border-gold);box-shadow:0 0 8px var(--shadow-glow)}.password-input::placeholder{color:var(--text-placeholder)}.login-button{width:100%;padding:.75rem;background:var(--bg-button);color:var(--text-primary);border:2px solid var(--border-primary);border-radius:0;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-shadow:1px 1px 0 var(--shadow-text)}.login-button:hover:not(:disabled){background:var(--bg-button-hover);border-color:var(--border-gold);box-shadow:0 0 8px var(--shadow-glow)}.login-button:disabled{opacity:.5;cursor:not-allowed}.error-message{color:var(--text-error);font-size:.875rem;margin-bottom:1rem;text-shadow:1px 1px 0 var(--shadow-text)}.oauth-buttons{display:flex;flex-direction:column;gap:1rem;width:100%}.oauth-button{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.75rem 1rem;border:2px solid var(--border-primary);border-radius:0;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-shadow:none}.oauth-button:disabled{opacity:.5;cursor:not-allowed}.oauth-button.google{background:#fff;color:#757575}.oauth-button.google:hover:not(:disabled){background:#f5f5f5;border-color:#4285f4;box-shadow:0 0 8px #4285f44d}.oauth-button.github{background:#24292e;color:#fff}.oauth-button.github:hover:not(:disabled){background:#2f363d;border-color:#fff;box-shadow:0 0 8px #fff3}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background:var(--bg-primary);color:var(--text-primary)}.spinner{width:50px;height:50px;border:4px solid var(--spinner-track);border-top-color:var(--spinner-active);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){#root{max-width:100%;height:100vh;max-height:100vh;border-radius:0;border-left:none;border-right:none}.login-box{margin:1rem;max-width:calc(100% - 2rem)}.login-button,.oauth-button{min-height:44px}}@media(max-width:480px){.login-box{padding:1.5rem;margin:.5rem;max-width:calc(100% - 1rem)}.login-box h1{font-size:1.5rem}.login-subtitle{font-size:.875rem;margin-bottom:1.5rem}.login-logo{width:60px;height:60px}.password-input{font-size:16px;min-height:44px}.login-button{min-height:44px}.oauth-button{min-height:44px;font-size:.9rem}}
