.chat-container{display:flex;flex-direction:column;min-height:100%}.api-error{background:#ef44441a;border:1px solid rgba(239,68,68,.5);border-radius:8px;padding:1rem;margin:1rem 2rem 0;color:#fca5a5;text-align:center}.chat-messages{flex:1;padding:2rem;display:flex;flex-direction:column;gap:1.5rem;max-width:900px;width:100%;margin:0 auto}.welcome-message{text-align:center;padding:2rem;color:#d1d5db}.welcome-text{font-size:1.2rem;margin-bottom:2rem;color:#a78bfa}.example-questions{background:#6b46c11a;border:1px solid rgba(107,70,193,.3);border-radius:8px;padding:1.5rem;max-width:500px;margin:0 auto}.example-title{font-weight:600;color:#c4b5fd;margin-bottom:1rem}.example-questions ul{list-style:none;padding:0}.example-questions li{padding:.5rem 0;color:#9ca3af;font-style:italic}.message{display:flex;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.user-message{justify-content:flex-end}.assistant-message{justify-content:flex-start}.message-content{display:flex;align-items:flex-start;gap:.75rem;max-width:80%}.message-icon{font-size:1.5rem;flex-shrink:0;filter:drop-shadow(0 0 8px rgba(107,70,193,.6))}.message-text{padding:1rem 1.25rem;border-radius:12px;line-height:1.6}.message-text:has(.typing-indicator){padding:0;background:transparent;border:none}.message-text .mana-symbol{display:inline-block;width:1.2em;height:1.2em;vertical-align:middle;margin:0 .1em}.message-text .card-image-container{margin:.5em 0 1em;display:flex;justify-content:flex-start}.message-text .card-image{max-width:200px;width:100%;height:auto;border-radius:12px;box-shadow:0 4px 12px #00000080;transition:transform .2s ease,box-shadow .2s ease}.message-text .card-image:hover{transform:scale(1.05);box-shadow:0 6px 20px #6b46c166;cursor:pointer}.card-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:9999;cursor:pointer;animation:fadeIn .2s ease-in;padding:40px 20px 20px}.card-modal-content{position:relative;max-width:90vw;max-height:90vh;cursor:default}.card-modal-image{max-width:100%;max-height:calc(90vh - 40px);height:auto;border-radius:16px;box-shadow:0 8px 32px #000c}.card-modal-close{position:absolute;top:-40px;right:-40px;background:#6b46c1cc;border:2px solid rgba(107,70,193,.5);color:#fff;font-size:32px;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;transition:background .2s ease,transform .2s ease}.card-modal-close:hover{background:#6b46c1;transform:scale(1.1)}@media(max-width:768px){.card-modal-close{top:10px;right:10px}}.message-text h1,.message-text h2,.message-text h3{font-weight:600;margin:.5em 0 .25em;line-height:1.3}.message-text h1:first-child,.message-text h2:first-child,.message-text h3:first-child{margin-top:0}.message-text h1{font-size:1.4em}.message-text h2{font-size:1.25em}.message-text h3{font-size:1.1em}.message-text .section-separator{border:none;border-top:2px solid rgba(107,70,193,.3);margin:1.5em 0}.message-text p{margin:0;line-height:1.6}.message-text p:first-child{margin-top:0}.message-text p:last-child{margin-bottom:0}.message-text strong{font-weight:700;color:#c4b5fd}.message-text .list-item{display:flex;gap:.5em;margin:.5em 0;line-height:1.6;align-items:flex-start}.message-text .list-item .list-marker{flex-shrink:0;font-weight:600;color:#a78bfa;min-width:1.2em;text-align:center}.message-text .list-item.numbered .list-marker{min-width:1.5em;text-align:right}.message-text p+p{margin-top:.5em}.message-text h3+p,.message-text h2+p,.message-text h1+p{margin-top:.1em}.message-text .list-item+p,.message-text p+.list-item{margin-top:.5em}.user-message .message-text{background:linear-gradient(135deg,#6b46c1,#7c3aed);color:#fff;border-bottom-right-radius:4px}.assistant-message .message-text{background:#6b46c126;color:#e5e7eb;border:1px solid rgba(107,70,193,.3);border-bottom-left-radius:4px}.typing-indicator{display:flex;gap:.4rem;padding:1rem 1.25rem;background:#6b46c126;border:1px solid rgba(107,70,193,.3);border-radius:12px 12px 12px 4px}.typing-indicator span{width:8px;height:8px;background:#a78bfa;border-radius:50%;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.chat-input-form{display:flex;gap:1rem;padding:1.5rem 2rem;max-width:900px;width:100%;margin:0 auto}.chat-input{flex:1;padding:.875rem 1.25rem;background:#6b46c11a;border:2px solid rgba(107,70,193,.3);border-radius:8px;color:#fff;font-size:1rem;outline:none;transition:border-color .2s ease,background .2s ease}.chat-input:focus{border-color:#7c3aed;background:#6b46c126}.chat-input::placeholder{color:#6b7280}.chat-input:disabled{opacity:.5;cursor:not-allowed}.chat-submit{padding:.875rem 2rem;background:linear-gradient(135deg,#6b46c1,#7c3aed);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 4px 12px #6b46c14d}.chat-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #6b46c166}.chat-submit:active:not(:disabled){transform:translateY(0)}.chat-submit:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.chat-messages{padding:1rem;gap:1rem}.message-content{max-width:90%}.message-text{padding:.75rem 1rem;font-size:.95rem}.chat-input-form{padding:1rem;gap:.75rem}.chat-submit{padding:.875rem 1.5rem}}.header{background:linear-gradient(135deg,#1a0033,#2d1b69,#1a0033);border-bottom:2px solid #6b46c1;padding:1rem 1.5rem;box-shadow:0 4px 20px #6b46c14d;position:sticky;top:0;z-index:100}.header-content{display:flex;align-items:center;gap:1rem}.header-content .logo{flex:1}.sidebar-toggle{background:transparent;border:none;color:#fff;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .2s ease}.sidebar-toggle:hover{background:#6b46c14d}.back-link{display:flex;align-items:center;gap:.5rem;color:#fff;text-decoration:none;font-size:1rem;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:all .2s ease;white-space:nowrap}.back-link:hover{background:#6b46c14d;text-shadow:0 0 10px rgba(107,70,193,.6)}.sidebar-toggle-spacer{width:40px;height:40px;flex-shrink:0}.logo{display:flex;align-items:center;gap:0;text-decoration:none;cursor:pointer;transition:opacity .2s ease}.logo:hover{opacity:.9}.wizard-icon{width:3rem;height:3rem;filter:drop-shadow(0 0 10px rgba(107,70,193,.8))}.title{font-size:1.5rem;font-weight:600;color:#fff;text-shadow:0 0 20px rgba(107,70,193,.8),0 0 40px rgba(107,70,193,.4);letter-spacing:.02em}.about-link{color:#fff;text-decoration:none;font-size:1rem;font-weight:500;padding:.5rem 1rem;border-radius:6px;transition:all .2s ease;white-space:nowrap}.about-link:hover{background:#6b46c14d;text-shadow:0 0 10px rgba(107,70,193,.6)}@media(max-width:768px){.header{padding:.875rem 1rem}.wizard-icon{width:2.5rem;height:2.5rem}.title{font-size:1.25rem}.about-link,.back-link{font-size:.875rem;padding:.375rem .75rem}}.sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:90;display:none}.sidebar{width:280px;min-width:280px;background:linear-gradient(180deg,#0a0014,#1a0033);border-right:2px solid #6b46c1;display:flex;flex-direction:column;transition:margin-left .3s ease,min-width .3s ease;position:relative;z-index:95;flex-shrink:0}.sidebar.closed{margin-left:-280px;min-width:0;border-right:none}.sidebar-content{display:flex;flex-direction:column;height:100%;padding:1rem;overflow:hidden}.new-chat-btn{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:#6b46c133;border:1px solid rgba(107,70,193,.4);border-radius:8px;color:#fff;font-size:.95rem;cursor:pointer;transition:all .2s ease;width:100%}.new-chat-btn:hover{background:#6b46c14d;border-color:#6b46c199}.sidebar-divider{border:none;border-top:1px solid rgba(107,70,193,.3);margin:1.5rem 0;flex-shrink:0}.tips-section{flex:0 1 auto;display:flex;flex-direction:column;overflow-y:auto;margin:0;padding:1.25rem;background:#6b46c11a;border:1px solid rgba(107,70,193,.2);border-radius:8px;min-height:60px}.tips-section h3{font-size:.9rem;color:#b794f4;font-weight:600;margin-bottom:1rem;margin-top:0}.tips-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.tips-list li{color:#d1d5db;font-size:.85rem;line-height:1.4;padding-left:.5rem;list-style:disc;margin-left:1rem}.sidebar-section::-webkit-scrollbar{width:6px}.sidebar-section::-webkit-scrollbar-track{background:transparent}.sidebar-section::-webkit-scrollbar-thumb{background:#6b46c14d;border-radius:3px}.section-header{margin-bottom:.75rem}.section-header h3{font-size:.85rem;color:#9ca3af;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.chat-history{display:flex;flex-direction:column;gap:.5rem}.empty-state{padding:2rem 1rem;text-align:center}.empty-state p{color:#6b7280;font-size:.9rem;line-height:1.5}.sidebar-bottom{display:flex;flex-direction:column;gap:.75rem;padding-top:0;border-top:none}.support-link{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .3s ease;width:100%}.coffee-link{background:linear-gradient(135deg,#fd0,#fbb034);color:#1a0033}.coffee-link:hover{transform:translateY(-2px);box-shadow:0 6px 16px #fd06}.discord-link{background:linear-gradient(135deg,#5865f2,#7289da);color:#fff}.discord-link:hover{transform:translateY(-2px);box-shadow:0 6px 16px #5865f266}.support-link span{font-size:1rem}.sidebar-footer{margin-top:0;border-top:none}.sidebar-footer .footer{background:transparent;border:none;padding:0rem 0;margin:0}.sidebar-footer .footer-content{max-width:100%}.sidebar-footer .fan-content-notice{margin-bottom:.75rem}.sidebar-footer .fan-content-notice p{font-size:.75rem;line-height:1.4}.sidebar-footer .footer-meta{padding-top:.75rem}.sidebar-footer .footer-meta p{font-size:.7rem}@media(max-width:768px){.sidebar-overlay{display:block}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar.closed{transform:translate(-100%)}}@media(min-width:769px){.sidebar-overlay{display:none!important}}.footer{background-color:#0a0014;border-top:2px solid #6b46c1;padding:2rem 1rem;margin-top:auto}.footer-content{max-width:1200px;margin:0 auto;text-align:center}.fan-content-notice{margin-bottom:1rem}.fan-content-notice p{font-size:.9rem;color:#9ca3af;line-height:1.6;max-width:800px;margin:0 auto}.policy-link{color:#a78bfa;text-decoration:none;font-weight:500;transition:color .2s ease}.policy-link:hover{color:#c4b5fd;text-decoration:underline}.footer-meta{padding-top:1rem;border-top:1px solid #1f1f1f}.footer-meta p{font-size:.85rem;color:#6b7280}@media(max-width:768px){.footer{padding:1.5rem 1rem}.fan-content-notice p{font-size:.85rem}}.about-page{display:flex;justify-content:center;align-items:flex-start;padding:2rem 1rem;overflow-y:auto;height:100%;width:100%}.about-content{max-width:95%;width:100%;background:#1a003366;border-radius:12px;padding:2.5rem;box-shadow:0 8px 32px #6b46c133;border:1px solid rgba(107,70,193,.3);height:fit-content}.about-content p{color:#e0e0e0;font-size:1rem;line-height:1.5;margin-bottom:1.5rem}.about-content ul{color:#e0e0e0;font-size:1rem;line-height:1.5;margin:1rem 0 1.5rem 2rem;list-style-type:disc}.about-content ul li{margin-bottom:.5rem}.about-content strong{color:#b794f4;font-weight:600}.support-buttons{display:flex;gap:1rem;margin:2rem 0;flex-wrap:wrap}.support-button{display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;text-decoration:none;transition:all .3s ease;box-shadow:0 4px 12px #0000004d}.coffee-button{background:linear-gradient(135deg,#fd0,#fbb034);color:#1a0033}.coffee-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #fd06}.discord-button{background:linear-gradient(135deg,#5865f2,#7289da);color:#fff}.discord-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #5865f266}.support-button span{font-size:1.25rem}.divider{border:none;border-top:1px solid rgba(107,70,193,.4);margin:2.5rem 0}.copyright-notice{background:#6b46c11a;border-left:3px solid #6b46c1;padding:1.5rem;border-radius:6px}.copyright-notice h2{font-size:1.25rem;margin-bottom:1rem}.copyright-notice p{font-size:.95rem;margin-bottom:1rem}.copyright-notice p:last-child{margin-bottom:0}@media(max-width:768px){.about-page{padding:1rem}.about-content{padding:1.5rem}.about-content h1{font-size:2rem}.about-content p,.about-content ul{font-size:1rem}.support-buttons{flex-direction:column}.support-button{width:100%;justify-content:center}}.app{height:100vh;display:flex;flex-direction:column;background-color:#000}.app-body{flex:1;display:flex;overflow:hidden;min-height:0}.main{flex:1;display:flex;flex-direction:column;overflow-y:auto;width:100%;min-height:0;background:linear-gradient(180deg,#0a0014,#1a0033)}.main::-webkit-scrollbar{width:8px}.main::-webkit-scrollbar-track{background:#1a0033}.main::-webkit-scrollbar-thumb{background:#6b46c1;border-radius:4px}.main::-webkit-scrollbar-thumb:hover{background:#7c3aed}@media(max-width:768px){.app-body{flex-direction:column}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#000;color:#fff}#root{min-height:100vh;display:flex;flex-direction:column}
