*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #faf8f5;--bg-secondary: #f5f2ed;--text-primary: #2d2926;--text-secondary: #6b6560;--accent: #c4a574;--accent-dark: #a08050;--white: #ffffff;--border: #e8e4de;--shadow: rgba(45, 41, 38, .08);--font-display: "Playfair Display", Georgia, serif;--font-body: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif}body.dark-mode{--bg-primary: #1a1918;--bg-secondary: #252322;--text-primary: #f5f2ed;--text-secondary: #a09a94;--white: #2d2926;--border: #3d3835;--shadow: rgba(0, 0, 0, .3)}html,body{height:100%;font-family:var(--font-body);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;transition:background .3s ease,color .3s ease}#root{height:100%}.app{height:100%;display:flex;flex-direction:column;position:relative;overflow:hidden}.background-texture{position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 20% 20%,rgba(196,165,116,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(196,165,116,.05) 0%,transparent 50%),var(--bg-primary);pointer-events:none;z-index:0;transition:background .3s ease}body.dark-mode .background-texture{background:radial-gradient(ellipse at 20% 20%,rgba(196,165,116,.05) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(196,165,116,.03) 0%,transparent 50%),var(--bg-primary)}.header{background:var(--white);border-bottom:1px solid var(--border);padding:1rem 1.5rem;position:relative;z-index:10;transition:background .3s ease,border-color .3s ease}.header-content{max-width:900px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.logo{display:flex;align-items:center;gap:.75rem}.logo-icon{font-size:1.75rem;color:var(--accent)}.logo-text h1{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--text-primary);letter-spacing:-.02em}.tagline{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em}.header-actions{display:flex;align-items:center;gap:.5rem}.icon-btn{background:transparent;border:1px solid var(--border);width:38px;height:38px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all .2s ease}.icon-btn:hover{border-color:var(--accent);color:var(--accent-dark);background:#c4a5740d}.clear-btn{background:transparent;border:1px solid var(--border);padding:.5rem 1rem;border-radius:6px;font-family:var(--font-body);font-size:.875rem;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.clear-btn:hover{border-color:var(--accent);color:var(--accent-dark);background:#c4a5740d}.chat-container{flex:1;display:flex;flex-direction:column;max-width:900px;width:100%;margin:0 auto;position:relative;z-index:1;overflow:hidden}.messages-wrapper{flex:1;overflow-y:auto;padding:2rem 1.5rem}.messages{display:flex;flex-direction:column;gap:1.5rem}.message{display:flex;gap:1rem;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{justify-content:flex-end}.message-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--white);font-size:1.25rem}.message-content-wrapper{display:flex;flex-direction:column;gap:.5rem;max-width:75%}.message-content{background:var(--white);padding:1rem 1.25rem;border-radius:16px;border:1px solid var(--border);box-shadow:0 2px 8px var(--shadow);transition:background .3s ease,border-color .3s ease}.message.user .message-content-wrapper{align-items:flex-end}.message.user .message-content{background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);color:var(--white);border:none;border-radius:16px 16px 4px}.message.assistant .message-content{border-radius:16px 16px 16px 4px}.message.error .message-content{background:#fef2f2;border-color:#fecaca;color:#991b1b}body.dark-mode .message.error .message-content{background:#3d2626;border-color:#5c3a3a;color:#fca5a5}.message-text{font-size:.9375rem;line-height:1.7}.message-text strong{font-weight:600}.message-text .heading{display:block;font-weight:700;font-size:1.1em;margin:.75em 0 .5em;color:var(--accent-dark)}.message-text a{color:var(--accent-dark);text-decoration:underline}.message.user .message-text a{color:var(--white)}.loading-content{display:flex;flex-direction:column;gap:.5rem}.loading-text{font-size:.8125rem;color:var(--text-secondary);font-style:italic;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.6}50%{opacity:1}}.copy-btn{align-self:flex-start;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;padding:.375rem .75rem;cursor:pointer;transition:all .2s ease;color:var(--text-secondary);display:flex;align-items:center;gap:.375rem;font-size:.75rem;font-family:var(--font-body)}.copy-btn:hover{background:var(--white);border-color:var(--accent);color:var(--accent-dark)}.copy-btn.copied{background:#dcfce7;border-color:#86efac;color:#16a34a}body.dark-mode .copy-btn.copied{background:#1a3d2a;border-color:#2d5a3d;color:#86efac}.typing-indicator{display:flex;gap:4px;padding:4px 0}.typing-indicator span{width:8px;height:8px;background:var(--accent);border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.quick-picks{padding:0 1.5rem 1rem}.quick-picks-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem;text-align:center}.quick-picks-grid{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.quick-pick-btn{background:var(--white);border:1px solid var(--border);border-radius:20px;padding:.5rem 1rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-family:var(--font-body);font-size:.875rem;color:var(--text-primary);transition:all .2s ease}.quick-pick-btn:hover{border-color:var(--accent);background:#c4a57414;transform:translateY(-2px);box-shadow:0 4px 12px var(--shadow)}.quick-pick-emoji{font-size:1.125rem}.chat-input-form{padding:1rem 1.5rem 1.5rem;background:linear-gradient(to top,var(--bg-primary) 80%,transparent)}.input-wrapper{display:flex;gap:.75rem;background:var(--white);border:1px solid var(--border);border-radius:16px;padding:.75rem 1rem;box-shadow:0 4px 12px var(--shadow);transition:all .2s ease}.input-wrapper:focus-within{border-color:var(--accent);box-shadow:0 4px 16px #c4a57426}.input-wrapper textarea{flex:1;border:none;outline:none;resize:none;font-family:var(--font-body);font-size:.9375rem;line-height:1.5;color:var(--text-primary);background:transparent;min-height:24px;max-height:200px}.input-wrapper textarea::placeholder{color:var(--text-secondary)}.input-wrapper button{width:40px;height:40px;border:none;background:linear-gradient(135deg,var(--accent) 0%,var(--accent-dark) 100%);border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s ease,opacity .2s ease}.input-wrapper button:hover:not(:disabled){transform:scale(1.05)}.input-wrapper button:disabled{opacity:.5;cursor:not-allowed}.input-wrapper button svg{width:18px;height:18px;color:var(--white)}.confetti-container{position:fixed;top:0;left:0;right:0;bottom:0;pointer-events:none;z-index:1000;overflow:hidden}.confetti-piece{position:absolute;top:-20px;width:10px;height:10px;border-radius:2px;animation:confetti-fall linear forwards}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.footer{text-align:center;padding:.75rem;color:var(--text-secondary);font-size:.75rem;position:relative;z-index:1}.messages-wrapper::-webkit-scrollbar{width:6px}.messages-wrapper::-webkit-scrollbar-track{background:transparent}.messages-wrapper::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.messages-wrapper::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media (max-width: 640px){.header{padding:.75rem 1rem}.logo-text h1{font-size:1.25rem}.tagline{display:none}.messages-wrapper{padding:1rem}.message-content-wrapper{max-width:85%}.chat-input-form{padding:.75rem 1rem 1rem}.quick-picks{padding:0 1rem 1rem}.quick-pick-btn{padding:.375rem .75rem;font-size:.8125rem}.header-actions{gap:.25rem}.icon-btn{width:34px;height:34px}.clear-btn{padding:.375rem .75rem;font-size:.8125rem}}
