*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0a0f;--bg2: #0f0f1a;--bg3: #13131f;--border: rgba(255,255,255,.07);--border-hover: rgba(167,139,250,.3);--purple: #a78bfa;--blue: #60a5fa;--green: #34d399;--text: #e2e8f0;--muted: #64748b;--muted2: #475569;--user-bubble: linear-gradient(135deg, #7c3aed, #4f46e5);--ai-bubble: #13131f;--radius: 18px;--shadow: 0 8px 32px rgba(0,0,0,.4)}html,body,#root{height:100%}body{font-family:Inter,sans-serif;background:var(--bg);color:var(--text);overflow:hidden}.orb{position:fixed;border-radius:50%;filter:blur(80px);pointer-events:none;z-index:0;opacity:.4}.orb1{width:500px;height:500px;background:radial-gradient(circle,#7c3aed33,transparent);top:-200px;right:-100px}.orb2{width:400px;height:400px;background:radial-gradient(circle,#1d4ed833,transparent);bottom:-150px;left:-100px}.orb3{width:300px;height:300px;background:radial-gradient(circle,#065f4633,transparent);top:40%;left:40%}.app{display:flex;flex-direction:column;height:100vh;position:relative;z-index:1;max-width:900px;margin:0 auto}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border);background:#0a0a0fcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-shrink:0}.header-left{display:flex;align-items:center;gap:12px}.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,#7c3aed22,#1d4ed822);border:1px solid var(--border-hover);border-radius:10px;display:flex;align-items:center;justify-content:center}.logo-title{font-size:18px;font-weight:700;background:linear-gradient(135deg,#a78bfa,#60a5fa);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.logo-sub{font-size:11px;color:var(--muted);display:block}.header-right{display:flex;align-items:center;gap:12px}.clear-btn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;background:#ffffff0d;border:1px solid var(--border);color:var(--muted);font-size:13px;cursor:pointer;transition:all .2s;font-family:inherit}.clear-btn:hover{background:#ef44441a;border-color:#ef44444d;color:#f87171}.portfolio-link{font-size:13px;font-weight:500;color:var(--purple);text-decoration:none;transition:opacity .2s}.portfolio-link:hover{opacity:.7}.chat-area{flex:1;overflow-y:auto;padding:24px;scroll-behavior:smooth}.chat-area::-webkit-scrollbar{width:4px}.chat-area::-webkit-scrollbar-track{background:transparent}.chat-area::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;animation:fadeUp .5s ease}.welcome-icon{width:80px;height:80px;background:linear-gradient(135deg,#7c3aed15,#1d4ed815);border:1px solid var(--border-hover);border-radius:24px;display:flex;align-items:center;justify-content:center;margin-bottom:24px}.welcome-title{font-size:32px;font-weight:700;margin-bottom:12px}.welcome-sub{color:var(--muted);font-size:15px;margin-bottom:40px;max-width:460px;line-height:1.6}.suggestions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:680px}.suggestion-chip{padding:10px 18px;border-radius:24px;background:var(--bg3);border:1px solid var(--border);color:var(--text);font-size:13px;cursor:pointer;transition:all .2s;font-family:inherit}.suggestion-chip:hover{border-color:var(--border-hover);background:#a78bfa14;transform:translateY(-1px)}.messages{display:flex;flex-direction:column;gap:20px;animation:fadeUp .3s ease}.msg-row{display:flex;gap:12px;align-items:flex-start;animation:fadeUp .3s ease}.msg-row.user{flex-direction:row-reverse}.msg-row.ai{flex-direction:row}.avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.ai-avatar{background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff}.user-avatar{background:linear-gradient(135deg,#0f766e,#0891b2);color:#fff}.bubble{max-width:72%;padding:14px 18px;border-radius:18px;font-size:15px;line-height:1.65;word-break:break-word}.ai-bubble{background:var(--ai-bubble);border:1px solid var(--border);border-top-left-radius:4px;color:var(--text)}.user-bubble{background:var(--user-bubble);border-top-right-radius:4px;color:#fff}.ai-bubble h1,.ai-bubble h2,.ai-bubble h3{margin:12px 0 8px;font-weight:600}.ai-bubble h1{font-size:20px}.ai-bubble h2{font-size:17px}.ai-bubble h3{font-size:15px}.ai-bubble p{margin-bottom:10px}.ai-bubble p:last-child{margin-bottom:0}.ai-bubble ul,.ai-bubble ol{padding-left:20px;margin-bottom:10px}.ai-bubble li{margin-bottom:4px}.ai-bubble code{background:#a78bfa26;border:1px solid rgba(167,139,250,.2);padding:2px 6px;border-radius:6px;font-family:JetBrains Mono,monospace;font-size:13px;color:#c4b5fd}.ai-bubble pre{background:#0006;border:1px solid var(--border);border-radius:12px;padding:16px;overflow-x:auto;margin:10px 0}.ai-bubble pre code{background:none;border:none;padding:0;color:#e2e8f0;font-size:13px;line-height:1.6}.ai-bubble blockquote{border-left:3px solid var(--purple);padding-left:14px;margin:8px 0;color:var(--muted)}.ai-bubble a{color:var(--blue);text-decoration:underline}.ai-bubble strong{color:#fff;font-weight:600}.ai-bubble table{width:100%;border-collapse:collapse;margin:10px 0}.ai-bubble th,.ai-bubble td{padding:8px 12px;border:1px solid var(--border);font-size:13px}.ai-bubble th{background:#a78bfa1a}.typing-bubble{display:flex;align-items:center;gap:6px;padding:14px 18px;min-width:60px}.dot{width:8px;height:8px;border-radius:50%;background:var(--purple);opacity:.7;animation:pulse 1.4s ease-in-out infinite}.dot:nth-child(2){animation-delay:.2s}.dot:nth-child(3){animation-delay:.4s}.error-bar{margin:0 24px 12px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;color:#f87171;font-size:14px}.input-area{padding:16px 24px 20px;border-top:1px solid var(--border);background:#0a0a0fcc;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-shrink:0}.input-wrapper{display:flex;gap:10px;align-items:flex-end;background:var(--bg3);border:1px solid var(--border);border-radius:16px;padding:10px 10px 10px 16px;transition:border-color .2s}.input-wrapper:focus-within{border-color:#a78bfa80}.chat-input{flex:1;background:none;border:none;outline:none;color:var(--text);font-size:15px;font-family:Inter,sans-serif;resize:none;line-height:1.5;max-height:200px;overflow-y:auto}.chat-input::placeholder{color:var(--muted)}.send-btn{width:38px;height:38px;border-radius:10px;flex-shrink:0;background:linear-gradient(135deg,#7c3aed,#4f46e5);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.send-btn:hover:not(.disabled){transform:translateY(-1px);box-shadow:0 4px 14px #7c3aed80}.send-btn.disabled{opacity:.4;cursor:not-allowed;background:var(--muted2)}.disclaimer{font-size:11px;color:var(--muted2);text-align:center;margin-top:10px}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,80%,to{transform:scale(.7);opacity:.4}40%{transform:scale(1);opacity:1}}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 600px){.header{padding:12px 16px}.logo-sub{display:none}.chat-area{padding:16px}.bubble{max-width:88%;font-size:14px}.input-area{padding:12px 16px 16px}.suggestions{gap:8px}.suggestion-chip{font-size:12px;padding:8px 14px}.welcome-title{font-size:24px}}
