*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}button{font:inherit;border:none;background:none;cursor:pointer}textarea,input{font:inherit;border:none;outline:none}:root{--navy:hsl(215,50%,23%);--navy-light:hsl(215,40%,35%);--navy-lighter:hsl(215,30%,50%);--gold:hsl(45,70%,50%);--gold-soft:hsl(45,60%,92%);--bg:#fff;--bg-soft:hsl(210,20%,98%);--bg-hover:hsl(210,15%,92%);--bg-muted:hsl(210,20%,95%);--border:hsl(214.3,25%,90%);--border-subtle:hsl(214,20%,93%);--text:hsl(215,25%,15%);--text-secondary:hsl(215,20%,45%);--text-tertiary:hsl(215,15%,60%);--primary-soft:hsl(215,40%,95%);--destructive:hsl(0,70%,42%);--green:hsl(155,50%,42%);--amber:hsl(35,80%,52%);--purple:hsl(270,40%,55%);--blue:hsl(215,60%,55%);--radius:10px;--radius-sm:6px;--radius-lg:14px;--transition:.28s cubic-bezier(.4,0,.2,1);--font-body:"DM Sans",-apple-system,BlinkMacSystemFont,sans-serif;--font-serif:"Instrument Serif",serif}html,body,#root{height:100%;font-family:var(--font-body);color:var(--text);background:var(--bg);font-size:14px;line-height:1.5}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:12px}.loading-logo{width:48px;height:48px;border-radius:12px;background:var(--gold);color:var(--navy);font-family:var(--font-serif);font-size:28px;font-style:italic;display:flex;align-items:center;justify-content:center}.loading-text{font-size:13px;color:var(--text-tertiary)}.login-screen{display:flex;align-items:center;justify-content:center;height:100%;background:var(--bg-soft);padding:24px}.login-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 28px;width:100%;max-width:340px;text-align:center;box-shadow:0 8px 40px #0000000f}.login-logo{width:48px;height:48px;border-radius:12px;background:var(--gold);color:var(--navy);font-family:var(--font-serif);font-size:28px;font-style:italic;display:inline-flex;align-items:center;justify-content:center;margin-bottom:16px}.login-title{font-size:20px;font-weight:600;color:var(--text);margin-bottom:4px}.login-subtitle{font-size:13px;color:var(--text-tertiary);margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:10px}.login-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;transition:border-color var(--transition)}.login-input:focus{border-color:var(--navy);box-shadow:0 0 0 3px var(--primary-soft)}.login-field{display:flex;flex-direction:column;gap:3px;text-align:left}.login-label{font-size:11px;font-weight:500;color:var(--text-secondary);display:flex;align-items:center;gap:4px}.login-error{font-size:12px;color:var(--destructive);text-align:left}.login-info{font-size:11px;color:var(--green);text-align:left}.login-hint{font-size:11px;color:var(--text-tertiary);text-align:center;line-height:1.4;margin-top:4px}.login-btn{width:100%;padding:10px;border-radius:var(--radius);background:var(--navy);color:#fff;font-size:13px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px;transition:background var(--transition)}.login-btn:hover:not(:disabled){background:var(--navy-light)}.login-btn:disabled{opacity:.5;cursor:default}.chat-pane{display:flex;flex-direction:column;height:100%;overflow:hidden}.chat-pane-header{height:48px;flex-shrink:0;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 14px;background:var(--bg)}.header-left{display:flex;align-items:center;gap:6px}.header-icon{color:var(--gold)}.header-title{font-size:14px;font-weight:600;color:var(--navy)}.skill-toggle{height:28px;padding:0 10px;border-radius:6px;font-size:11.5px;font-weight:500;color:var(--text-secondary);border:1px solid var(--border-subtle);display:inline-flex;align-items:center;gap:4px;transition:all var(--transition)}.skill-toggle:hover{border-color:var(--navy-lighter);color:var(--navy)}.skill-toggle.active{background:var(--primary-soft);border-color:var(--navy);color:var(--navy)}.skill-clear{width:20px;height:20px;border-radius:4px;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;font-size:11px}.skill-clear:hover{background:var(--bg-muted);color:var(--text)}.active-skill-banner{display:flex;align-items:center;gap:6px;padding:6px 14px;font-size:11px;color:var(--navy);background:var(--gold-soft);border-bottom:1px solid hsl(45,40%,85%)}.skill-banner-desc{color:var(--text-tertiary);margin-left:4px}.skill-picker{position:absolute;top:48px;right:0;left:0;z-index:50;background:var(--bg);border-bottom:1px solid var(--border);box-shadow:0 12px 40px #0000001a;max-height:70vh;overflow-y:auto;animation:slide-down .2s cubic-bezier(.16,1,.3,1)}@keyframes slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.skill-picker-header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px 8px;border-bottom:1px solid var(--border-subtle)}.skill-picker-title{font-size:12px;font-weight:600;color:var(--text);text-transform:uppercase;letter-spacing:.5px}.skill-picker-close{width:24px;height:24px;border-radius:4px;color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;font-size:13px}.skill-picker-close:hover{background:var(--bg-muted);color:var(--text)}.skill-category{padding:8px 0}.skill-category-label{font-size:10px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.8px;padding:4px 14px}.skill-item{display:flex;align-items:flex-start;gap:10px;width:100%;padding:8px 14px;text-align:left;transition:background var(--transition)}.skill-item:hover{background:var(--bg-soft)}.skill-item.active{background:var(--primary-soft)}.skill-item-icon{width:32px;height:32px;border-radius:8px;background:var(--bg-muted);color:var(--navy);display:flex;align-items:center;justify-content:center;flex-shrink:0}.skill-item.active .skill-item-icon{background:var(--navy);color:#fff}.skill-item-info{flex:1;min-width:0}.skill-item-name{font-size:13px;font-weight:500;color:var(--text);display:block}.skill-item-desc{font-size:11px;color:var(--text-tertiary);display:block;margin-top:1px;line-height:1.35}.chat-messages{flex:1;overflow-y:auto;padding:16px 14px;display:flex;flex-direction:column;gap:16px}.message{display:flex;gap:10px}.message.user{flex-direction:row-reverse}.message-avatar{width:28px;height:28px;border-radius:50%;flex-shrink:0;font-size:11px;font-weight:500;display:flex;align-items:center;justify-content:center}.message.assistant .message-avatar{background:var(--primary-soft);color:var(--navy)}.message.user .message-avatar{background:var(--navy);color:#fff;font-weight:600}.message.streaming .message-avatar{background:var(--gold-soft);color:var(--gold)}.message-body{flex:1;min-width:0}.message.user .message-body{display:flex;flex-direction:column;align-items:flex-end}.message-bubble{padding:10px 14px;border-radius:var(--radius-lg);font-size:13px;line-height:1.6;max-width:100%}.message.assistant .message-bubble{background:var(--bg-soft);border:1px solid var(--border-subtle);border-top-left-radius:4px}.message.user .message-bubble{background:var(--navy);color:#fff;border-top-right-radius:4px}.message-text p{margin-bottom:8px}.message-text p:last-child{margin-bottom:0}.message-text strong{font-weight:600}.message-time{font-size:10px;color:var(--text-tertiary);margin-top:3px;padding:0 2px}.streaming-cursor{display:inline-block;width:2px;height:14px;background:var(--navy);margin-left:2px;animation:blink 1s step-end infinite;vertical-align:text-bottom}@keyframes blink{50%{opacity:0}}.typing-indicator{display:flex;gap:4px;padding:8px 0}.typing-indicator span{width:6px;height:6px;border-radius:50%;background:var(--text-tertiary);animation:typing 1.4s ease-in-out infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.phase-indicator{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--text-tertiary);padding:4px 0;margin-bottom:4px}.thinking-block{margin-bottom:8px;font-size:12px}.thinking-block summary{cursor:pointer;color:var(--text-tertiary);font-weight:500;font-size:11px;padding:4px 0}.thinking-content{padding:8px 12px;background:var(--bg-muted);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:12px;line-height:1.5;margin-top:4px;white-space:pre-wrap}.message-actions{display:flex;gap:2px;margin-top:4px;opacity:0;transition:opacity var(--transition)}.message:hover .message-actions{opacity:1}.action-btn{width:26px;height:26px;border-radius:var(--radius-sm);color:var(--text-tertiary);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}.action-btn:hover{background:var(--bg-muted);color:var(--text)}.citations-row{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px}.citation-chip{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:500;border:1px solid;cursor:default}.citation-chip-icon{font-size:11px}.citation-article{background:#f0f4fa;color:#2d5286;border-color:#d4deed}.citation-decision{background:#f5f1f9;color:#59367d;border-color:#e0d7ea}.citation-convention{background:#faf1eb;color:#8f5024;border-color:#ecd6c6}.citation-eu{background:#f1f1f9;color:#363b7d;border-color:#d7d9ea}.citation-web{background:#edf7f3;color:#267353;border-color:#cde4db}.citation-ged{background:var(--gold-soft);color:#7a541f;border-color:#e0cfb8}.tool-calls-section{display:flex;flex-direction:column;gap:4px;margin-top:8px}.tool-call-row{display:flex;align-items:center;gap:6px;padding:4px 8px;border-radius:var(--radius-sm);font-size:11px;background:var(--bg-muted)}.tool-call-icon{font-size:12px}.tool-call-name{font-weight:500;color:var(--text);font-family:ui-monospace,SFMono-Regular,monospace;font-size:11px}.tool-call-status{color:var(--text-tertiary);margin-left:auto;font-size:10px;text-transform:uppercase}.tool-running .tool-call-name{color:var(--blue)}.tool-error .tool-call-name{color:var(--destructive)}.quality-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:10px;font-weight:500;margin-top:8px}.quality-badge.pass{background:#edf7f3;color:#267353;border:1px solid hsl(155,30%,85%)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;padding:24px}.empty-logo{width:56px;height:56px;border-radius:14px;background:var(--gold);color:var(--navy);font-family:var(--font-serif);font-size:32px;font-style:italic;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.empty-title{font-size:17px;font-weight:600;color:var(--text);margin-bottom:4px}.empty-desc{font-size:12.5px;color:var(--text-tertiary);max-width:240px;line-height:1.5;margin-bottom:20px}.empty-suggestions{display:flex;flex-direction:column;gap:6px;width:100%}.suggestion-chip{padding:8px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:12px;color:var(--text-secondary);text-align:left;transition:all var(--transition)}.suggestion-chip:hover{border-color:var(--navy);color:var(--navy);background:var(--primary-soft)}.input-area{flex-shrink:0;padding:10px 14px 14px;background:var(--bg);border-top:1px solid var(--border-subtle)}.input-box{display:flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:6px 10px;min-height:44px;transition:all var(--transition)}.input-box:focus-within{border-color:var(--navy);box-shadow:0 0 0 3px var(--primary-soft)}.input-box textarea{flex:1;font-size:13px;line-height:1.5;color:var(--text);background:transparent;padding:4px 0;min-height:28px;max-height:120px;resize:none}.input-box textarea::placeholder{color:var(--text-tertiary)}.input-btn{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0}.input-btn.attach{color:var(--text-tertiary)}.input-btn.attach:hover{background:var(--bg-muted);color:var(--text-secondary)}.input-btn.send{background:var(--navy);color:#fff}.input-btn.send:hover{background:var(--navy-light);transform:scale(1.05)}.input-btn.send:disabled{background:var(--bg-muted);color:var(--text-tertiary);transform:none;cursor:default}.input-btn.stop{background:var(--destructive);color:#fff}.input-btn.stop:hover{opacity:.9}.permission-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;display:flex;align-items:center;justify-content:center;animation:fade-in .15s ease;padding:16px}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.permission-dialog{background:var(--bg);border-radius:var(--radius-lg);width:100%;max-width:340px;padding:20px;box-shadow:0 24px 80px #0000002e;animation:dialog-in .25s cubic-bezier(.16,1,.3,1)}@keyframes dialog-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.permission-icon{width:40px;height:40px;border-radius:10px;background:var(--gold-soft);color:var(--gold);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.permission-title{font-size:15px;font-weight:600;margin-bottom:4px}.permission-desc{font-size:12.5px;color:var(--text-secondary);margin-bottom:12px}.permission-detail{padding:8px 10px;border-radius:var(--radius-sm);background:var(--bg-soft);border:1px solid var(--border-subtle);margin-bottom:16px}.permission-tool{font-size:12px;font-weight:500;color:var(--navy);font-family:ui-monospace,monospace}.permission-input{font-size:11px;color:var(--text-tertiary);margin-top:4px;white-space:pre-wrap;word-break:break-all;max-height:80px;overflow:hidden}.permission-actions{display:flex;gap:8px;justify-content:flex-end}.permission-btn{padding:7px 14px;border-radius:var(--radius);font-size:12.5px;font-weight:500;display:inline-flex;align-items:center;gap:5px;transition:all var(--transition)}.permission-btn.deny{border:1px solid var(--border);color:var(--text-secondary)}.permission-btn.deny:hover{background:var(--bg-muted);color:var(--text)}.permission-btn.approve{background:var(--navy);color:#fff;border:1px solid var(--navy)}.permission-btn.approve:hover{background:var(--navy-light)}
