@import"https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Geist+Mono:wght@300;400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0c0c10;--surface: #13131a;--surface-2: #1c1c26;--border: rgba(255,255,255,.07);--border-focus: rgba(255,255,255,.18);--accent: #e8d5b0;--accent-glow: rgba(232, 213, 176, .06);--text-primary: #f4f0e8;--text-secondary: #7a7a8c;--text-muted: #3a3a4a;--danger: #ff6b6b}html,body,#root{height:100%;width:100%}body{background:var(--bg);color:var(--text-primary);font-family:Geist Mono,monospace;overflow:hidden}.page{display:flex;flex-direction:column;height:100vh;width:100vw;position:relative}.page:before{content:"";position:fixed;bottom:0;left:50%;transform:translate(-50%);width:70vw;height:40vh;background:radial-gradient(ellipse at bottom,rgba(232,213,176,.04) 0%,transparent 70%);pointer-events:none;z-index:0}.topbar{display:flex;align-items:center;justify-content:space-between;padding:1.2rem 2rem;border-bottom:1px solid var(--border);flex-shrink:0;position:relative;z-index:10}.topbar-brand{font-family:"Instrument Serif",serif;font-size:1.15rem;color:var(--accent);letter-spacing:.01em}.topbar-meta{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-muted)}.output-area{flex:1;overflow-y:auto;padding:3rem 0 1.5rem;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1;scrollbar-width:thin;scrollbar-color:var(--surface-2) transparent}.output-area::-webkit-scrollbar{width:4px}.output-area::-webkit-scrollbar-track{background:transparent}.output-area::-webkit-scrollbar-thumb{background:var(--surface-2);border-radius:4px}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;animation:fadeUp .8s cubic-bezier(.22,1,.36,1) both;width:100%}.empty-icon{font-family:"Instrument Serif",serif;font-style:italic;font-size:3.5rem;color:var(--text-muted);line-height:1}.empty-title{font-family:"Instrument Serif",serif;font-size:1.6rem;color:var(--text-secondary)}.empty-sub{font-size:.65rem;letter-spacing:.12em;color:var(--text-muted);text-transform:uppercase}.message-wrap{width:100%;max-width:720px;padding:0 2rem;display:flex;flex-direction:column;gap:2.5rem}.message{display:flex;flex-direction:column;gap:.6rem;animation:fadeUp .4s cubic-bezier(.22,1,.36,1) both}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.message-role{font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);display:flex;align-items:center;gap:.5rem}.message-role:before{content:"";width:12px;height:1px;background:currentColor}.message-role.user{color:var(--accent)}.message-body{font-size:.9rem;line-height:1.8;color:var(--text-primary);white-space:pre-wrap;word-break:break-word}.message-image{max-width:260px;border-radius:10px;border:1px solid var(--border);opacity:.9;margin-top:.25rem}.thinking{display:flex;gap:5px;align-items:center;padding:.25rem 0}.thinking-dot{width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.3;animation:throb 1.2s ease-in-out infinite}.thinking-dot:nth-child(2){animation-delay:.2s}.thinking-dot:nth-child(3){animation-delay:.4s}@keyframes throb{0%,to{opacity:.2;transform:scale(.8)}50%{opacity:1;transform:scale(1.1)}}.stream-cursor{display:inline-block;width:2px;height:.85em;background:var(--accent);margin-left:2px;vertical-align:middle;animation:blink 1s step-end infinite}@keyframes blink{50%{opacity:0}}.input-dock{flex-shrink:0;padding:.75rem 2rem 1.5rem;display:flex;flex-direction:column;align-items:center;gap:.5rem;position:relative;z-index:10;background:linear-gradient(to top,var(--bg) 65%,transparent)}.input-shell{width:100%;max-width:720px;background:var(--surface);border:1px solid var(--border);border-radius:18px;transition:border-color .2s,box-shadow .2s;box-shadow:0 8px 40px #00000080}.input-shell:focus-within{border-color:var(--border-focus);box-shadow:0 8px 40px #0009,0 0 0 1px #e8d5b00f}.preview-strip{display:flex;align-items:center;gap:.6rem;padding:.75rem 1rem 0}.preview-thumb-wrap{position:relative;display:inline-flex}.preview-thumb{width:52px;height:52px;object-fit:cover;border-radius:8px;border:1px solid var(--border)}.preview-remove{position:absolute;top:-5px;right:-5px;width:18px;height:18px;border-radius:50%;background:var(--danger);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.55rem;color:#fff;transition:transform .15s}.preview-remove:hover{transform:scale(1.15)}.input-row{display:flex;align-items:flex-end;gap:.5rem;padding:.6rem .6rem .6rem 1rem}.text-input{flex:1;background:none;border:none;outline:none;resize:none;color:var(--text-primary);font-family:Geist Mono,monospace;font-size:.875rem;line-height:1.6;max-height:160px;overflow-y:auto;scrollbar-width:none;padding:.35rem 0}.text-input::placeholder{color:var(--text-muted)}.text-input::-webkit-scrollbar{display:none}.action-btn{flex-shrink:0;width:36px;height:36px;border-radius:10px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:background .15s,color .15s,border-color .15s,transform .1s}.action-btn:hover{background:var(--surface);color:var(--text-primary);border-color:var(--border-focus)}.action-btn:active{transform:scale(.93)}.file-btn-wrap{position:relative;flex-shrink:0}.file-btn-wrap input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}.send-btn{flex-shrink:0;width:36px;height:36px;border-radius:10px;border:none;background:var(--accent);color:var(--bg);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.85rem;transition:transform .15s,opacity .15s,box-shadow .15s;box-shadow:0 2px 12px #e8d5b02e}.send-btn:hover:not(:disabled){transform:scale(1.07);box-shadow:0 4px 20px #e8d5b052}.send-btn:active:not(:disabled){transform:scale(.94)}.send-btn:disabled{opacity:.3;cursor:not-allowed}.btn-spinner{width:14px;height:14px;border:2px solid rgba(12,12,16,.25);border-top-color:var(--bg);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.input-hint{font-size:.58rem;color:var(--text-muted);letter-spacing:.08em}
