:root{--bg-deep:#0a0a0c;--bg-surface:#121216;--bg-raised:#1a1a20;--bg-hover:#22222a;--border:#2a2a34;--border-subtle:#1e1e26;--text-primary:#e8e6e3;--text-secondary:#8a8894;--text-muted:#5a586a;--accent:#c9a55a;--accent-dim:#a08540;--accent-glow:#c9a55a14;--accent-glow-strong:#c9a55a26;--user-bubble:#1c1e2e;--assistant-bubble:#161618;--card-fact:#2a3a50;--card-preference:#3a2a50;--card-relationship:#2a4a3a;--card-commitment:#4a3a2a;--card-episode:#2a4a4a;--danger:#c05050;--success:#50a060;--radius:8px;--radius-lg:12px;--transition:.18s ease}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-deep);color:var(--text-primary);height:100vh;font-family:DM Sans,sans-serif;font-size:14px;line-height:1.6;overflow:hidden}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.btn{border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);cursor:pointer;transition:all var(--transition);letter-spacing:.02em;background:0 0;padding:6px 14px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:500}.btn:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-muted)}.btn-accent{border-color:var(--accent-dim);color:var(--accent)}.btn-accent:hover{background:var(--accent-glow);border-color:var(--accent)}.btn-sm{padding:4px 10px;font-size:11px}.btn-danger{border-color:var(--danger);color:var(--danger)}.btn-danger:hover{background:#c050501a}.field label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px;font-size:11px;font-weight:500;display:block}.field input,.field select,.field textarea{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-primary);transition:border-color var(--transition);outline:none;padding:7px 10px;font-family:JetBrains Mono,monospace;font-size:12px}.field input::placeholder,.field textarea::placeholder{color:var(--text-muted)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent-dim)}.field select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%235a586a'/%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;padding-right:28px}.field select option{background:var(--bg-raised);color:var(--text-primary)}.header{border-bottom:1px solid var(--border-subtle);background:var(--bg-surface);justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.header-left{align-items:center;gap:16px;display:flex}.logo{letter-spacing:.04em;color:var(--accent);font-family:Crimson Pro,serif;font-size:22px;font-weight:400}.logo span{color:var(--text-muted);letter-spacing:0;margin-left:10px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:400}.nav-link{color:var(--text-muted);transition:color var(--transition);font-size:12px;text-decoration:none}.nav-link:hover{color:var(--accent)}.header-actions{align-items:center;gap:8px;display:flex}@media (width<=768px){.header{padding:10px 14px}.header-actions{gap:4px}}.config-bar{background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);transition:max-height .3s,opacity .2s;overflow:hidden}.config-bar.open{opacity:1;max-height:300px}.config-inner{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;padding:16px 24px;display:grid}@media (width<=768px){.config-inner{grid-template-columns:1fr;padding:12px 14px}}.messages{scroll-behavior:smooth;flex:1;padding:24px;overflow-y:auto}.msg{margin-bottom:20px;animation:.3s both msgIn}@keyframes msgIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.msg-role{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:6px;font-size:11px;font-weight:500}.msg-user .msg-role{color:var(--accent-dim)}.msg-bubble{border-radius:var(--radius-lg);word-break:break-word;max-width:85%;padding:14px 18px;font-size:14px;line-height:1.7}.msg-bubble p{margin:0 0 8px}.msg-bubble p:last-child{margin-bottom:0}.msg-bubble code{background:var(--bg-deep);color:var(--accent);border-radius:4px;padding:2px 5px;font-family:JetBrains Mono,monospace;font-size:12px}.msg-bubble pre{background:var(--bg-deep);border:1px solid var(--border);border-radius:var(--radius);margin:8px 0;padding:12px;overflow-x:auto}.msg-bubble pre code{color:var(--text-primary);background:0 0;padding:0;font-size:12px;line-height:1.5}.msg-bubble ul,.msg-bubble ol{margin:8px 0;padding-left:20px}.msg-bubble li{margin:4px 0}.msg-bubble blockquote{border-left:3px solid var(--accent-dim);color:var(--text-secondary);margin:8px 0;padding:4px 12px}.msg-bubble table{border-collapse:collapse;margin:8px 0;font-size:13px}.msg-bubble th,.msg-bubble td{border:1px solid var(--border);padding:6px 10px}.msg-bubble th{background:var(--bg-raised);font-weight:500}.msg-bubble strong{color:var(--text-primary)}.msg-bubble em{color:var(--text-secondary)}.msg-bubble a{color:var(--accent);text-decoration:none}.msg-bubble a:hover{text-decoration:underline}.msg-user .msg-bubble{background:var(--user-bubble);border:1px solid #252740;border-bottom-right-radius:2px;margin-left:auto}.msg-assistant .msg-bubble{background:var(--assistant-bubble);border:1px solid var(--border-subtle);border-bottom-left-radius:2px}.msg-meta{color:var(--text-muted);gap:12px;margin-top:6px;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.msg-meta span{opacity:.7}.empty-state{height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.empty-state-icon{border:1px solid var(--border);width:48px;height:48px;color:var(--accent-dim);border-radius:50%;justify-content:center;align-items:center;font-family:Crimson Pro,serif;font-size:20px;display:flex}.empty-state p{font-size:13px}.cursor-blink{color:var(--accent);vertical-align:text-bottom;font-size:14px;line-height:1;animation:1s step-end infinite blink;display:inline}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}@media (width<=768px){.messages{padding:16px}.msg-bubble{max-width:95%}}.input-area{border-top:1px solid var(--border-subtle);background:var(--bg-surface);padding:16px 24px}.input-wrap{align-items:flex-end;gap:10px;display:flex}.input-wrap textarea{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius-lg);color:var(--text-primary);resize:none;min-height:44px;max-height:160px;transition:border-color var(--transition);outline:none;flex:1;padding:10px 14px;font-family:DM Sans,sans-serif;font-size:14px;line-height:1.6}.input-wrap textarea::placeholder{color:var(--text-muted)}.input-wrap textarea:focus{border-color:var(--accent-dim)}.send-btn{border-radius:var(--radius-lg);border:1px solid var(--accent-dim);background:var(--accent-glow);width:44px;height:44px;color:var(--accent);cursor:pointer;transition:all var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:flex}.send-btn:hover{background:var(--accent-glow-strong);border-color:var(--accent)}.send-btn:disabled{opacity:.3;cursor:not-allowed}.send-btn svg{width:18px;height:18px}@media (width<=768px){.input-area{padding:10px 14px}}.sidebar{background:var(--bg-surface);border-left:1px solid var(--border-subtle);z-index:201;flex-direction:column;width:320px;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;right:0;transform:translate(100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{z-index:200;background:#00000080;display:none;position:fixed;inset:0}.sidebar-overlay.active{display:block}.sidebar-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.sidebar-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:12px;font-weight:500}.card-count{color:var(--text-muted);background:var(--bg-raised);border-radius:10px;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:11px}.sidebar-cards{flex:1;padding:12px;overflow-y:auto}.memory-card{border-radius:var(--radius);border:1px solid var(--border-subtle);background:var(--bg-raised);transition:all var(--transition);margin-bottom:8px;padding:10px 12px;animation:.4s both cardIn}@keyframes cardIn{0%{opacity:0;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.memory-card:hover{border-color:var(--border);background:var(--bg-hover)}.memory-card.inactive{opacity:.4}.card-header{align-items:center;gap:6px;margin-bottom:6px;display:flex}.card-klass{text-transform:uppercase;letter-spacing:.08em;color:#fff;border-radius:3px;padding:1px 6px;font-size:10px;font-weight:600}.klass-fact{background:var(--card-fact)}.klass-preference{background:var(--card-preference)}.klass-relationship{background:var(--card-relationship)}.klass-commitment{background:var(--card-commitment)}.klass-episode{background:var(--card-episode)}.card-importance{color:var(--accent-dim);font-family:JetBrains Mono,monospace;font-size:10px}.card-badge{background:var(--bg-deep);color:var(--text-muted);border-radius:3px;margin-left:auto;padding:1px 5px;font-size:10px}.card-content{color:var(--text-secondary);font-size:13px;line-height:1.5}.card-time{color:var(--text-muted);opacity:.6;margin-top:4px;font-family:JetBrains Mono,monospace;font-size:10px}.sidebar-empty{height:200px;color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:20px;font-size:13px;line-height:1.6;display:flex}@media (width<=768px){.sidebar{width:300px}}.history-panel{background:var(--bg-surface);border-right:1px solid var(--border-subtle);z-index:201;flex-direction:column;width:300px;transition:transform .25s;display:flex;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.history-panel.open{transform:translate(0)}.history-overlay{z-index:200;background:#00000080;display:none;position:fixed;inset:0}.history-overlay.active{display:block}.history-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.history-header-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:12px;font-weight:500}.history-close{color:var(--text-muted);cursor:pointer;transition:color var(--transition);background:0 0;border:none;padding:0 4px;font-size:18px}.history-close:hover{color:var(--text-primary)}.history-list{flex:1;padding:8px;overflow-y:auto}.history-item{border-radius:var(--radius);cursor:pointer;transition:all var(--transition);border:1px solid #0000;align-items:center;gap:8px;margin-bottom:4px;padding:10px 12px;display:flex}.history-item:hover{background:var(--bg-hover);border-color:var(--border-subtle)}.history-item.active{background:var(--accent-glow);border-color:var(--accent-dim)}.history-item-info{flex:1;min-width:0}.history-item-id{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-family:JetBrains Mono,monospace;font-size:11px;overflow:hidden}.history-item-meta{color:var(--text-muted);margin-top:2px;font-size:10px}.history-item-actions{opacity:0;transition:opacity var(--transition);flex-shrink:0;gap:2px;display:flex}.history-item:hover .history-item-actions{opacity:1}.history-item-rename,.history-item-delete{color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:14px}.history-item-rename:hover{color:var(--accent);background:var(--accent-glow)}.history-item-delete:hover{color:var(--danger);background:#c050501a}.history-rename-input{background:var(--bg-deep);border:1px solid var(--accent-dim);width:100%;color:var(--text-primary);border-radius:4px;outline:none;padding:4px 8px;font-family:DM Sans,sans-serif;font-size:12px}.history-item-uuid{opacity:.6;font-family:JetBrains Mono,monospace;font-size:9px}.history-empty{height:120px;color:var(--text-muted);justify-content:center;align-items:center;font-size:13px;display:flex}.chat-app{flex-direction:column;height:100vh;display:flex}.chat-main{flex-direction:column;flex:1;min-height:0;display:flex}.btn-stream-on{border-color:var(--success);color:var(--success)}.typing-indicator{background:var(--assistant-bubble);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);border-bottom-left-radius:2px;gap:4px;padding:14px 18px;display:inline-flex}.typing-dot{background:var(--text-muted);border-radius:50%;width:6px;height:6px;animation:1.2s infinite typing}.typing-dot:nth-child(2){animation-delay:.15s}.typing-dot:nth-child(3){animation-delay:.3s}@keyframes typing{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}.admin-app{flex-direction:column;height:100vh;display:flex}.admin-key-bar{background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);padding:12px 24px}.admin-body{flex:1;grid-template-columns:220px 1fr;min-height:0;display:grid}.admin-nav{background:var(--bg-surface);border-right:1px solid var(--border-subtle);padding:8px;overflow-y:auto}.admin-nav-item{border-radius:var(--radius);width:100%;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:10px 12px;font-family:DM Sans,sans-serif;font-size:13px;display:flex}.admin-nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.admin-nav-item.active{background:var(--accent-glow);color:var(--accent);border:1px solid var(--accent-dim)}.nav-icon{text-align:center;width:20px;font-size:14px}.admin-content{padding:20px 24px;overflow-y:auto}.admin-section-content{grid-template-columns:1fr 1fr;gap:20px;height:100%;display:grid}.admin-form{flex-direction:column;gap:12px;display:flex}.admin-form textarea{resize:vertical;font-family:JetBrains Mono,monospace;font-size:12px}.admin-actions{flex-wrap:wrap;gap:8px;margin-top:8px;display:flex}.admin-response{flex-direction:column;display:flex}.response-header{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);justify-content:space-between;align-items:center;margin-bottom:8px;font-size:12px;font-weight:500;display:flex}.response-loading{color:var(--accent);font-size:11px}.response-body{background:var(--bg-raised);border:1px solid var(--border);border-radius:var(--radius);color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;flex:1;padding:16px;font-family:JetBrains Mono,monospace;font-size:12px;overflow:auto}@media (width<=900px){.admin-body{grid-template-columns:1fr}.admin-nav{border-right:none;border-bottom:1px solid var(--border-subtle);flex-direction:row;gap:4px;padding:8px 12px;display:flex;overflow-x:auto}.admin-nav-item{white-space:nowrap;padding:8px 12px}.admin-section-content{grid-template-columns:1fr}}
