:root{--bg:#0a0f1e;--bg-card:#111827;--bg-hover:#1e2a3a;--bg-sidebar:#0d1424;--border:#1e293b;--border-light:#263248;--text:#f1f5f9;--text-muted:#64748b;--text-sub:#94a3b8;--primary:#3b82f6;--primary-hover:#2563eb;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--sidebar-w:220px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px;line-height:1.5}#root{min-height:100vh}.portal-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);border-right:1px solid var(--border);z-index:100;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-brand{color:var(--text);border-bottom:1px solid var(--border);white-space:nowrap;align-items:center;gap:.625rem;padding:1.25rem 1rem;font-size:.9375rem;font-weight:600;display:flex;overflow:hidden}.sidebar-brand svg{color:var(--primary);flex-shrink:0}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:.75rem .5rem;display:flex;overflow-y:auto}.sidebar-link{color:var(--text-muted);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:.625rem;width:100%;padding:.5rem .75rem;font-family:inherit;font-size:.875rem;transition:all .15s;display:flex}.sidebar-link:hover{background:var(--bg-hover);color:var(--text)}.sidebar-link.active{background:color-mix(in srgb, var(--primary) 15%, transparent);color:var(--primary);font-weight:500}.sidebar-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem;display:flex}.sidebar-assistant-badge{color:var(--text-muted);align-items:center;gap:.375rem;font-size:.8125rem;display:flex;overflow:hidden}.sidebar-logout{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;flex-shrink:0;padding:4px;display:flex}.sidebar-logout:hover{color:var(--danger);background:#ef44441a}.portal-main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;display:flex}.chat-widget{z-index:1000;flex-direction:column;align-items:flex-end;gap:.75rem;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.chat-bubble{background:var(--primary);cursor:pointer;color:#fff;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 4px 16px #00000040}.chat-bubble:hover{transform:scale(1.08);box-shadow:0 6px 20px #0000004d}.chat-bubble-open{background:var(--bg-card);color:var(--text)}.chat-bubble-emoji{font-size:1.5rem;line-height:1}.chat-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;flex-direction:column;width:380px;max-width:calc(100vw - 32px);height:520px;max-height:calc(100vh - 48px);animation:.2s panel-in;display:flex;overflow:hidden;box-shadow:0 12px 48px #0006}@keyframes panel-in{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.chat-header{background:linear-gradient(135deg, var(--primary), color-mix(in srgb, var(--primary) 70%, #000));align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.chat-header-icon{background:#ffffff26;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;display:flex}.chat-header-info{flex:1}.chat-header-name{color:#fff;font-size:1rem;font-weight:600}.chat-header-sub{color:#ffffffa6;margin-top:1px;font-size:.75rem}.chat-header-btn{color:#fff9;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px;transition:all .15s;display:flex}.chat-header-btn:hover{color:#fff;background:#ffffff26}.chat-messages{scroll-behavior:smooth;flex-direction:column;flex:1;gap:1rem;padding:1.25rem;display:flex;overflow-y:auto}.chat-msg{align-items:flex-end;gap:.625rem;max-width:85%;animation:.2s msg-in;display:flex}@keyframes msg-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.chat-msg-user{flex-direction:row-reverse;align-self:flex-end}.chat-msg-assistant{align-self:flex-start}.chat-msg-avatar{background:color-mix(in srgb, var(--primary) 20%, transparent);width:28px;height:28px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-bottom:2px;display:flex}.chat-msg-bubble{white-space:pre-wrap;word-break:break-word;border-radius:14px;padding:.625rem .875rem;font-size:.875rem;line-height:1.6}.chat-msg-user .chat-msg-bubble{background:var(--primary);color:#fff;border-radius:14px 14px 4px}.chat-msg-assistant .chat-msg-bubble{background:var(--bg-hover);color:var(--text);border:1px solid var(--border-light);border-radius:14px 14px 14px 4px}.chat-msg-loading{align-items:center;gap:5px;display:flex;padding:.75rem 1rem!important}.dot{background:var(--text-muted);border-radius:50%;width:6px;height:6px;animation:1.2s infinite bounce}.dot:nth-child(2){animation-delay:.15s}.dot:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-5px)}}.chat-input-area{border-top:1px solid var(--border);background:var(--bg-card);gap:.625rem;padding:.875rem 1rem;display:flex}.chat-input{background:var(--bg-hover);border:1px solid var(--border-light);color:var(--text);border-radius:10px;outline:none;flex:1;max-height:120px;padding:.625rem .875rem;font-family:inherit;font-size:.875rem;transition:border-color .2s}.chat-input:focus{border-color:var(--primary)}.chat-input::placeholder{color:var(--text-muted)}.chat-send-btn{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:10px;flex-shrink:0;justify-content:center;align-self:flex-end;align-items:center;width:40px;height:40px;transition:all .15s;display:flex}.chat-send-btn:hover:not(:disabled){background:var(--primary-hover)}.chat-send-btn:disabled{opacity:.45;cursor:not-allowed}.chat-powered{text-align:center;color:var(--text-muted);background:var(--bg-card);padding:5px;font-size:.6875rem}.chat-powered a{color:var(--text-sub);text-decoration:none}.chat-powered a:hover{color:var(--primary)}.page{max-width:1100px;padding:2rem 1.5rem}.page-header{margin-bottom:1.5rem}.page-title{color:var(--text);font-size:1.5rem;font-weight:700}.page-subtitle{color:var(--text-muted);margin-top:2px;font-size:.875rem}.stats-row{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;min-width:150px;padding:1rem 1.25rem}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:.75rem}.stat-value{color:var(--text);font-size:1.25rem;font-weight:700}.stage-pills{flex-wrap:wrap;gap:.5rem;margin-bottom:1rem;display:flex}.stage-pill{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;background:0 0;border-radius:999px;align-items:center;gap:.375rem;padding:.3125rem .75rem;font-family:inherit;font-size:.8125rem;transition:all .15s;display:inline-flex}.stage-pill:hover{border-color:var(--text-sub);color:var(--text)}.stage-pill.active{border-color:var(--primary);color:var(--primary);background:color-mix(in srgb, var(--primary) 10%, transparent)}.stage-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.data-table-wrap{border:1px solid var(--border);border-radius:10px;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:.875rem}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);background:var(--bg-card);border-bottom:1px solid var(--border);white-space:nowrap;padding:.75rem 1rem;font-size:.75rem;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;padding:.75rem 1rem}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table .row-danger td{background:#ef44440d}.contact-list{flex-direction:column;gap:1px;display:flex}.contact-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;margin-bottom:6px;overflow:hidden}.contact-row{align-items:center;gap:.875rem;padding:.875rem 1rem;transition:background .15s;display:flex}.contact-row:hover{background:var(--bg-hover)}.contact-avatar{background:color-mix(in srgb, var(--primary) 20%, transparent);width:38px;height:38px;color:var(--primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.875rem;font-weight:700;display:flex}.contact-info{flex:1}.contact-name{font-weight:500}.contact-company{color:var(--text-muted);margin-top:1px;font-size:.8125rem}.contact-meta{align-items:center;gap:.625rem;display:flex}.contact-details{border-top:1px solid var(--border);background:var(--bg);flex-direction:column;gap:.5rem;padding:.875rem 1rem 1rem;display:flex}.detail-row{gap:1rem;display:flex}.detail-label{color:var(--text-muted);flex-shrink:0;width:110px;font-size:.8125rem}.detail-value{color:var(--text);font-size:.875rem}.detail-value.link{color:var(--primary);text-decoration:none}.detail-value.link:hover{text-decoration:underline}.login-screen{background:radial-gradient(ellipse at 50% 0%, color-mix(in srgb, var(--primary) 12%, transparent) 0%, transparent 70%), var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);text-align:center;border-radius:16px;width:100%;max-width:380px;padding:2.5rem 2rem}.login-icon{margin-bottom:1rem;font-size:2.5rem}.login-title{color:var(--text);font-size:1.375rem;font-weight:700}.login-subtitle{color:var(--text-muted);margin-top:4px;margin-bottom:2rem;font-size:.875rem}.login-form{text-align:left;flex-direction:column;gap:1rem;display:flex}.form-group{flex-direction:column;gap:.375rem;display:flex}.form-label{color:var(--text-sub);font-size:.8125rem;font-weight:500}.login-error{color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;padding:.625rem .875rem;font-size:.875rem}.login-footer{color:var(--text-muted);margin-top:1.5rem;font-size:.75rem}.login-footer a{color:var(--text-sub);text-decoration:none}.login-footer a:hover{color:var(--primary)}.input{background:var(--bg-hover);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;padding:.625rem .875rem;font-family:inherit;font-size:.875rem;transition:border-color .2s}.input:focus{border-color:var(--primary)}.input::placeholder{color:var(--text-muted)}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.5rem 1rem;font-family:inherit;font-size:.875rem;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.badge{white-space:nowrap;border-radius:999px;align-items:center;padding:.125rem .5rem;font-size:.6875rem;font-weight:600;display:inline-flex}.badge-ghost{background:var(--bg-hover);color:var(--text-muted);border:1px solid var(--border)}.splash{justify-content:center;align-items:center;gap:6px;min-height:100vh;display:flex}.splash-dot{background:var(--primary);border-radius:50%;width:8px;height:8px;animation:1.2s infinite bounce}.text-muted{color:var(--text-muted)}.monospace{font-family:SF Mono,Fira Code,monospace;font-size:.8125rem}.small{font-size:.8125rem}.loading-text{text-align:center;color:var(--text-muted);padding:2rem}.empty-state{text-align:center;color:var(--text-muted);padding:3rem;font-size:.9375rem}.spin{animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.modal-overlay{z-index:500;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:620px;max-height:85vh;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h2{font-size:1.125rem;font-weight:600}.modal-body{flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:.5rem;padding:1rem 1.5rem;display:flex}.form-row{flex-direction:column;gap:.375rem;display:flex}.form-row label{color:var(--text-sub);font-size:.8125rem;font-weight:500}.select{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:8px;outline:none;width:100%;padding:.625rem .75rem;font-size:.875rem}.select:focus{border-color:var(--primary)}.template-info{background:var(--bg);border:1px solid var(--border-light);color:var(--text-sub);border-radius:8px;padding:.75rem 1rem;font-size:.8125rem}.template-info span{color:var(--text);font-weight:500}.line-items{flex-direction:column;gap:.5rem;display:flex}.line-item{grid-template-columns:1fr 80px 100px 32px;align-items:center;gap:.5rem;display:grid}.line-item input{width:100%}.line-total{text-align:right;color:var(--text-sub);padding:.5rem 0;font-size:.875rem}.line-total strong{color:var(--text)}.btn-ghost{border:1px solid var(--border);color:var(--text-sub);cursor:pointer;background:0 0;border-radius:8px;padding:.5rem 1rem;font-size:.8125rem}.btn-ghost:hover{border-color:var(--text-muted);color:var(--text)}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-icon{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem;font-size:1.125rem}.btn-icon:hover{color:var(--danger)}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-light)}
