@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@400;500;600;700&display=swap";*{box-sizing:border-box}:root{font-family:Noto Sans KR,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#0d1117;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}a{color:#81c784;text-decoration:none}a:hover{color:#a5d6a7}button{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1f2e,#0d1117);position:relative;overflow:hidden}.login-background{position:absolute;inset:0;pointer-events:none}.bamboo-pattern{position:absolute;inset:0;background:radial-gradient(circle at 20% 80%,rgba(76,175,80,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(129,199,132,.08) 0%,transparent 50%),radial-gradient(circle at 50% 50%,rgba(46,125,50,.05) 0%,transparent 70%)}.login-card{position:relative;z-index:1;background:#ffffff08;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:48px 40px;max-width:420px;width:100%;margin:20px;box-shadow:0 4px 24px #0006,0 0 80px #4caf5014}.login-header{text-align:center;margin-bottom:40px}.bamboo-icon{font-size:64px;margin-bottom:16px;filter:drop-shadow(0 4px 12px rgba(76,175,80,.3))}.login-title{font-size:28px;font-weight:700;color:#fff;margin:0 0 12px;background:linear-gradient(135deg,#81c784,#4caf50);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-subtitle{color:#fff9;font-size:15px;line-height:1.6;margin:0}.login-buttons{display:flex;flex-direction:column;gap:12px}.login-btn{display:flex;align-items:center;justify-content:center;gap:12px;width:100%;padding:16px 24px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.login-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(255,255,255,.1),transparent);opacity:0;transition:opacity .3s}.login-btn:hover:before{opacity:1}.login-btn-icon{width:20px;height:20px}.kakao-btn{background:#fee500;color:#000}.kakao-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #fee5004d}.google-btn{background:#fff;color:#333}.google-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #fff3}.login-footer{text-align:center;margin-top:32px;font-size:12px;color:#fff6}.login-footer a{color:#81c784cc;text-decoration:none;transition:color .2s}.login-footer a:hover{color:#81c784}@media(max-width:480px){.login-card{padding:32px 24px;border-radius:20px}.bamboo-icon{font-size:48px}.login-title{font-size:24px}}.profile-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.profile-modal{background:linear-gradient(145deg,#1e2533,#171c28);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:32px;max-width:400px;width:90%;position:relative;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.profile-close{position:absolute;top:16px;right:16px;width:32px;height:32px;border:none;background:#ffffff0d;border-radius:8px;cursor:pointer;color:#ffffff80;transition:all .2s;display:flex;align-items:center;justify-content:center}.profile-close:hover{background:#ffffff1a;color:#fff}.profile-close svg{width:18px;height:18px}.profile-title{font-size:22px;font-weight:600;color:#fff;margin:0 0 24px}.profile-form{display:flex;flex-direction:column;gap:20px}.profile-field{position:relative}.profile-field label{display:block;font-size:13px;color:#fff9;margin-bottom:8px}.profile-field input{width:100%;padding:14px 60px 14px 16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-size:15px;transition:all .2s;box-sizing:border-box}.profile-field input:focus{outline:none;border-color:#4caf50;background:#4caf500d}.profile-field input::placeholder{color:#ffffff4d}.char-count{position:absolute;right:14px;bottom:14px;font-size:12px;color:#fff6}.profile-error{color:#f44336;font-size:13px;margin:0;padding:12px 16px;background:#f443361a;border-radius:8px}.profile-info{padding:16px;background:#ffffff08;border-radius:12px;font-size:13px;color:#ffffff80}.profile-info p{margin:0}.profile-info p+p{margin-top:8px}.profile-info strong{color:#ffffffb3}.profile-actions{display:flex;flex-direction:column;gap:12px;margin-top:8px}.profile-save-btn{padding:14px 24px;background:linear-gradient(135deg,#4caf50,#388e3c);border:none;border-radius:12px;color:#fff;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s}.profile-save-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #4caf504d}.profile-save-btn:disabled{opacity:.6;cursor:not-allowed}.profile-logout-btn{padding:14px 24px;background:transparent;border:1px solid rgba(244,67,54,.3);border-radius:12px;color:#f44336;font-size:15px;font-weight:500;cursor:pointer;transition:all .3s}.profile-logout-btn:hover{background:#f443361a;border-color:#f4433680}.app-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#0d1117f2;border-bottom:1px solid rgba(255,255,255,.06);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:0;z-index:100}.header-brand{display:flex;align-items:center;gap:12px}.brand-icon{font-size:28px}.brand-name{font-size:18px;font-weight:600;background:linear-gradient(135deg,#81c784,#4caf50);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-actions{display:flex;align-items:center;gap:12px}.coffee-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#ff9800,#f57c00);border:none;border-radius:20px;color:#fff;font-size:13px;font-weight:600;text-decoration:none;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #ff98004d}.coffee-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff980066;background:linear-gradient(135deg,#ffa726,#ff9800)}.coffee-icon{font-size:16px}.coffee-text{white-space:nowrap}.header-profile{display:flex;align-items:center;gap:10px;padding:8px 12px 8px 8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:12px;cursor:pointer;transition:all .2s;color:#fff}.header-profile:hover{background:#ffffff14;border-color:#ffffff1f}.profile-avatar{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,#4caf50,#388e3c);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600}.profile-name{font-size:14px;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-arrow{width:18px;height:18px;opacity:.5}@media(max-width:768px){.app-header{padding:12px 16px}.brand-name{font-size:16px}.coffee-text{display:none}.coffee-btn{padding:8px 12px}.profile-name{display:none}}.sidebar-overlay{position:fixed;inset:0;background:#00000080;opacity:0;visibility:hidden;transition:all .3s;z-index:200}.sidebar-overlay.open{opacity:1;visibility:visible}.sidebar{position:fixed;top:0;left:0;width:300px;height:100%;background:linear-gradient(180deg,#1a1f2e,#0d1117);border-right:1px solid rgba(255,255,255,.06);transform:translate(-100%);transition:transform .3s ease;z-index:201;display:flex;flex-direction:column}.sidebar.open{transform:translate(0)}.sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.06)}.sidebar-header h2{font-size:16px;font-weight:600;color:#fff;margin:0 0 16px}.new-chat-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;background:linear-gradient(135deg,#4caf50,#388e3c);border:none;border-radius:10px;color:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.new-chat-btn:hover{transform:translateY(-2px);box-shadow:0 4px 16px #4caf504d}.new-chat-btn svg{width:18px;height:18px}.session-list{flex:1;overflow-y:auto;padding:12px}.no-sessions{color:#fff6;font-size:14px;text-align:center;padding:32px 16px}.session-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:10px;cursor:pointer;transition:all .2s;margin-bottom:4px}.session-item:hover{background:#ffffff0d}.session-item.active{background:#4caf5026;border:1px solid rgba(76,175,80,.3)}.session-info{flex:1;min-width:0}.session-title{display:block;font-size:14px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-date{font-size:12px;color:#fff6}.session-delete{width:28px;height:28px;border:none;background:transparent;border-radius:6px;color:#fff6;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s}.session-item:hover .session-delete{opacity:1}.session-delete:hover{background:#f4433633;color:#f44336}.session-delete svg{width:16px;height:16px}@media(min-width:769px){.sidebar-overlay{display:none}.sidebar{position:relative;transform:none;width:280px;flex-shrink:0}}.chat-bubble{display:flex;gap:12px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-bubble.user{justify-content:flex-end}.chat-bubble.assistant{justify-content:flex-start}.bubble-avatar{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#4caf5033,#2e7d3233);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.bubble-content{max-width:70%;display:flex;flex-direction:column;gap:6px}.bubble-text{padding:14px 18px;border-radius:18px;font-size:15px;line-height:1.6;word-break:break-word;white-space:pre-wrap}.chat-bubble.user .bubble-text{background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff;border-radius:18px 18px 4px}.chat-bubble.assistant .bubble-text{background:#ffffff0d;border:1px solid rgba(255,255,255,.08);color:#ffffffe6;border-radius:18px 18px 18px 4px}.bubble-time{font-size:11px;color:#ffffff4d;padding:0 4px}.chat-bubble.user .bubble-time{text-align:right}@media(max-width:768px){.bubble-content{max-width:85%}.bubble-avatar{width:36px;height:36px}}.message-list{display:flex;flex-direction:column;gap:16px}.typing-indicator{display:flex;align-items:center;gap:6px;padding:16px 20px;background:#4caf501a;border-radius:18px 18px 18px 4px;width:fit-content;max-width:80px}.typing-dot{width:8px;height:8px;background:#4caf50;border-radius:50%;animation:bounce 1.4s ease-in-out infinite}.typing-dot:nth-child(1){animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}.message-input-container{padding:16px 24px 24px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.3))}.input-wrapper{display:flex;gap:12px;align-items:flex-end;background:#ffffff0d;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:12px 16px;transition:all .2s}.input-wrapper:focus-within{border-color:#4caf5080;background:#4caf500d}.message-textarea{flex:1;background:transparent;border:none;color:#fff;font-size:15px;line-height:1.5;resize:none;min-height:24px;max-height:150px;font-family:inherit}.message-textarea:focus{outline:none}.message-textarea::placeholder{color:#fff6}.message-textarea:disabled{opacity:.5}.send-button{width:44px;height:44px;border:none;border-radius:12px;background:linear-gradient(135deg,#4caf50,#388e3c);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.send-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 16px #4caf5066}.send-button:disabled{background:#ffffff1a;color:#ffffff4d;cursor:not-allowed}.send-button svg{width:20px;height:20px}.input-hint{text-align:center;font-size:11px;color:#ffffff4d;margin:8px 0 0}@media(max-width:768px){.message-input-container{padding:12px 16px 16px}.send-button{width:40px;height:40px}}.chat-window{flex:1;display:flex;flex-direction:column;height:100%;background:linear-gradient(180deg,#0d1117,#161b22)}.chat-welcome{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px}.welcome-icon{font-size:80px;margin-bottom:24px;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.chat-welcome h2{font-size:28px;font-weight:600;color:#fff;margin:0 0 16px;background:linear-gradient(135deg,#81c784,#4caf50);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.chat-welcome p{color:#fff9;font-size:16px;line-height:1.6;margin:0 0 32px}.start-chat-btn{padding:16px 32px;background:linear-gradient(135deg,#4caf50,#388e3c);border:none;border-radius:14px;color:#fff;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.start-chat-btn:hover{transform:translateY(-3px);box-shadow:0 12px 32px #4caf5066}.chat-messages{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#fff3}.empty-messages{flex:1;display:flex;align-items:center;justify-content:center}.empty-messages p{color:#fff6;text-align:center;font-size:15px;line-height:1.6}@media(max-width:768px){.chat-welcome h2{font-size:24px}.welcome-icon{font-size:60px}.chat-messages{padding:16px}}.app-container{display:flex;height:100vh;background:#0d1117}.main-content{flex:1;display:flex;flex-direction:column;position:relative;min-width:0}.menu-toggle{display:none;position:fixed;top:16px;left:16px;width:44px;height:44px;border:none;background:#ffffff0d;border-radius:10px;color:#fff;cursor:pointer;z-index:99;align-items:center;justify-content:center;transition:all .2s}.menu-toggle:hover{background:#ffffff1a}.menu-toggle svg{width:22px;height:22px}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0d1117;color:#fff9;gap:16px}.loading-spinner{width:40px;height:40px;border:3px solid rgba(76,175,80,.2);border-top-color:#4caf50;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.menu-toggle{display:flex}}
