pre code.hljs{display:block;overflow-x:auto;padding:1em}code.hljs{padding:3px 5px}/*!
  Theme: GitHub Dark
  Description: Dark theme as seen on github.com
  Author: github.com
  Maintainer: @Hirse
  Updated: 2021-05-15

  Outdated base version: https://github.com/primer/github-syntax-dark
  Current colors taken from GitHub's CSS
*/.hljs{color:#c9d1d9;background:#0d1117}.hljs-doctag,.hljs-keyword,.hljs-meta .hljs-keyword,.hljs-template-tag,.hljs-template-variable,.hljs-type,.hljs-variable.language_{color:#ff7b72}.hljs-title,.hljs-title.class_,.hljs-title.class_.inherited__,.hljs-title.function_{color:#d2a8ff}.hljs-attr,.hljs-attribute,.hljs-literal,.hljs-meta,.hljs-number,.hljs-operator,.hljs-variable,.hljs-selector-attr,.hljs-selector-class,.hljs-selector-id{color:#79c0ff}.hljs-regexp,.hljs-string,.hljs-meta .hljs-string{color:#a5d6ff}.hljs-built_in,.hljs-symbol{color:#ffa657}.hljs-comment,.hljs-code,.hljs-formula{color:#8b949e}.hljs-name,.hljs-quote,.hljs-selector-tag,.hljs-selector-pseudo{color:#7ee787}.hljs-subst{color:#c9d1d9}.hljs-section{color:#1f6feb;font-weight:700}.hljs-bullet{color:#f2cc60}.hljs-emphasis{color:#c9d1d9;font-style:italic}.hljs-strong{color:#c9d1d9;font-weight:700}.hljs-addition{color:#aff5b4;background-color:#033a16}.hljs-deletion{color:#ffdcd7;background-color:#67060c}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica Neue,sans-serif}button{cursor:pointer;font-family:inherit}textarea,input{font-family:inherit}a{color:inherit;text-decoration:none}:root,[data-theme=dark]{--bg: #212121;--sidebar-bg: #171717;--surface: #2f2f2f;--surface-hover:#383838;--border: #3d3d3d;--text: #ececec;--text-secondary: #b4b4b4;--muted: #8e8ea0;--accent: #6366f1;--accent-hover: #4f46e5;--accent-dim: rgba(99,102,241,.15);--user-msg: #2f2f2f;--input-bg: #2f2f2f;--input-border: #555;--code-bg: #1a1a1a;--code-border: #333;--scrollbar: #444;--danger: #ef4444;--danger-bg: rgba(239,68,68,.1);--success: #22c55e;--shadow: 0 8px 32px rgba(0,0,0,.5);--shadow-sm: 0 2px 8px rgba(0,0,0,.3);--toggle-off: #3d3d3d}[data-theme=light]{--bg: #f9f9f9;--sidebar-bg: #ffffff;--surface: #ffffff;--surface-hover:#f3f4f6;--border: #e5e7eb;--text: #0d0d0d;--text-secondary: #374151;--muted: #6b7280;--accent: #6366f1;--accent-hover: #4f46e5;--accent-dim: rgba(99,102,241,.08);--user-msg: #f0f0f0;--input-bg: #ffffff;--input-border: #d1d5db;--code-bg: #f6f8fa;--code-border: #e5e7eb;--scrollbar: #d1d5db;--danger: #ef4444;--danger-bg: rgba(239,68,68,.06);--success: #16a34a;--shadow: 0 8px 32px rgba(0,0,0,.1);--shadow-sm: 0 2px 8px rgba(0,0,0,.06);--toggle-off: #d1d5db}#root{height:100%;background:var(--bg);color:var(--text);transition:background .2s,color .2s}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--scrollbar);border-radius:10px}.app-layout{display:flex;height:100%;overflow:hidden}.sidebar{width:260px;min-width:260px;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100%;transition:background .2s,border-color .2s}.sidebar-header{padding:16px 12px 10px}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:6px 4px;margin-bottom:8px}.sidebar-brand-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--accent),#8b5cf6);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.sidebar-brand-name{font-size:16px;font-weight:700;color:var(--text)}.new-chat-btn{width:100%;display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:14px;font-weight:500;transition:background .15s,border-color .15s}.new-chat-btn:hover{background:var(--surface-hover);border-color:var(--accent)}.new-chat-btn svg{opacity:.7}.conv-list{flex:1;overflow-y:auto;padding:4px 8px}.conv-date-label{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:12px 8px 4px}.conv-item{display:flex;align-items:center;padding:9px 10px;border-radius:8px;cursor:pointer;gap:8px;position:relative;transition:background .12s;margin-bottom:1px}.conv-item:hover{background:var(--surface-hover)}.conv-item.active{background:var(--accent-dim)}.conv-item.active .conv-title{color:var(--accent)}.conv-icon{font-size:14px;flex-shrink:0;opacity:.6}.conv-title{flex:1;font-size:13.5px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conv-del{background:none;border:none;color:var(--muted);font-size:13px;padding:3px 5px;border-radius:5px;line-height:1;flex-shrink:0;transition:color .15s;cursor:pointer}.conv-del:hover{color:var(--danger)}.conv-actions{display:flex;gap:2px}.conv-item:hover .conv-actions{opacity:1!important}.sidebar-footer{padding:8px 8px 12px;border-top:1px solid var(--border)}.sidebar-user{display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;font-size:13px;color:var(--muted);margin-bottom:4px}.sidebar-user-avatar{width:26px;height:26px;background:var(--accent-dim);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--accent);flex-shrink:0}.sidebar-user-email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-action{display:flex;align-items:center;gap:9px;width:100%;padding:9px 10px;border-radius:8px;background:none;border:none;color:var(--text-secondary);font-size:13.5px;text-align:left;transition:background .12s,color .12s}.sidebar-action:hover{background:var(--surface-hover);color:var(--text)}.sidebar-action.danger:hover{color:var(--danger);background:var(--danger-bg)}.main-area{flex:1;display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg)}.welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:8px;padding:32px 40px 40px;overflow-y:auto}.welcome:before{content:"";flex:1 0 0;max-height:40px}.welcome:after{content:"";flex:1 0 0;max-height:40px}.welcome-icon{font-size:48px;margin-bottom:4px}.welcome-title{font-size:26px;font-weight:700;color:var(--text);text-align:center}.welcome-sub{font-size:15px;color:var(--muted);text-align:center}.welcome-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:16px;max-width:520px}.chip{padding:8px 16px;border-radius:20px;background:var(--surface);border:1px solid var(--border);font-size:13.5px;color:var(--text-secondary);cursor:pointer;transition:border-color .15s,color .15s}.chip:hover{border-color:var(--accent);color:var(--accent)}.welcome-files{margin-top:20px;width:100%;max-width:560px}.welcome-files-title{font-size:13px;font-weight:600;color:var(--muted);text-align:center;letter-spacing:.04em;margin-bottom:10px;text-transform:uppercase}.welcome-files-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.file-cap-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:var(--surface);border:1px solid var(--border);transition:border-color .15s,background .15s}.file-cap-item:hover{border-color:var(--accent);background:var(--accent-dim)}.file-cap-icon{font-size:20px;flex-shrink:0}.file-cap-info{display:flex;flex-direction:column;flex:1;min-width:0}.file-cap-info b{font-size:12.5px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-cap-info span{font-size:11px;color:var(--muted);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-cap-ext{font-size:10.5px;font-weight:600;color:var(--accent);background:var(--accent-dim);padding:2px 6px;border-radius:4px;flex-shrink:0;font-family:SF Mono,Fira Code,monospace}.chat-view{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-header{display:flex;align-items:center;padding:14px 20px;border-bottom:1px solid var(--border);gap:12px;min-height:57px}.chat-header-title{flex:1;font-size:14px;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-btn{padding:6px 12px;border-radius:8px;background:none;border:1px solid var(--border);color:var(--muted);font-size:13px;transition:all .15s}.header-btn:hover{border-color:var(--danger);color:var(--danger)}.messages-container{flex:1;overflow-y:auto;padding:24px 0}.messages-inner{max-width:760px;margin:0 auto;padding:0 20px}.message-group{margin-bottom:24px}.message-row{display:flex;gap:14px;align-items:flex-start}.message-row.user{flex-direction:row-reverse}.msg-avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;margin-top:2px}.msg-avatar.ai{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff}.msg-avatar.user{background:var(--surface);border:1px solid var(--border)}.msg-content{flex:1;min-width:0}.msg-role{font-size:12px;font-weight:600;color:var(--muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.04em}.msg-bubble{display:inline-block;background:var(--user-msg);border-radius:18px 18px 4px;padding:11px 16px;font-size:15px;line-height:1.65;color:var(--text);max-width:80%;white-space:pre-wrap}.msg-text{font-size:15px;line-height:1.75;color:var(--text)}.msg-text p{margin-bottom:12px}.msg-text p:last-child{margin-bottom:0}.msg-text ul,.msg-text ol{padding-left:22px;margin-bottom:12px}.msg-text li{margin-bottom:4px}.msg-text h1,.msg-text h2,.msg-text h3{font-weight:700;margin:18px 0 8px;color:var(--text)}.msg-text h1{font-size:20px}.msg-text h2{font-size:17px}.msg-text h3{font-size:15px}.msg-text strong{font-weight:600}.msg-text em{font-style:italic}.msg-text a{color:var(--accent);text-decoration:underline}.msg-text blockquote{border-left:3px solid var(--accent);padding-left:14px;color:var(--muted);margin:10px 0}.msg-text hr{border:none;border-top:1px solid var(--border);margin:14px 0}.msg-text code:not(pre code){background:var(--code-bg);padding:2px 7px;border-radius:5px;font-size:13.5px;color:#a5b4fc;font-family:SF Mono,Fira Code,monospace;border:1px solid var(--code-border)}.msg-text pre{margin:0;overflow-x:auto;background:#0d1117}.msg-text pre code{display:block;padding:14px 16px;font-size:13.5px;line-height:1.6;font-family:SF Mono,Fira Code,Consolas,monospace;background:#0d1117!important}.code-block{border-radius:10px;overflow:hidden;margin:14px 0;border:1px solid #30363d}.code-block-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;background:#161b22;border-bottom:1px solid #30363d}.code-block-lang{font-size:12px;color:#8b949e;font-family:SF Mono,monospace;text-transform:lowercase}.code-header-actions{display:flex;gap:6px;align-items:center}.code-copy-btn{background:none;border:1px solid #30363d;color:#8b949e;font-size:11px;padding:3px 10px;border-radius:6px;cursor:pointer;transition:all .15s;font-family:-apple-system,sans-serif}.code-copy-btn:hover{border-color:#8b949e;color:#e6edf3;background:#21262d}.code-run-btn{background:#1a4731;border:1px solid #2d6a4f;color:#4ade80;font-size:11px;padding:3px 11px;border-radius:6px;cursor:pointer;transition:all .15s;font-family:-apple-system,sans-serif;font-weight:600;margin-right:4px}.code-run-btn:hover{background:#15803d;border-color:#4ade80;color:#fff}.code-run-btn:disabled{opacity:.5;cursor:default}.code-output{border:1px solid #30363d;border-top:none;background:#0d1117;color:#e6edf3;font-family:SF Mono,Fira Code,monospace;font-size:12.5px;padding:12px 16px;white-space:pre-wrap;word-break:break-all;border-radius:0 0 10px 10px;margin-top:-14px;margin-bottom:14px;max-height:320px;overflow-y:auto;line-height:1.6}.code-output.running{color:#8b949e}.code-output.success{border-left:3px solid #4ade80}.code-output.error{border-left:3px solid #f87171;color:#fca5a5}.code-block-pre{margin:0!important;overflow-x:auto;background:#0d1117;border-radius:0!important}.code-block-pre code{display:block;padding:14px 16px;font-size:13.5px;line-height:1.6;font-family:SF Mono,Fira Code,Consolas,monospace;background:#0d1117!important}.hljs{background:#0d1117!important}.msg-text table{border-collapse:collapse;width:100%;margin:12px 0}.msg-text th,.msg-text td{border:1px solid var(--border);padding:8px 12px;font-size:14px}.msg-text th{background:var(--surface);font-weight:600;color:var(--accent)}.status-badge{display:inline-flex;align-items:center;gap:10px;border-radius:14px;padding:10px 16px;font-size:13.5px;animation:fade-in .25s ease;border:1px solid;transition:all .2s}.status-think{background:var(--surface);border-color:var(--border);color:var(--text-secondary)}.status-search{background:#6366f114;border-color:#6366f14d;color:var(--accent)}.status-queue{background:#f59e0b14;border-color:#f59e0b59;color:#f59e0b}.status-icon{font-size:18px;flex-shrink:0}.searching-badge{display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:7px 14px;font-size:13.5px;color:var(--text-secondary);animation:fade-in .25s ease;transition:all .2s}.search-spinner{width:12px;height:12px;border-radius:50%;border:2px solid var(--border);border-top-color:var(--accent);animation:spin .7s linear infinite;flex-shrink:0}.thinking-dots{display:inline-flex;gap:4px;align-items:center;flex-shrink:0}.thinking-dots span{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block;animation:thinking-bounce .9s ease-in-out infinite}.thinking-dots span:nth-child(2){animation-delay:.15s}.thinking-dots span:nth-child(3){animation-delay:.3s}@keyframes thinking-bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-5px);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1}}@keyframes blink{50%{opacity:0}}.cursor{display:inline-block;animation:blink 1s step-end infinite;margin-left:1px}.input-area{padding:12px 20px 18px;background:var(--bg)}.input-area-inner{max-width:760px;margin:0 auto}.attach-preview{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px 12px;margin-bottom:8px;font-size:13px;color:var(--text-secondary)}.attach-preview button{margin-left:auto;background:none;border:none;color:var(--muted);font-size:16px;line-height:1}.attach-preview button:hover{color:var(--danger)}.input-box{display:flex;align-items:flex-end;gap:8px;background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:16px;padding:10px 12px;transition:border-color .2s;box-shadow:var(--shadow-sm)}.input-box:focus-within{border-color:var(--accent)}.input-icon-btn{background:none;border:none;color:var(--muted);font-size:18px;padding:4px 5px;border-radius:7px;flex-shrink:0;transition:color .15s,background .15s}.input-icon-btn:hover{color:var(--text);background:var(--surface-hover)}.msg-textarea{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:15px;resize:none;min-height:24px;max-height:200px;line-height:1.6;overflow-y:auto;padding:0}.msg-textarea::placeholder{color:var(--muted)}.send-btn{width:34px;height:34px;border-radius:10px;flex-shrink:0;background:var(--accent);color:#fff;border:none;display:flex;align-items:center;justify-content:center;font-size:16px;transition:opacity .2s,background .2s}.send-btn:hover{opacity:.85}.send-btn:disabled{background:var(--border);color:var(--muted)}.input-hint{text-align:center;font-size:11.5px;color:var(--muted);margin-top:8px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--surface);border:1px solid var(--border);border-radius:20px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;padding:28px;position:relative;box-shadow:var(--shadow);animation:modal-in .18s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-close{position:absolute;top:18px;right:18px;background:none;border:none;color:var(--muted);font-size:20px;line-height:1;padding:4px;border-radius:6px;transition:color .15s,background .15s}.modal-close:hover{color:var(--text);background:var(--surface-hover)}.modal h2{font-size:18px;font-weight:700;margin-bottom:22px;color:var(--text)}.modal-section{margin-bottom:26px}.modal-section:last-child{margin-bottom:0}.modal-section-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border)}.toggle-row:first-child{padding-top:0}.toggle-row:last-child{border-bottom:none;padding-bottom:0}.toggle-label{font-size:14.5px;color:var(--text)}.toggle-desc{font-size:12px;color:var(--muted);margin-top:2px}.toggle{width:42px;height:23px;border-radius:12px;background:var(--toggle-off);border:none;position:relative;cursor:pointer;transition:background .2s;flex-shrink:0}.toggle.on{background:var(--accent)}.toggle:after{content:"";position:absolute;width:17px;height:17px;background:#fff;border-radius:50%;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 3px #0000004d}.toggle.on:after{transform:translate(19px)}.modal-field{margin-bottom:14px}.modal-field label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}.modal-input{width:100%;padding:10px 14px;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-size:14.5px;outline:none;transition:border-color .2s}.modal-input:focus{border-color:var(--accent)}.modal-textarea{width:100%;min-height:110px;padding:11px 14px;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-size:14px;resize:vertical;outline:none;line-height:1.6;transition:border-color .2s}.modal-textarea:focus{border-color:var(--accent)}.modal-btn{padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600;border:none;cursor:pointer;transition:opacity .2s}.modal-btn.primary{background:var(--accent);color:#fff}.modal-btn.primary:hover{opacity:.85}.modal-btn.secondary{background:var(--surface-hover);color:var(--text);border:1px solid var(--border)}.modal-btn.secondary:hover{background:var(--border)}.modal-btn.danger{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger)}.usage-bar-wrap{margin-top:8px}.usage-bar{height:6px;background:var(--border);border-radius:10px;overflow:hidden}.usage-fill{height:100%;background:linear-gradient(90deg,var(--accent),#8b5cf6);border-radius:10px;transition:width .4s}.usage-label{font-size:13px;color:var(--muted);margin-top:6px}.model-tag{display:inline-flex;align-items:center;gap:6px;background:var(--accent-dim);border:1px solid var(--accent);color:var(--accent);padding:5px 12px;border-radius:20px;font-size:13px;font-family:monospace}.alert{padding:10px 14px;border-radius:10px;font-size:13.5px;margin-bottom:12px}.alert.error{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger)}.alert.success{background:#22c55e1a;color:var(--success);border:1px solid var(--success)}.calc-modal{max-width:300px}.calc-display{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:12px;font-size:26px;font-family:monospace;text-align:right;color:var(--text);min-height:58px;word-break:break-all;line-height:1.2}.calc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}.calc-btn{padding:14px 0;border:none;border-radius:10px;font-size:16px;font-weight:500;transition:opacity .15s}.calc-btn:hover{opacity:.75}.calc-btn.num{background:var(--surface-hover);color:var(--text)}.calc-btn.op{background:var(--accent-dim);color:var(--accent)}.calc-btn.ac{background:var(--danger-bg);color:var(--danger)}.calc-btn.eq{background:var(--accent);color:#fff}.calc-btn.del{background:var(--surface);color:var(--muted)}.calc-btn.span2{grid-column:span 2}.login-page{min-height:100svh;display:flex;align-items:center;justify-content:center;background:var(--bg);position:relative;overflow-x:hidden;overflow-y:auto}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:44px 40px;width:100%;max-width:420px;box-shadow:var(--shadow)}.login-brand{text-align:center;margin-bottom:32px}.login-brand-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--accent),#8b5cf6);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 14px}.login-brand h1{font-size:26px;font-weight:700;color:var(--text)}.login-brand p{font-size:13px;color:var(--muted);margin-top:5px}.login-tabs{display:flex;gap:4px;padding:4px;background:var(--bg);border-radius:10px;margin-bottom:24px}.login-tab{flex:1;padding:9px;text-align:center;border-radius:7px;font-size:14px;font-weight:500;color:var(--muted);border:none;background:none;cursor:pointer;transition:all .15s}.login-tab.active{background:var(--accent);color:#fff}.login-field{margin-bottom:16px}.login-field label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}.login-field input{width:100%;padding:12px 16px;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-size:15px;outline:none;transition:border-color .2s}.login-field input:focus{border-color:var(--accent)}.login-field input::placeholder{color:var(--muted)}.login-btn{width:100%;padding:13px;background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:opacity .2s;margin-top:4px}.login-btn:hover{opacity:.9}.login-btn:disabled{opacity:.45;cursor:not-allowed}.login-theme-btn{background:var(--surface);border:1px solid var(--border);color:var(--text-secondary);padding:7px 12px;border-radius:8px;font-size:14px;transition:all .15s;cursor:pointer;white-space:nowrap}.login-theme-btn:hover{border-color:var(--accent);color:var(--accent)}.url-fetch-bar{display:flex;align-items:center;gap:8px;background:var(--surface);border:1.5px solid var(--accent);border-radius:12px;padding:8px 12px;margin-bottom:8px;animation:fade-in .15s ease}.url-fetch-icon{font-size:16px;flex-shrink:0}.url-fetch-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:14px}.url-fetch-input::placeholder{color:var(--muted)}.url-fetch-btn{padding:5px 12px;border-radius:8px;background:var(--accent);color:#fff;border:none;font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap;transition:opacity .15s;flex-shrink:0}.url-fetch-btn:hover{opacity:.85}.url-fetch-btn:disabled{opacity:.4;cursor:not-allowed}.url-fetch-cancel{background:none;border:none;color:var(--muted);font-size:16px;cursor:pointer;padding:2px 4px;flex-shrink:0;transition:color .15s}.url-fetch-cancel:hover{color:var(--danger)}.input-icon-btn.active{color:var(--accent)}.artifact-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}.artifact-card{display:flex;align-items:center;gap:12px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 14px;transition:border-color .15s,box-shadow .15s}.artifact-card:hover{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.artifact-icon{font-size:22px;flex-shrink:0}.artifact-info{flex:1;min-width:0}.artifact-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.artifact-meta{font-size:12px;color:var(--muted);margin-top:2px}.artifact-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.artifact-preview-btn{width:32px;height:32px;border-radius:8px;background:var(--surface-hover);border:1px solid var(--border);color:var(--muted);font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s;cursor:pointer}.artifact-preview-btn:hover{border-color:var(--accent);color:var(--accent)}.artifact-download-btn{padding:6px 14px;border-radius:8px;background:var(--accent);color:#fff;border:none;font-size:13px;font-weight:600;white-space:nowrap;transition:opacity .15s;cursor:pointer}.artifact-download-btn:hover{opacity:.85}.artifact-download-btn:disabled{opacity:.45;cursor:not-allowed}.artifact-delete-btn{width:32px;height:32px;border-radius:8px;background:none;border:1px solid var(--border);color:var(--muted);font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s;cursor:pointer}.artifact-delete-btn:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}.artifact-expired{opacity:.6;border-color:var(--border)!important;box-shadow:none!important}.artifact-expired .artifact-name{text-decoration:line-through;color:var(--muted)}.artifact-danger{border-color:#f59e0b!important;background:#f59e0b0f!important}.artifact-warnings{margin-top:5px;display:flex;flex-direction:column;gap:3px}.artifact-warning-item{font-size:11px;color:#b45309;font-weight:500;background:#f59e0b1f;border-radius:4px;padding:2px 6px;line-height:1.5}.artifact-build-btn{padding:6px 12px;border-radius:8px;background:var(--surface-hover);border:1px solid var(--border);color:var(--text-secondary);font-size:13px;font-weight:600;white-space:nowrap;transition:all .15s;cursor:pointer}.artifact-build-btn:hover{border-color:var(--accent);color:var(--accent)}.build-modal{max-width:540px}.build-targets{display:flex;flex-direction:column;gap:8px}.build-target-btn{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;background:var(--surface-hover);border:1.5px solid var(--border);color:var(--text);text-align:left;cursor:pointer;transition:all .15s;width:100%}.build-target-btn:hover{border-color:var(--accent)}.build-target-btn.selected{border-color:var(--accent);background:var(--accent-dim)}.build-target-btn.unavailable{opacity:.55;cursor:default}.build-target-btn.unavailable:hover{border-color:var(--border)}.build-target-icon{font-size:22px;flex-shrink:0}.build-target-label{font-size:14px;font-weight:600}.build-target-req{font-size:12px;color:var(--muted);margin-top:2px}.build-progress-bar-wrap{height:6px;background:var(--border);border-radius:10px;overflow:hidden;margin-bottom:14px}.build-progress-bar{height:100%;background:linear-gradient(90deg,var(--accent),#8b5cf6);border-radius:10px;transition:width .4s}.build-log{background:#0d1117;border:1px solid #30363d;border-radius:10px;padding:12px 14px;font-family:SF Mono,Fira Code,monospace;font-size:12.5px;line-height:1.6;color:#e6edf3;max-height:300px;overflow-y:auto;white-space:pre-wrap;word-break:break-all}.admin-modal{max-width:600px}.user-table{width:100%;border-collapse:collapse}.user-table th,.user-table td{padding:10px 14px;text-align:left;font-size:13.5px;border-bottom:1px solid var(--border)}.user-table th{color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.05em}.user-table tr:last-child td{border-bottom:none}.admin-badge{background:var(--accent-dim);color:var(--accent);font-size:11px;padding:2px 7px;border-radius:10px;font-weight:600}.limit-btn{padding:4px 10px;background:var(--surface-hover);border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:12px;cursor:pointer;transition:all .15s}.limit-btn:hover{border-color:var(--accent);color:var(--accent)}.sidebar-close-btn{display:none;background:none;border:none;color:var(--muted);font-size:20px;padding:4px 8px;border-radius:6px;cursor:pointer;margin-left:auto;transition:color .15s}.sidebar-close-btn:hover{color:var(--danger)}.mobile-topbar{display:none;align-items:center;padding:10px 12px;border-bottom:1px solid var(--border);background:var(--bg)}.mobile-menu-btn{display:none;background:none;border:none;color:var(--text);font-size:20px;padding:4px 8px;border-radius:7px;cursor:pointer;flex-shrink:0;transition:background .15s}.mobile-menu-btn:hover{background:var(--surface-hover)}.sidebar-backdrop{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:149;background:#00000073}.pdf-btn{padding:6px 12px;border-radius:8px;background:none;border:1px solid var(--border);color:var(--muted);font-size:12px;display:flex;align-items:center;gap:5px;transition:all .15s;cursor:pointer;flex-shrink:0}.pdf-btn:hover{border-color:#ef4444;color:#ef4444}@media (max-width: 768px){.sidebar{position:fixed;left:-280px;top:0;bottom:0;width:280px;z-index:150;transition:left .25s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 24px #0006}.sidebar.open{left:0}.sidebar-backdrop.show{display:block}.sidebar-close-btn{display:flex!important}.app-layout{position:relative;overflow:hidden}.main-area{width:100%}.mobile-menu-btn{display:flex;align-items:center;justify-content:center}.mobile-topbar{display:flex}.chat-header{padding:10px 12px;gap:8px}.chat-header-title{font-size:13px}.messages-inner{padding:0 12px}.input-area{padding:8px 12px 14px}.welcome{padding:24px 16px 32px}.welcome-files-grid{grid-template-columns:1fr}.welcome-title{font-size:22px}.modal{max-width:100%;margin:0 12px;border-radius:16px;padding:20px}.login-page{align-items:flex-start;padding:64px 12px 32px}.login-card{margin:0;padding:24px 16px;border-radius:16px;width:100%;max-width:100%!important}.login-brand h1{font-size:22px}.login-brand{margin-bottom:20px}.calc-grid{gap:4px!important}.calc-grid button{font-size:13px!important}.msg-bubble{max-width:92%}.code-block{overflow-x:auto}.pdf-btn-label,.editor-desc{display:none}}@media print{.sidebar,.sidebar-backdrop,.mobile-topbar,.chat-header,.input-area,.code-run-btn,.code-copy-btn,.artifact-actions,.artifact-build-btn,.mobile-menu-btn,.pdf-btn,.header-btn,.model-selector-wrap{display:none!important}body,#root,.app-layout,.main-area,.chat-view,.messages-container,.messages-inner,.message-group{background:#fff!important;color:#111!important}.app-layout{display:block!important}.main-area{width:100%!important;display:block!important}.chat-view{display:block!important;height:auto!important;overflow:visible!important}.messages-container{overflow:visible!important;height:auto!important}.msg-text{color:#111!important;font-size:13px!important}.msg-bubble{background:#f3f4f6!important;color:#111!important;border-radius:8px!important}.msg-avatar.ai{background:#6366f1!important}.code-block{border:1px solid #ccc!important;page-break-inside:avoid}.code-block-pre code,.msg-text pre code{background:#f6f8fa!important;color:#111!important}.code-block-header{background:#f0f0f0!important}.message-group{page-break-inside:avoid;margin-bottom:12px!important}.messages-inner:before{content:"MakeBotAI 대화 내용";display:block;font-size:18px;font-weight:700;color:#111;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid #6366f1}}
