:root{--doca-green-primary: #00a050;--doca-green-light: #50b478;--doca-green-muted: #8cc8a0;--petrus-yellow: #f0c800;--petrus-yellow-dim: #dcb400;--petrus-gray: #3c3c3c;--petrus-gray-light: #606060;--dok-bg: #0e1512;--dok-surface: #161e18;--dok-surface-raised: #1e2a21;--dok-border: #2a3d2e;--dok-border-bright: #3c5a40;--dok-accent: #f0c800;--dok-accent-hover: #dcb400;--dok-accent-dim: #f0c80030;--dok-green: #00a050;--dok-green-hover: #00b85a;--dok-green-dim: #00a05020;--dok-text-primary: #f0f2ee;--dok-text-secondary: #a8b8aa;--dok-text-muted: #607060;--dok-success: #00a050;--dok-warning: #f0c800;--dok-error: #e05050;--dok-radius: 6px;--dok-font-display: "Syne", sans-serif;--dok-font-body: "IBM Plex Sans", sans-serif;--dok-font-mono: "IBM Plex Mono", monospace;--sidebar-w: 260px}*,*:before,*:after{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--dok-bg);color:var(--dok-text-primary);font-family:var(--dok-font-body);font-weight:400;font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,h2,h3,h4{font-family:var(--dok-font-display);font-weight:800;letter-spacing:-.01em;margin:0}button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit}a{color:var(--dok-green);text-decoration:none}a:hover{color:var(--dok-green-hover)}::selection{background:var(--dok-accent-dim)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--dok-border);border-radius:6px;border:2px solid var(--dok-bg)}::-webkit-scrollbar-thumb:hover{background:var(--dok-border-bright)}.grain-overlay:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;opacity:.025;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}@keyframes messageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes cursorBlink{0%,to{opacity:1}50%{opacity:0}}@keyframes typingBounce{0%,80%,to{transform:translateY(0);opacity:.4}40%{transform:translateY(-4px);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.app-shell{position:relative;display:flex;height:100vh;height:100dvh;overflow:hidden;z-index:2}.main-col{display:flex;flex-direction:column;flex:1;min-width:0}.header{display:flex;align-items:center;gap:12px;height:60px;padding:0 20px;background:var(--dok-surface);border-bottom:1px solid var(--dok-border);flex-shrink:0}.header .header-title{font-family:var(--dok-font-body);font-weight:500;font-size:14px;color:var(--dok-text-secondary)}.header .header-spacer{flex:1}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid transparent;background:transparent;color:var(--dok-text-secondary);border-radius:var(--dok-radius);cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.icon-btn:hover{background:var(--dok-surface-raised);color:var(--dok-text-primary);border-color:var(--dok-border)}.sidebar{display:flex;flex-direction:column;width:var(--sidebar-w);background:var(--dok-surface);border-right:1px solid var(--dok-border);flex-shrink:0}.sidebar-head{padding:18px 16px 12px}.new-chat-btn{display:flex;align-items:center;gap:8px;width:100%;margin-top:14px;padding:10px 12px;background:var(--dok-accent);color:var(--dok-bg);font-weight:600;border:none;border-radius:var(--dok-radius);cursor:pointer;transition:background .15s ease}.new-chat-btn:hover{background:var(--dok-accent-hover)}.conv-list{flex:1;overflow-y:auto;padding:8px}.conv-section-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--dok-text-muted);padding:8px 10px 4px}.conv-item{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:var(--dok-radius);cursor:pointer;color:var(--dok-text-secondary);border-left:3px solid transparent;transition:background .15s ease,color .15s ease}.conv-item:hover{background:var(--dok-surface-raised);color:var(--dok-text-primary)}.conv-item.active{background:var(--dok-green-dim);border-left-color:var(--dok-green);color:var(--dok-text-primary)}.conv-item .conv-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14px}.conv-item .conv-del{opacity:0;color:var(--dok-text-muted);transition:opacity .15s ease,color .15s ease}.conv-item:hover .conv-del{opacity:1}.conv-item .conv-del:hover{color:var(--dok-error)}.skeleton{height:36px;border-radius:var(--dok-radius);margin:6px 0;background:linear-gradient(90deg,var(--dok-surface-raised) 25%,var(--dok-border) 37%,var(--dok-surface-raised) 63%);background-size:800px 100%;animation:shimmer 1.4s infinite linear}.chat-window{display:flex;flex-direction:column;flex:1;min-height:0}.messages-scroll{flex:1;overflow-y:auto;padding:24px 0}.messages-inner{max-width:760px;margin:0 auto;padding:0 20px;display:flex;flex-direction:column;gap:18px}.bubble-row{display:flex;animation:messageIn .2s ease-out}.bubble-row.user{justify-content:flex-end}.bubble{max-width:86%;padding:12px 15px;border-radius:var(--dok-radius);border:1px solid;font-size:15px;word-wrap:break-word;overflow-wrap:break-word}.bubble.user{background:var(--dok-accent-dim);border-color:var(--dok-accent)}.bubble.assistant{background:var(--dok-surface-raised);border-color:var(--dok-border-bright);width:100%}.bubble-role{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.bubble.user .bubble-role{color:var(--dok-accent);text-align:right}.bubble.assistant .bubble-role{color:var(--dok-green)}.bubble-row.assistant{flex-direction:column;align-items:flex-start}.feedback-row{display:flex;align-items:center;gap:6px;margin-top:6px;padding-left:2px}.feedback-btn{background:transparent;border:1px solid var(--dok-border);color:var(--dok-text-secondary);border-radius:6px;padding:4px 7px;cursor:pointer;display:inline-flex;align-items:center;transition:color .12s,border-color .12s,background .12s}.feedback-btn:hover:not(:disabled){color:var(--dok-green);border-color:var(--dok-green)}.feedback-btn.active{color:var(--dok-green);border-color:var(--dok-green);background:#2dd4911f}.feedback-btn:disabled{cursor:default;opacity:.85}.feedback-thanks{font-size:12px;color:var(--dok-text-secondary);margin-left:4px}.stream-cursor{display:inline-block;width:7px;height:1.1em;background:var(--dok-accent);margin-left:2px;vertical-align:text-bottom;animation:cursorBlink 1s step-start infinite}.typing{display:inline-flex;gap:5px;padding:4px 0}.typing span{width:7px;height:7px;border-radius:50%;background:var(--dok-green);animation:typingBounce 1.2s infinite ease-in-out}.typing span:nth-child(2){animation-delay:.15s}.typing span:nth-child(3){animation-delay:.3s}.md p{margin:0 0 10px}.md p:last-child{margin-bottom:0}.md ul,.md ol{margin:0 0 10px;padding-left:22px}.md li{margin:3px 0}.md h1,.md h2,.md h3{margin:16px 0 8px;font-family:var(--dok-font-display)}.md h1{font-size:20px}.md h2{font-size:17px}.md h3{font-size:15px}.md a{text-decoration:underline}.md code.inline{font-family:var(--dok-font-mono);font-size:.88em;background:var(--dok-bg);border:1px solid var(--dok-border);border-radius:4px;padding:1px 5px}.md pre{margin:0 0 12px;border-radius:var(--dok-radius);overflow:hidden;border:1px solid var(--dok-border)}.md table{border-collapse:collapse;margin:0 0 12px;width:100%}.md th,.md td{border:1px solid var(--dok-border);padding:6px 10px;text-align:left}.md th{background:var(--dok-bg)}.md blockquote{border-left:3px solid var(--dok-green);margin:0 0 10px;padding-left:12px;color:var(--dok-text-secondary)}.composer{border-top:1px solid var(--dok-border);background:var(--dok-surface);padding:14px 0 16px;flex-shrink:0}.composer-inner{max-width:760px;margin:0 auto;padding:0 20px}.composer-box{display:flex;align-items:flex-end;gap:10px;background:var(--dok-surface-raised);border:1px solid var(--dok-border);border-radius:var(--dok-radius);padding:8px 8px 8px 14px;transition:border-color .15s ease}.composer-box:focus-within{border-color:var(--dok-border-bright)}.composer-box textarea{flex:1;resize:none;border:none;background:transparent;outline:none;max-height:200px;line-height:1.5;padding:5px 0}.composer-box textarea::placeholder{color:var(--dok-text-muted)}.send-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:var(--dok-accent);color:var(--dok-bg);border:none;border-radius:var(--dok-radius);cursor:pointer;transition:background .15s ease,opacity .15s ease;flex-shrink:0}.attach-btn{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;background:transparent;color:var(--dok-text-secondary);border:none;border-radius:var(--dok-radius);cursor:pointer;transition:color .15s ease,background .15s ease;flex-shrink:0}.attach-btn:hover:not(:disabled){color:var(--dok-green);background:var(--dok-surface)}.attach-btn:disabled{opacity:.4;cursor:not-allowed}.attach-chip{display:inline-flex;align-items:center;gap:6px;max-width:100%;margin-bottom:8px;padding:6px 10px;background:var(--dok-surface-raised);border:1px solid var(--dok-border);border-radius:var(--dok-radius);font-size:13px;color:var(--dok-text-secondary)}.attach-chip .attach-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attach-remove{display:inline-flex;align-items:center;background:transparent;border:none;color:var(--dok-text-muted);cursor:pointer;padding:2px}.attach-remove:hover{color:var(--dok-accent)}.attach-error{margin-bottom:8px;font-size:13px;color:#ff6b6b}.send-btn:hover:not(:disabled){background:var(--dok-accent-hover)}.send-btn:disabled{opacity:.4;cursor:not-allowed}.composer-meta{display:flex;justify-content:space-between;margin-top:6px;font-size:11px;color:var(--dok-text-muted);padding:0 4px}.empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:22px;padding:40px 20px;text-align:center}.empty-state .tagline{color:var(--dok-text-secondary);max-width:440px}.suggestions{display:flex;flex-direction:column;gap:10px;width:100%;max-width:460px}.suggestion{text-align:left;padding:12px 14px;background:var(--dok-surface);border:1px solid var(--dok-border);border-radius:var(--dok-radius);color:var(--dok-text-primary);cursor:pointer;transition:border-color .15s ease,background .15s ease}.suggestion:hover{border-color:var(--dok-accent);background:var(--dok-surface-raised)}.admin-shell{position:relative;display:flex;height:100vh;height:100dvh;overflow:hidden;z-index:2}.admin-nav{width:240px;background:var(--dok-surface);border-right:1px solid var(--dok-border);padding:20px 12px;flex-shrink:0;display:flex;flex-direction:column;gap:4px}.admin-nav-title{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--dok-text-muted);padding:12px 10px 6px}.admin-nav a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--dok-radius);color:var(--dok-text-secondary);border-left:3px solid transparent;transition:background .15s ease,color .15s ease}.admin-nav a:hover{background:var(--dok-surface-raised);color:var(--dok-text-primary)}.admin-nav a.active{background:var(--dok-green-dim);border-left-color:var(--dok-green);color:var(--dok-text-primary)}.admin-content{flex:1;overflow-y:auto;padding:32px 40px}.admin-section{max-width:680px}.admin-section h2{font-size:22px;margin-bottom:6px}.admin-section .section-desc{color:var(--dok-text-secondary);margin-bottom:24px}.field{margin-bottom:22px}.field label{display:block;font-weight:600;font-size:14px;margin-bottom:8px}.field .field-hint{font-size:12px;color:var(--dok-text-muted);margin-top:6px}.field-row{display:flex;justify-content:space-between;align-items:baseline}.field-value{font-family:var(--dok-font-mono);color:var(--dok-accent);font-size:13px}.input,.select,.textarea{width:100%;background:var(--dok-surface-raised);border:1px solid var(--dok-border);border-radius:var(--dok-radius);padding:10px 12px;outline:none;transition:border-color .15s ease}.input:focus,.select:focus,.textarea:focus{border-color:var(--dok-border-bright)}.textarea{resize:vertical;min-height:120px;line-height:1.5}input[type=range]{width:100%;accent-color:var(--dok-accent);cursor:pointer}.btn-primary{display:inline-flex;align-items:center;gap:8px;background:var(--dok-accent);color:var(--dok-bg);font-weight:600;border:none;border-radius:var(--dok-radius);padding:11px 20px;cursor:pointer;transition:background .15s ease,opacity .15s ease}.btn-primary:hover:not(:disabled){background:var(--dok-accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-ghost{background:transparent;border:1px solid var(--dok-border);color:var(--dok-text-secondary);border-radius:var(--dok-radius);padding:9px 16px;cursor:pointer;transition:border-color .15s ease,color .15s ease}.btn-ghost:hover{border-color:var(--dok-border-bright);color:var(--dok-text-primary)}.badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;padding:4px 10px;border-radius:100px}.badge.ok{background:var(--dok-green-dim);color:var(--dok-green-hover)}.badge.off{background:#e0505020;color:var(--dok-error)}.toast{position:fixed;bottom:24px;right:24px;z-index:50;padding:12px 18px;border-radius:var(--dok-radius);border:1px solid var(--dok-border-bright);background:var(--dok-surface-raised);animation:messageIn .2s ease-out}.toast.ok{border-color:var(--dok-green)}.toast.err{border-color:var(--dok-error)}.toggle{position:relative;display:inline-block;width:44px;height:24px}.toggle input{opacity:0;width:0;height:0}.toggle .track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--dok-border);border-radius:100px;transition:background .15s ease}.toggle .track:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:var(--dok-text-primary);border-radius:50%;transition:transform .15s ease}.toggle input:checked+.track{background:var(--dok-green)}.toggle input:checked+.track:before{transform:translate(20px)}.dropzone{border:2px dashed var(--dok-border-bright);border-radius:var(--dok-radius);padding:36px 20px;text-align:center;color:var(--dok-text-secondary);cursor:pointer;transition:border-color .15s ease,background .15s ease}.dropzone.active{border-color:var(--dok-accent);background:var(--dok-accent-dim)}.progress-track{height:8px;background:var(--dok-surface-raised);border-radius:100px;overflow:hidden;margin-top:12px}.progress-fill{height:100%;background:var(--dok-accent);transition:width .2s ease}.doc-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--dok-surface);border:1px solid var(--dok-border);border-radius:var(--dok-radius);margin-top:10px}.doc-row .doc-meta{flex:1;min-width:0}.doc-row .doc-name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-row .doc-sub{font-size:12px;color:var(--dok-text-muted)}.login-screen{position:relative;z-index:2;height:100vh;height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:20px}.login-card{width:100%;max-width:360px;background:var(--dok-surface);border:1px solid var(--dok-border);border-radius:var(--dok-radius);padding:28px;display:flex;flex-direction:column;gap:14px}.spinner{width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .7s linear infinite}.error-banner{background:#e0505018;border:1px solid var(--dok-error);color:#f0a0a0;border-radius:var(--dok-radius);padding:10px 14px;font-size:13px;margin:0 auto 12px;max-width:760px}.mobile-only,.sidebar-backdrop{display:none}@media (max-width: 768px){.mobile-only{display:inline-flex}.sidebar{position:fixed;top:0;left:0;bottom:0;z-index:40;transform:translate(-100%);transition:transform .2s ease}.sidebar.open{transform:translate(0)}.sidebar-backdrop.show{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:35;background:#00000080}.admin-content{padding:24px 18px}.admin-nav{width:200px}.composer-box textarea,.input,.select{font-size:16px}.header{height:56px;padding:0 14px}.header .header-title{display:none}.composer{padding-top:12px}.messages-inner{padding-left:14px;padding-right:14px}.bubble{max-width:92%}.empty-state{padding:0 18px}}.composer{padding-bottom:calc(16px + env(safe-area-inset-bottom));padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.sidebar{padding-bottom:env(safe-area-inset-bottom)}
