:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;font-weight:400;color-scheme:light dark;color:#1a1a1a;background:linear-gradient(135deg,#f0fdfa,#ccfbf1);background-attachment:fixed;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary-color: #0f766e;--secondary-color: #0d9488;--accent-color: #14b8a6;--success-color: #059669;--warning-color: #d97706;--error-color: #dc2626;--text-primary: #0f172a;--text-secondary: #334155;--text-muted: #64748b;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--border-color: #e2e8f0;--emscale-primary: #0f766e;--emscale-secondary: #0d9488;--emscale-accent: #14b8a6;--emscale-light: #ccfbf1;--emscale-dark: #134e4a;--emscale-gray: #64748b;--emscale-light-gray: #f0fdfa;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem}a{font-weight:500;color:var(--emscale-primary);text-decoration:inherit}a:hover{color:var(--emscale-secondary)}body{margin:0;display:flex;flex-direction:column;min-width:320px;min-height:100vh;height:100vh;background:var(--bg-primary)}h1{font-size:1.75rem;line-height:1.2;font-weight:600;color:var(--text-primary);margin:0;letter-spacing:-.025em}.header-title{color:#01448e;align-self:flex-end;margin-bottom:0}#app{max-width:1200px;margin:0 auto;padding:1.5rem;width:100%;min-height:100vh;display:flex;flex-direction:column;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid var(--border-color)}.card{padding:2em}.read-the-docs{color:#888}button,.button{border-radius:var(--radius-md);border:1px solid transparent;padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-transform:none;letter-spacing:.025em;background:var(--emscale-primary);color:#fff}.button{padding:.75rem 1.5rem;margin:.25rem;border-radius:var(--radius-md);background:var(--emscale-primary);color:#fff;box-shadow:0 1px 2px #0000000d;border:none;font-weight:600;letter-spacing:.025em}.button:hover{transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;background:var(--emscale-secondary)}.button:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.button:focus,button:focus{outline:2px solid var(--accent-color);outline-offset:2px}button:disabled,.button:disabled{background:var(--bg-tertiary);color:var(--text-muted);cursor:not-allowed;opacity:.6;transform:none;box-shadow:none}.button.warning:disabled{background:#fbbf24;color:#92400e;opacity:.7}.button.secondary{background:var(--bg-primary);color:var(--emscale-primary);border:2px solid var(--emscale-primary)}.button.secondary:hover{background:var(--emscale-light);color:var(--emscale-dark);transform:translateY(-1px)}.button.warning{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.button.warning:hover{background:linear-gradient(135deg,#d97706,#b45309);transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.button.danger{background:linear-gradient(135deg,var(--error-color),#dc2626)}.button.danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}.button.success{background:linear-gradient(135deg,var(--success-color),#059669)}.button.success:hover{background:linear-gradient(135deg,#059669,#047857)}#status{padding:.75rem 1rem;margin:.5rem;border-radius:var(--radius-lg);position:sticky;top:0;z-index:100;font-weight:600;font-size:.875rem;display:inline-flex;align-items:center;gap:.5rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-sm);transition:all .3s ease}#status:before{content:"";width:8px;height:8px;border-radius:50%;display:inline-block;animation:pulse 2s infinite}.connected{background:linear-gradient(135deg,#10b9811a,#0596691a);color:var(--success-color);border-color:#10b98133}.connected:before{background-color:var(--success-color)}.disconnected{background:linear-gradient(135deg,#f59e0b1a,#d977061a);color:var(--warning-color);border-color:#f59e0b33}.disconnected:before{background-color:var(--warning-color)}.error{background:linear-gradient(135deg,#ef44441a,#dc26261a);color:var(--error-color);border-color:#ef444433}.error:before{background-color:var(--error-color)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}#chat-container{flex:1;overflow-y:auto;border:1px solid var(--border-color);margin:1rem 0;padding:2rem;border-radius:var(--radius-lg);display:flex;flex-direction:column;background:var(--bg-primary);box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;scroll-behavior:smooth}#chat-container::-webkit-scrollbar{width:6px}#chat-container::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:var(--radius-sm)}#chat-container::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-sm)}#chat-container::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.message{margin:.75rem 0;padding:1rem 1.25rem;border-radius:var(--radius-xl);position:relative;max-width:75%;box-shadow:var(--shadow-sm);word-wrap:break-word;animation:messageSlideIn .3s ease-out;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.message:hover{box-shadow:var(--shadow-md);transform:translateY(-1px);transition:all .2s ease}.user{background:var(--emscale-primary);color:#fff;align-self:flex-end;border-bottom-right-radius:var(--radius-sm);margin-left:auto;box-shadow:0 2px 4px #0000001a}.assistant{background:var(--emscale-light-gray);color:var(--text-primary);align-self:flex-start;border-bottom-left-radius:var(--radius-sm);margin-right:auto;border:1px solid var(--emscale-light)}.system{background:linear-gradient(135deg,#f59e0b1a,#d977061a);color:var(--warning-color);font-style:italic;max-width:90%;align-self:center;text-align:center;font-size:.875rem;border:1px solid rgba(245,158,11,.2)}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.role-label{font-size:.75em;color:#666;margin-bottom:4px;font-weight:700}.conversation-end{background-color:#f5f5f5b3;color:#666;font-style:italic;padding:8px 15px;border-radius:20px;margin:15px auto;text-align:center;max-width:60%;font-size:.9em}.message-content{line-height:1.4}#controls{position:fixed;bottom:0;left:0;right:0;padding:15px;box-shadow:0 -2px 5px #0000001a;display:flex;justify-content:center;gap:10px;z-index:100}@media (prefers-color-scheme: dark){:root{--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--border-color: #334155;--emscale-primary: #14b8a6;--emscale-secondary: #0d9488;--emscale-accent: #5eead4;--emscale-light: #134e4a;--emscale-dark: #0f766e;--emscale-gray: #94a3b8;--emscale-light-gray: #1e293b}body{background:linear-gradient(135deg,#0f172a,#1e293b)}#chat-container{background:var(--bg-secondary);border-color:var(--border-color)}.user{background:var(--emscale-primary);color:#fff}.assistant{background:var(--emscale-light-gray);color:var(--text-primary);border-color:var(--emscale-light)}.system{background:linear-gradient(135deg,#f59e0b33,#d9770633);color:#fbbf24;border-color:#f59e0b4d}.conversation-end{background:#374151b3;color:var(--text-muted)}.role-label{color:var(--text-muted)}.connected{background:linear-gradient(135deg,#10b98133,#05966933);color:#34d399;border-color:#10b9814d}.disconnected{background:linear-gradient(135deg,#f59e0b33,#d9770633);color:#fbbf24;border-color:#f59e0b4d}.error{background:linear-gradient(135deg,#ef444433,#dc262633);color:#f87171;border-color:#ef44444d}}@media (prefers-color-scheme: light){:root{color:var(--text-primary);background-color:var(--bg-primary)}a:hover{color:var(--emscale-secondary)}button{background-color:var(--emscale-primary);color:#fff}#chat-container,#controls{background-color:var(--bg-primary)}}@media (max-width: 1024px){#app{max-width:95%;padding:1rem}.header-top{flex-direction:column;align-items:stretch;gap:1rem}.header-actions{align-self:flex-end}.header-controls{flex-direction:column;align-items:stretch;gap:1rem}.session-controls,.button-container{justify-content:center}}@media (max-width: 768px){h1,.header-title{font-size:1.5rem}.message{max-width:85%;padding:.875rem 1rem}.button,button{padding:.5rem 1rem;font-size:.75rem}#app{padding:.75rem}.header{padding:1rem}.header-top{flex-direction:column;align-items:stretch;gap:.75rem}.header-actions{align-self:center;flex-wrap:wrap;justify-content:center}.header-controls{flex-direction:column;align-items:stretch;gap:.75rem}.session-controls{justify-content:center;flex-wrap:wrap;gap:.5rem}.button-container{justify-content:center;flex-wrap:wrap;gap:.25rem}.emscale-logo-img{height:2.5rem}}@media (max-width: 480px){h1{font-size:1.75rem}.header-subtitle{font-size:.8125rem}.message{max-width:90%;padding:.75rem .875rem}#chat-container{margin:.5rem 0;padding:1rem}.button,button{padding:.5rem 1rem;font-size:.75rem;margin:.125rem}#app{padding:.5rem}.header{padding:.75rem}.system-prompt-textarea{min-height:120px;font-size:.8125rem}.emscale-logo-img{height:2rem}.logo-container{gap:.75rem}}.header{display:flex;flex-direction:column;padding:1.5rem 2rem;margin-bottom:1.5rem;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:0 2px 8px #00000014;border:1px solid var(--border-color);position:relative;gap:1rem}.header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--emscale-primary),var(--emscale-secondary));border-radius:var(--radius-lg) var(--radius-lg) 0 0}.header-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.header-brand{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.header-actions{display:flex;gap:.5rem;flex-shrink:0;align-items:center}.logo-container{display:flex;align-items:flex-end;gap:.75rem;flex-wrap:nowrap}.emscale-logo-img{height:3rem;width:auto;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));transition:transform .3s ease}.emscale-logo-img:hover{transform:scale(1.05)}.header-subtitle{font-size:1rem;color:var(--emscale-secondary);margin:0;font-weight:500;letter-spacing:.025em}.header-controls{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap}.session-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.timer-container{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color);font-weight:600;color:var(--text-primary)}.timer-icon{font-size:1.25rem;animation:tick 1s infinite}@keyframes tick{0%,50%{transform:rotate(0)}25%{transform:rotate(15deg)}75%{transform:rotate(-15deg)}}.button-container{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center;justify-content:flex-end}#system-prompt-container{margin:1rem 0 1.5rem;padding:2rem;border-radius:var(--radius-lg);background:var(--bg-primary);transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid var(--border-color);box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;position:relative}#system-prompt-container:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--emscale-primary),var(--emscale-secondary));border-radius:var(--radius-lg) var(--radius-lg) 0 0}#system-prompt-container h2{margin-top:0;margin-bottom:1.5rem;font-size:1.5rem;font-weight:700;color:var(--emscale-primary);letter-spacing:-.025em}.editor-container{display:flex;flex-direction:column;gap:1rem}.system-prompt-textarea{width:100%;min-height:200px;padding:1rem;border:1px solid var(--border-color);border-radius:var(--radius-lg);font-family:JetBrains Mono,Fira Code,Consolas,monospace;font-size:.875rem;resize:vertical;background:var(--bg-secondary);color:var(--text-primary);transition:all .2s ease;line-height:1.6}.system-prompt-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.prompt-controls{display:flex;justify-content:flex-end;gap:.5rem}#save-confirmation{color:var(--success-color);font-weight:600;padding:.5rem 1rem;margin-bottom:.5rem;background:#10b9811a;border-radius:var(--radius-md);border:1px solid rgba(16,185,129,.2);animation:fadeInOut 2s ease-in-out}@keyframes fadeInOut{0%,to{opacity:0;transform:translateY(-10px)}20%,80%{opacity:1;transform:translateY(0)}}@media (prefers-color-scheme: dark){#system-prompt-container{background-color:#2d3436;color:#b2bec3}.system-prompt-textarea{background-color:#1e1e1e;color:#e4e4e4;border-color:#333}#save-confirmation{color:#a5d6a7}}@media (max-width: 768px){.header{flex-direction:column;align-items:flex-start}.header-controls{flex-direction:column;align-items:flex-start;width:100%;margin-top:10px}.button-container{width:100%;justify-content:space-between}.system-prompt-textarea{min-height:150px}}.footer{background:var(--bg-primary);color:var(--text-muted);text-align:center;padding:1rem;margin-top:auto;border-radius:var(--radius-lg);border:1px solid var(--border-color);font-size:.875rem;font-weight:500}.message.assistant{text-align:left;align-self:flex-start}.message.user{text-align:right;align-self:flex-end}.message.assistant .message-content{text-align:left}.message.user .message-content{text-align:right}.message.user{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));color:#fff;margin-left:auto;border-bottom-right-radius:var(--radius-sm);box-shadow:var(--shadow-md)}.message.assistant{background:var(--bg-primary);color:var(--text-primary);margin-right:auto;border-bottom-left-radius:var(--radius-sm);border:1px solid var(--border-color)}.message-time{display:none}@media (prefers-color-scheme: dark){.message.assistant{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}}@media (max-width: 768px){.system-prompt-textarea{min-height:150px}}
