html[data-theme=day]{--bg-primary: #E3F2FD;--bg-secondary: #FAFBFC;--primary: #1976D2;--accent: #388E3C;--text-primary: #1A237E;--text-secondary: #546E7A;--user-bubble: #BBDEFB;--bot-bubble: #FFFFFF;--surface: rgba(255, 255, 255, .9);--border-subtle: rgba(25, 118, 210, .15);--border-input: rgba(25, 118, 210, .25);--shadow-subtle: 0 2px 8px rgba(0, 0, 0, .06);--table-header-bg: #f5f5f5;--table-even-bg: #fafafa;--table-border: #e0e0e0}html[data-theme=night]{--bg-primary: #0D2137;--bg-secondary: #0f172a;--primary: #42A5F5;--accent: #81C784;--text-primary: #F5F5F5;--text-secondary: #B0BEC5;--user-bubble: rgba(30, 58, 95, .9);--bot-bubble: #263238;--surface: rgba(30, 41, 59, .95);--border-subtle: rgba(66, 165, 245, .2);--border-input: rgba(66, 165, 245, .3);--shadow-subtle: 0 2px 12px rgba(0, 0, 0, .3);--table-header-bg: #37474F;--table-even-bg: #1e293b;--table-border: #455a64}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Nunito,Inter,sans-serif;height:100vh;overflow:hidden;transition:background .4s ease,color .4s ease}html[data-theme=day] body{background:linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 50%,#fff 100%);background-attachment:fixed;color:var(--text-primary)}html[data-theme=night] body{background:linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);background-attachment:fixed;color:var(--text-primary)}.app-container{display:flex;flex-direction:column;height:100vh;max-width:1200px;margin:0 auto;background:transparent;transition:background .4s ease}.header-logo{height:48px;width:auto;object-fit:contain;flex-shrink:0}.header{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);z-index:10;transition:background .4s ease,border-color .4s ease}.header h1{color:var(--primary);font-size:1.35rem;font-weight:700;font-family:Nunito,sans-serif}.controls{display:flex;gap:20px;align-items:center}.mode-selector{display:flex;gap:8px;background:var(--border-subtle);padding:5px;border-radius:12px}.mode-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:none;background:transparent;cursor:pointer;border-radius:8px;font-weight:600;font-family:Nunito,sans-serif;color:var(--text-secondary);transition:all .25s ease}.mode-btn:hover{color:var(--text-primary);background:var(--border-subtle)}.mode-btn.active{background:var(--primary);color:#fff;box-shadow:var(--shadow-subtle)}.theme-toggle,.reset-btn{background:transparent;border:none;cursor:pointer;color:var(--text-secondary);padding:.5rem;border-radius:50%;transition:color .2s,background .2s;display:flex;align-items:center;justify-content:center}.theme-toggle:hover,.reset-btn:hover{color:var(--primary);background:var(--border-subtle)}.header-actions{display:flex;align-items:center;gap:.5rem}.chat-area{flex:1;overflow-y:auto;padding:2rem;display:flex;flex-direction:column;gap:1.5rem;scroll-behavior:smooth}html[data-theme=day] .chat-area,html[data-theme=night] .chat-area{background:transparent}.chat-area::-webkit-scrollbar{width:8px}.chat-area::-webkit-scrollbar-track{background:var(--border-subtle);border-radius:4px}.chat-area::-webkit-scrollbar-thumb{background:var(--primary);border-radius:4px;opacity:.5}.chat-area::-webkit-scrollbar-thumb:hover{background:var(--primary)}.welcome-message{text-align:center;margin-top:2rem;color:var(--text-secondary)}.welcome-message h2{color:var(--primary);margin-bottom:.75rem;font-family:Nunito,sans-serif;font-size:1.5rem}.welcome-message p{color:var(--text-secondary);font-size:1rem}.welcome-message .tagline{margin-top:.5rem;font-size:.9rem;color:var(--accent);font-weight:600}.suggestions{display:flex;justify-content:center;gap:1rem;margin-top:2rem;flex-wrap:wrap}.suggestions button{padding:.75rem 1.5rem;border:1px solid var(--primary);background:var(--surface);color:var(--primary);border-radius:20px;cursor:pointer;font-family:Nunito,sans-serif;font-weight:600;transition:all .25s ease;box-shadow:var(--shadow-subtle)}.suggestions button:hover{background:var(--primary);color:#fff;transform:translateY(-1px)}.message{display:flex;width:100%}.message.user{justify-content:flex-end}.message.assistant{justify-content:flex-start}.message-content{max-width:80%;padding:1rem 1.5rem;border-radius:16px;line-height:1.6;font-size:15px;box-shadow:var(--shadow-subtle);transition:background .4s ease,border-color .4s ease,color .4s ease}.message.user .message-content{background:var(--user-bubble);border-top-right-radius:4px;color:var(--text-primary)}.message.assistant .message-content{background:var(--bot-bubble);border:1px solid var(--border-subtle);border-top-left-radius:4px;color:var(--text-primary)}.message-content p{margin-bottom:.5rem}.message-content ul,.message-content ol{margin-left:1.5rem;margin-bottom:.5rem}.message-content strong{color:var(--accent)}.message-content h1,.message-content h2,.message-content h3{color:var(--primary);margin-top:.75rem;margin-bottom:.5rem}.message-content table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.9rem}.message-content th,.message-content td{border:1px solid var(--table-border);padding:.75rem;text-align:left;color:var(--text-primary)}.message-content th{background:var(--table-header-bg);font-weight:600;color:var(--primary)}.message-content tr:nth-child(2n){background:var(--table-even-bg)}.sources-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-subtle);font-size:.9rem}.sources-section h4{color:var(--text-secondary);margin-bottom:.5rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.sources-section ul{list-style:none;margin:0;padding:0}.sources-section li{margin-bottom:.5rem;display:flex;align-items:center;flex-wrap:wrap;gap:.5rem}.source-index{font-weight:700;color:var(--accent);min-width:25px}.source-title{font-weight:500;color:var(--text-primary)}.source-link{display:inline-flex;align-items:center;gap:.25rem;color:var(--primary);text-decoration:none;font-size:.85rem;padding:.2rem .5rem;border-radius:4px;background:var(--border-subtle);transition:background .2s,text-decoration .2s}.source-link:hover{text-decoration:underline;background:var(--primary);color:#fff}.loading{display:flex;gap:.5rem;padding:1rem!important}.dot{width:8px;height:8px;background:var(--primary);border-radius:50%;animation:bounce 1.4s infinite ease-in-out both;opacity:.9}.dot:nth-child(1){animation-delay:-.32s}.dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.input-area{padding:1.5rem 2rem;background:var(--surface);border-top:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:background .4s ease,border-color .4s ease}.input-wrapper{display:flex;gap:1rem;background:var(--bot-bubble);padding:.5rem;border-radius:12px;border:1px solid var(--border-input);transition:border-color .25s,box-shadow .25s}.input-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 2px var(--border-subtle)}.input-wrapper textarea{flex:1;border:none;background:transparent;padding:.75rem;font-family:Nunito,Inter,sans-serif;font-size:1rem;resize:none;outline:none;max-height:100px;color:var(--text-primary)}.input-wrapper textarea::placeholder{color:var(--text-secondary)}.input-wrapper button{background:var(--primary);color:#fff;border:none;width:45px;height:45px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .25s,transform .2s}.input-wrapper button:hover:not(:disabled){filter:brightness(1.1);transform:scale(1.02)}.input-wrapper button:disabled{opacity:.5;cursor:not-allowed;transform:none}button:focus-visible,select:focus-visible,textarea:focus-visible,a:focus-visible{outline:2px solid var(--primary);outline-offset:2px}@media(max-width:768px){.header{padding:1rem;flex-direction:column;gap:1rem}.header h1{font-size:1.2rem}.controls{width:100%;justify-content:center}.mode-selector{width:100%;justify-content:space-between}.mode-btn{padding:.5rem .75rem;font-size:.9rem}.chat-area{padding:1rem}.message-content{max-width:92%}.suggestions{flex-direction:column;align-items:stretch}.suggestions button{width:100%}.input-area{padding:1rem}}
