*,*:before,*:after{box-sizing:border-box}body,html{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;margin:0;padding:0;height:100%;height:100dvh;width:100%;overflow:hidden;background-color:#000;color:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overscroll-behavior:none}.chat-container{height:100%;height:100dvh;width:100%;display:flex;flex-direction:column;position:relative;background-color:#000;padding-top:env(safe-area-inset-top);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.header{position:absolute;top:calc(12px + env(safe-area-inset-top,0px));left:calc(12px + env(safe-area-inset-left,0px));right:calc(12px + env(safe-area-inset-right,0px));z-index:1001;display:flex;align-items:center;justify-content:space-between}.logo{display:flex;align-items:center;gap:8px}.logo-icon{font-size:22px;font-weight:300;color:#fff;font-family:Times New Roman,Georgia,serif;letter-spacing:-1px}.logo-text{font-size:18px;font-weight:500;color:#fff;letter-spacing:.5px;background:linear-gradient(135deg,#fff,#888);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.icon-btn{background:#1e1e1ee6;border:1px solid #333;border-radius:50%;width:34px;height:34px;min-width:44px;min-height:44px;font-size:16px;cursor:pointer;color:#888;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.icon-btn:hover{background:#1a1a1a;color:#fff;border-color:#555}#settings-btn.icon-btn{width:32px;height:32px;min-width:32px;min-height:32px}#download-section{position:fixed;inset:0;width:100%;height:100%;max-width:none;background:#000000f2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:8px;z-index:2000;display:flex;flex-direction:column;opacity:0;pointer-events:none;transform:translateY(20px);transition:opacity .3s ease,transform .3s ease;border:none;border-radius:0;overflow-y:auto}#download-section.visible{opacity:1;pointer-events:auto;transform:translateY(0)}.settings-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #1a1a1a}.settings-header h2{font-size:20px;font-weight:600;margin:0;color:#fff;letter-spacing:-.5px}.close-btn{background:transparent;border:none;color:#888;padding:8px;cursor:pointer;border-radius:50%;transition:all .2s}.close-btn:hover{background:#222;color:#fff}#download-section p{margin:0 0 8px;font-size:12px;color:#888;text-transform:uppercase;letter-spacing:1px;font-weight:500}.download-container{display:flex;gap:12px;align-items:center;margin-bottom:24px}#model-selection{flex:1;min-width:0;background:#0a0a0a;border:1px solid #222;border-radius:12px;padding:14px 16px;color:#ccc;font-size:14px;appearance:none;cursor:pointer;overflow:hidden;text-overflow:ellipsis;height:48px;transition:all .2s ease;font-weight:500;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}#model-selection:focus{outline:none;border-color:#555;background-color:#111}#download{background:#0a0a0a;border:1px solid #222;border-radius:12px;width:48px;height:48px;min-width:48px;min-height:48px;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;color:#666;-webkit-tap-highlight-color:transparent;touch-action:manipulation}#download:hover:not(:disabled){background:#151515;border-color:#333;color:#fff}#download:disabled{opacity:.4;cursor:not-allowed}.settings-actions{margin-top:32px;padding-top:24px;border-top:1px solid #1a1a1a}.system-prompt-section{margin-top:24px}.system-prompt-section .settings-btn{justify-content:space-between;margin-bottom:0;padding:14px 16px;height:auto;min-height:48px}.system-prompt-section .chevron{width:16px;height:16px;transition:transform .2s ease}.system-prompt-section.open .chevron{transform:rotate(180deg)}#sys-prompt-editor{margin-top:16px;display:flex;flex-direction:column;gap:12px;margin-bottom:24px}#sys-prompt-input{width:100%;background:#0a0a0a;border:1px solid #222;border-radius:12px;color:#ccc;font-family:SF Mono,Monaco,monospace;font-size:13px;padding:16px;resize:vertical;min-height:160px;line-height:1.5}#sys-prompt-input:focus{outline:none;border-color:#444}.reset-link{background:none;border:none;color:#666;font-size:12px;cursor:pointer;align-self:flex-end;text-decoration:underline;padding:4px}.reset-link:hover{color:#999}.settings-btn{display:flex;align-items:center;gap:12px;width:100%;padding:14px 16px;background:#0a0a0a;border:1px solid #222;border-radius:12px;color:#888;font-size:14px;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;min-height:48px}.settings-btn:hover{background:#151515;border-color:#333;color:#fff}.settings-btn svg{width:18px;height:18px}.settings-option{display:flex;align-items:center;gap:12px;margin-top:24px;padding:4px 0;cursor:pointer}.settings-option input[type=checkbox]{width:18px;height:18px;accent-color:#fff}.settings-option span{font-size:14px;color:#bbb}.model-hint{margin:12px 0 0;font-size:12px;color:#555;text-align:left}#download-status{margin-top:16px;background:#0a0a0a;border:1px solid #1a1a1a;padding:12px 16px;border-radius:12px;font-size:12px;color:#888;word-break:break-word;line-height:1.4}#download-status.error{background:#1a0505;border-color:#311;color:#ff6b6b}.chat-box{flex:1;overflow-y:auto;padding:56px 12px 12px;display:flex;flex-direction:column;gap:10px}.chat-box::-webkit-scrollbar{width:6px}.chat-box::-webkit-scrollbar-track{background:transparent}.chat-box::-webkit-scrollbar-thumb{background:#333;border-radius:3px}.chat-stats{background:#0a0a0a;border-top:1px solid #1a1a1a;padding:8px 12px;font-size:10px;color:#555;font-family:SF Mono,Monaco,Courier New,monospace}.message-container{width:100%;display:flex}.message{padding:10px 14px;border-radius:16px;max-width:90%;font-size:14px;line-height:1.4}.message-container.user{justify-content:flex-end}.message-container.assistant{justify-content:flex-start}.message-container.user .message{background:linear-gradient(135deg,#2d2d2d,#1a1a1a);color:#fff;border:1px solid #333}.message-container.assistant .message{background:#111;color:#ccc;border:1px solid #222}.thinking-wrapper{width:100%}.thinking-toggle{display:flex;align-items:center;gap:8px;padding:10px 14px;background:linear-gradient(135deg,#1a1a1a,#0d0d0d);border:1px solid #2a2a2a;border-radius:12px;cursor:pointer;margin-bottom:8px;transition:all .2s ease}.thinking-toggle:hover{background:linear-gradient(135deg,#222,#111);border-color:#333}.thinking-toggle .thinking-icon{width:18px;height:18px;color:#666}.thinking-toggle .thinking-label{font-size:13px;color:#888;font-weight:500}.thinking-toggle .thinking-chevron{margin-left:auto;width:16px;height:16px;color:#555;transition:transform .2s ease}.thinking-toggle.expanded .thinking-chevron{transform:rotate(180deg)}.thinking-content{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;background:#0a0a0a;border-radius:10px;font-size:13px;color:#666;line-height:1.6;margin-bottom:8px}.thinking-content.expanded{max-height:300px;overflow-y:auto;padding:12px 14px;border:1px solid #1a1a1a}.thinking-content::-webkit-scrollbar{width:4px}.thinking-content::-webkit-scrollbar-thumb{background:#333;border-radius:2px}.loading-indicator{display:flex;align-items:center;justify-content:center;padding:12px 16px;background:linear-gradient(135deg,#1a1a1a,#0d0d0d);border:1px solid #2a2a2a;border-radius:16px;margin-bottom:8px}.loading-dots{display:flex;gap:4px}.loading-dots span{width:6px;height:6px;background:#555;border-radius:50%;animation:loadingPulse 1.4s ease-in-out infinite;will-change:opacity,transform}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes loadingPulse{0%,60%,to{opacity:.3;transform:scale(1)}30%{opacity:1;transform:scale(1.2)}}.thinking-indicator{display:flex;align-items:center;gap:8px;padding:12px 16px;background:linear-gradient(135deg,#1a1a1a,#0d0d0d);border:1px solid #2a2a2a;border-radius:16px;margin-bottom:8px}.thinking-dots{display:flex;gap:4px}.thinking-dots span{width:6px;height:6px;background:#555;border-radius:50%;animation:thinkingPulse 1.4s ease-in-out infinite}.thinking-dots span:nth-child(2){animation-delay:.2s}.thinking-dots span:nth-child(3){animation-delay:.4s}@keyframes thinkingPulse{0%,60%,to{opacity:.3;transform:scale(1)}30%{opacity:1;transform:scale(1.2)}}.thinking-text{font-size:11px;color:#666;font-style:italic}.response-content{padding:10px 14px;background:#111;border:1px solid #222;border-radius:16px;color:#ccc;font-size:14px;line-height:1.5}.response-content h1,.response-content h2,.response-content h3,.response-content h4,.response-content h5,.response-content h6{margin:16px 0 8px;color:#fff;font-weight:600;line-height:1.3}.response-content h1{font-size:1.5em}.response-content h2{font-size:1.3em}.response-content h3{font-size:1.15em}.response-content h4{font-size:1em}.response-content p{margin:8px 0}.response-content p:first-child{margin-top:0}.response-content p:last-child{margin-bottom:0}.response-content strong{color:#fff;font-weight:600}.response-content em{font-style:italic;color:#bbb}.response-content a{color:#6ea8fe;text-decoration:none}.response-content a:hover{text-decoration:underline}.response-content ul,.response-content ol{margin:8px 0;padding-left:24px}.response-content li{margin:4px 0}.response-content blockquote{margin:12px 0;padding:8px 16px;border-left:3px solid #444;background:#0a0a0a;border-radius:0 8px 8px 0;color:#999}.response-content hr{border:none;border-top:1px solid #333;margin:16px 0}.response-content code{font-family:SF Mono,Monaco,Cascadia Code,Courier New,monospace;font-size:.9em}.response-content :not(pre)>code{background:#1a1a1a;padding:2px 6px;border-radius:4px;color:#e06c75;border:1px solid #2a2a2a}.response-content pre{margin:12px 0;padding:0;border-radius:10px;overflow:hidden;background:#0d1117;border:1px solid #2a2a2a}.response-content pre code{display:block;padding:14px 16px;overflow-x:auto;line-height:1.5}.response-content pre code::-webkit-scrollbar{height:6px}.response-content pre code::-webkit-scrollbar-track{background:#0a0a0a}.response-content pre code::-webkit-scrollbar-thumb{background:#333;border-radius:3px}.response-content table{width:100%;border-collapse:collapse;margin:12px 0;font-size:13px}.response-content th,.response-content td{padding:10px 12px;border:1px solid #2a2a2a;text-align:left}.response-content th{background:#1a1a1a;color:#fff;font-weight:600}.response-content tr:nth-child(2n){background:#0a0a0a}.response-content .katex-display{margin:16px 0;padding:12px;background:#0a0a0a;border-radius:8px;overflow-x:auto;border:1px solid #1a1a1a}.response-content .katex{font-size:1.05em;color:#e0e0e0}.response-content .katex-display>.katex{text-align:center}.chat-input-container{padding:10px 12px calc(16px + env(safe-area-inset-bottom,0px)) 12px;background:#000;border-top:1px solid #111;display:flex;gap:8px;align-items:center;flex-shrink:0}#user-input{flex:1;min-width:0;background:#0a0a0a;border:1px solid #222;border-radius:20px;padding:12px 16px;color:#fff;font-size:16px;transition:all .2s ease;-webkit-tap-highlight-color:transparent}#user-input:focus{outline:none;border-color:#444;background:#111}#user-input::placeholder{color:#555}#send{background:linear-gradient(135deg,#333,#1a1a1a);border:1px solid #444;border-radius:50%;width:44px;height:44px;min-width:44px;min-height:44px;flex-shrink:0;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation}#send:hover:not(:disabled){background:linear-gradient(135deg,#444,#2a2a2a);border-color:#555;transform:scale(1.05)}#send:disabled{opacity:.3;cursor:not-allowed;transform:none}.settings-option{display:flex;align-items:center;gap:10px;margin-top:12px;padding-top:0;border-top:none;font-size:11px;color:#666;cursor:pointer}.settings-option input[type=checkbox]{appearance:none;-webkit-appearance:none;width:32px;height:18px;background:#1a1a1a;border:1px solid #333;border-radius:9px;cursor:pointer;position:relative;transition:all .2s ease}.settings-option input[type=checkbox]:before{content:"";position:absolute;top:2px;left:2px;width:12px;height:12px;background:#444;border-radius:50%;transition:all .2s ease}.settings-option input[type=checkbox]:checked{background:#333;border-color:#555}.settings-option input[type=checkbox]:checked:before{left:16px;background:#fff}.hidden{display:none!important}:root{--viewport-height: 100dvh}@supports (height: 100dvh){.chat-container{height:var(--viewport-height, 100dvh)}}@media(max-width:480px){.response-content pre code{font-size:12px;padding:12px}.response-content{font-size:15px}.message{font-size:15px;max-width:85%}#download-section{left:12px;right:12px;width:auto;max-width:none}.thinking-toggle{padding:12px 14px}.chat-box{-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.response-content .katex-display{overflow-x:auto;-webkit-overflow-scrolling:touch}#send,.mic-btn{width:38px;height:38px;min-width:38px;min-height:38px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.icon-btn:focus-visible,#send:focus-visible,#download:focus-visible,#user-input:focus-visible{outline:2px solid #666;outline-offset:2px}.mic-btn{background:#111;color:#888;border-color:#333;flex-shrink:0}.mic-btn:hover{background:#222;color:#fff}.mic-btn.listening{background:#3a1111;color:#ff6b6b;border-color:#f44;animation:pulse-red 1.5s infinite;will-change:box-shadow}@keyframes pulse-red{0%{box-shadow:0 0 #f446}70%{box-shadow:0 0 0 10px #f440}to{box-shadow:0 0 #f440}}.mic-btn i{width:20px;height:20px}.brain-section{margin-top:12px;padding:12px;background:#0a0a0a;border:1px solid #1a1a1a;border-radius:10px}.brain-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.brain-title{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:#888}.brain-title svg{width:14px;height:14px;color:#666}.brain-count{font-size:11px;color:#888;background:transparent;padding:0;border-radius:0;margin-left:auto;font-weight:500}.brain-stats{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;background:#0a0a0a;border:1px solid #1a1a1a;border-radius:12px;margin-bottom:12px}.brain-status{padding:0;background:transparent;border:none;border-radius:0;font-size:12px;color:#888;display:flex;align-items:center;min-height:auto;margin-bottom:8px;font-weight:500;width:100%}.brain-status.ready{color:#4ade80}.brain-status.ready:before{content:"";display:inline-block;width:8px;height:8px;background:#10b981;border-radius:50%;margin-right:8px;box-shadow:0 0 10px #10b98166}.brain-status.error{color:#ff6b6b}.brain-progress{margin-bottom:10px}.progress-bar{height:4px;background:#1a1a1a;border-radius:2px;overflow:hidden;margin-bottom:4px}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:2px;transition:width .3s ease;width:0%}.progress-text{font-size:9px;color:#555}.small-btn{padding:8px 10px;font-size:11px}.small-btn:disabled{opacity:.4;cursor:not-allowed}.small-btn svg{width:14px;height:14px}.brain-actions{display:flex;gap:12px;margin-top:16px;margin-bottom:24px}.brain-actions .settings-btn{flex:1;padding:12px;height:auto;min-height:42px}.danger-btn{color:#ff6b6b;border-color:#311}.danger-btn:hover{background:#1a0505;border-color:#f44}.brain-hint{font-size:9px;color:#444;margin:8px 0 0;text-align:center}
