@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}:root{--primary-gradient: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--sidebar-gradient: linear-gradient(180deg, #2c3e50 0%, #000000 100%);--glass-bg: rgba(255, 255, 255, .1);--glass-border: rgba(255, 255, 255, .18);--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);--accent-color: #ffd700;--bubble-user: rgba(118, 75, 162, .8);--bubble-bot: rgba(255, 255, 255, .15)}*{margin:0;padding:0;box-sizing:border-box;font-family:Inter,sans-serif}body{background:var(--primary-gradient);height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden}#root{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.app-container{width:100%;max-width:700px;height:100vh;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:0 8px 32px #1f26875e;display:flex;flex-direction:column;overflow:hidden;position:relative}.chat-header{padding:20px;border-bottom:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-between}.chat-header h1{font-size:1.5rem;font-weight:600;color:var(--text-primary);letter-spacing:-.5px}.header-left{display:flex;align-items:center;gap:16px}.menu-button{background:none;border:none;color:var(--text-primary);padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background-color .2s}.menu-button:hover{background-color:#ffffff1a}.side-menu-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2000;opacity:0;visibility:hidden;transition:all .3s ease}.side-menu-overlay.open{opacity:1;visibility:visible}.side-menu{position:fixed;top:0;left:0;width:280px;height:100%;background:#1a1a1a;border-right:1px solid var(--glass-border);z-index:2001;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;color:#fff}.side-menu.open{transform:translate(0)}.side-menu-header{padding:24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1)}.side-menu-header h2{font-size:1.25rem;font-weight:600}.side-menu-header .close-button{background:none;border:none;color:#fff6;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.side-menu-header .close-button:hover{background:#ffffff1a;color:#fff}.side-menu-content{flex:1;overflow-y:auto;padding:20px 0;display:flex;flex-direction:column}.user-profile-section{padding:0 24px 24px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(255,255,255,.1);margin-bottom:20px}.user-avatar{width:48px;height:48px;background:var(--primary-gradient);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;border:2px solid var(--glass-border)}.user-info{display:flex;flex-direction:column}.user-email{font-size:.9rem;font-weight:500;word-break:break-all}.user-points{font-size:.75rem;color:var(--accent-color);font-weight:600}.side-menu-nav{display:flex;flex-direction:column;flex:1}.side-menu-nav ul{list-style:none;display:flex;flex-direction:column;flex:1}.side-menu-nav button{width:100%;padding:14px 24px;display:flex;align-items:center;gap:12px;background:none;border:none;color:var(--text-secondary);font-size:.95rem;cursor:pointer;transition:all .2s;text-align:left}.side-menu-nav button:hover{background:#ffffff0d;color:#fff}.side-menu-nav button .icon{font-size:1.1rem}.logout-item{margin-top:auto;border-top:1px solid rgba(255,255,255,.05)}.side-menu-logout-button{width:100%;padding:14px 24px;display:flex!important;align-items:center;gap:12px;background:none;border:none;color:#ff4757!important;font-size:.95rem;cursor:pointer;transition:all .2s;text-align:left}.side-menu-logout-button:hover{background:#ff47571a!important;color:#ff6b81!important}.side-menu-footer{padding:20px 24px;font-size:.75rem;color:var(--text-secondary);border-top:1px solid rgba(255,255,255,.1);text-align:center}.status-indicator{display:flex;align-items:center;font-size:.8rem;color:var(--text-secondary)}.status-dot{width:8px;height:8px;background-color:#4ade80;border-radius:50%;margin-right:8px;box-shadow:0 0 10px #4ade80}.user-point-badge{background:#ffd7001a;border:1px solid rgba(255,215,0,.3);color:var(--accent-color);padding:4px 8px;border-radius:20px;font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:6px;width:fit-content;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:slideInLeft .5s ease-out}.point-icon{font-size:.9rem}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.messages-container{flex:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:16px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-thumb{background-color:#fff3;border-radius:10px}.message-wrapper{display:flex;flex-direction:column;max-width:85%;gap:4px}.message-row{display:flex;align-items:flex-end;gap:4px;width:100%}.message-wrapper.user{align-self:flex-end;align-items:flex-end}.message-wrapper.bot{align-self:flex-start;align-items:flex-start}.message{padding:12px 18px;border-radius:18px;font-size:.95rem;line-height:1.5;position:relative;white-space:pre-wrap;animation:fadeIn .3s ease-out forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{background:var(--bubble-user);color:#fff;border-bottom-right-radius:4px}.message.bot{background:var(--bubble-bot);color:var(--text-primary);border-bottom-left-radius:4px;border:1px solid var(--glass-border)}.message.bot.translate{background:#2ed57380;border-color:#2ed57366;box-shadow:0 4px 15px #2ed5731a}.message.bot.correct{background:#ff475780;border-color:#ff475766;box-shadow:0 4px 15px #ff47571a}.message-wrapper.system{align-self:center;max-width:95%;margin:12px 0}.message.system{background:#ffffff14;color:var(--text-secondary);border-radius:12px;font-size:.85rem;padding:10px 20px;text-align:center;border:1px dashed var(--glass-border);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .4s ease-out}.message-time{font-size:.65rem;color:var(--text-secondary);opacity:.8}.translation-section{margin-top:8px;border-top:1px solid rgba(255,255,255,.1);padding-top:8px}.translation-toggle{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:var(--text-secondary);font-size:.75rem;font-weight:500;width:auto;height:28px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;border-radius:14px;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);margin-left:8px;vertical-align:middle;box-shadow:0 2px 8px #0000001a}.speaker-button{background:#ffd7001a;border-color:#ffd7004d}.speaker-button:hover{background:#ffd70033;border-color:#ffd70080}.translation-toggle:hover{background:#fff3;transform:scale(1.1);border-color:#fff6}.translation-toggle:active{transform:scale(.95)}.bookmark-button{background:none;border:none;color:var(--text-secondary);width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);padding:0;opacity:.4;flex-shrink:0;margin-bottom:4px}.bookmark-button svg{width:100%;height:100%}.bookmark-button:hover{transform:scale(1.1);color:var(--accent-color);opacity:1}.bookmark-button.saved{color:var(--accent-color);opacity:1;cursor:default}.bookmark-button:active{transform:scale(.95)}.korean-text{font-size:.9rem;color:var(--text-primary);background:#ffffff0d;padding:8px;border-radius:8px;border-left:3px solid var(--accent-color);animation:fadeIn .3s ease-out}.input-area{padding:20px;border-top:1px solid var(--glass-border);display:flex;gap:12px;align-items:flex-end}.input-wrapper{flex:1;position:relative}input,textarea{width:100%;padding:14px 20px;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:14px;color:#fff;font-size:.95rem;outline:none;transition:all .2s;font-family:inherit}textarea{resize:none;min-height:52px;max-height:200px;overflow-y:auto;line-height:1.5;display:block}textarea::-webkit-scrollbar{width:4px}textarea::-webkit-scrollbar-track{background:transparent}textarea::-webkit-scrollbar-thumb{background-color:#fff3;border-radius:4px}input:focus,textarea:focus{background:#ffffff1a;border-color:#fff6}input::placeholder,textarea::placeholder{color:#ffffff4d}.send-button{background:#fff;color:#764ba2;border:none;padding:12px 24px;border-radius:14px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.send-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.send-button:active{transform:translateY(0)}.send-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.typing-indicator{font-size:.8rem;color:var(--text-secondary);margin-bottom:8px;padding-left:20px;height:20px}.auth-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:20px}.auth-card{width:100%;max-width:400px;background:#ffffff0d;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:24px;padding:40px;display:flex;flex-direction:column;gap:24px;box-shadow:0 12px 40px #0003}.auth-card h2{color:#fff;font-size:2rem;font-weight:700;text-align:center;margin-bottom:8px}.auth-card p{color:var(--text-secondary);text-align:center;font-size:.9rem}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:var(--text-secondary);font-size:.85rem;margin-left:4px}.auth-footer{text-align:center;margin-top:16px;font-size:.9rem;color:var(--text-secondary)}.auth-footer button{background:none;border:none;color:#fff;font-weight:600;cursor:pointer;margin-left:8px;text-decoration:underline}.logout-button{background:#ffffff1a;color:#fff;border:1px solid var(--glass-border);padding:6px 12px;border-radius:10px;font-size:.8rem;cursor:pointer;transition:all .2s}.logout-button:hover{background:#f003;border-color:#ff00004d}.error-message{background:#ff475726;color:#ff4757;padding:12px;border-radius:10px;font-size:.85rem;text-align:center;border:1px solid rgba(255,71,87,.3)}.word-popup-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.word-popup-card{background:#282c34f2;width:90%;max-width:500px;border-radius:20px;border:1px solid var(--glass-border);box-shadow:0 20px 50px #00000080;padding:24px;color:#fff;animation:scaleUp .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes scaleUp{0%{transform:scale(.8);opacity:0}to{transform:scale(1);opacity:1}}.word-popup-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:12px}.word-popup-header h3{font-size:1.2rem;font-weight:600}.close-popup{background:none;border:none;color:#fff6;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.close-popup:hover{background:#ffffff1a;color:#fff}.word-popup-sentence{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.word-button{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#fff;padding:8px 12px;border-radius:8px;cursor:pointer;font-size:1rem;transition:all .2s}.word-button:hover{background:#ffffff26;transform:translateY(-2px)}.word-button.active{background:var(--accent-color);color:#000;font-weight:600;transform:scale(1.05);box-shadow:0 0 15px #ffd70066}.word-definition-section{background:#ffffff08;border-radius:12px;padding:16px;border-left:4px solid var(--accent-color);animation:fadeIn .3s ease-out}.word-definition-section h4{font-size:1.1rem;margin-bottom:8px;color:var(--accent-color);text-transform:capitalize}.definition-content{font-size:.95rem;line-height:1.6;white-space:pre-wrap}.definition-placeholder{color:var(--text-secondary);font-style:italic}.save-word-button{margin-top:16px;width:100%;background:var(--accent-color);color:#000;border:none;padding:12px;border-radius:10px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.save-word-button:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 4px 12px #ffd7004d}.save-word-button:active{transform:translateY(0)}.saved-list-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:3000;animation:fadeIn .3s ease-out}.saved-list-modal{background:#1a1a1a;width:90%;max-width:600px;height:80vh;border-radius:20px;border:1px solid var(--glass-border);box-shadow:0 25px 50px #0009;display:flex;flex-direction:column;overflow:hidden;animation:scaleUp .3s cubic-bezier(.175,.885,.32,1.275)}.saved-list-header{padding:10px 14px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid rgba(255,255,255,.1)}.saved-list-header .close-button{background:none;border:none;color:#ffffff40;cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.saved-list-header .close-button:hover{background:#ffffff1a;color:#fff}.saved-list-content{flex:1;overflow-y:auto}.saved-items-list{list-style:none;display:flex;flex-direction:column}.saved-item{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);padding:16px;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;transition:all .2s}.saved-item:hover{background:#ffffff14;border-color:#fff3}.item-main{flex:1}.item-text{font-size:.95rem;color:#fff;margin-bottom:4px}.item-subtext{font-size:.9rem;color:var(--text-secondary);line-height:1.4;margin-bottom:8px}.item-date{font-size:.7rem;color:#ffffff4d}.delete-button{background:#ff475799;border:none;color:#fff;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;box-shadow:0 4px 10px #0000004d}.delete-button:active{background:#ff4757;transform:scale(.9)}.empty-state,.loading-state{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-secondary);font-style:italic}@media(max-width:768px){.app-container{position:fixed;top:0;left:0;width:100%;height:100dvh;max-width:none;border:none;border-radius:0;margin:0}.chat-header{padding-top:max(20px,env(safe-area-inset-top));position:sticky;top:0;z-index:50;background:#0000004d;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}}.mode-toggle-container{display:flex;background:#0003;border-radius:12px;padding:4px;gap:4px;margin-left:6px}.mode-toggle-button{background:transparent;border:none;color:var(--text-secondary);font-size:.75rem;font-weight:600;padding:6px 12px;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.mode-toggle-button:hover{background:#ffffff0d;color:#fff}.mode-toggle-button.active{background:#ffffff26;color:#fff;box-shadow:0 2px 8px #0000001a}.text-visibility-toggle{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;color:var(--text-secondary);font-size:.75rem;font-weight:500;cursor:pointer;padding:4px 10px;margin-right:8px;transition:all .2s;vertical-align:middle}.text-visibility-toggle:hover{background:#fff3;color:#fff;transform:translateY(-1px)}.audio-mode-placeholder{display:flex;align-items:center;gap:8px;color:var(--text-primary);opacity:.9;font-weight:500;padding:4px 0}.audio-icon{font-size:1.2rem;animation:pulse 2s infinite}.tts-provider-select{margin-left:6px;font-size:.75rem;font-weight:600}@keyframes pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}to{transform:scale(1);opacity:1}}@media(max-width:480px){.mode-toggle-container{padding:2px}.mode-toggle-button{padding:4px 8px}}.new-chat-button-container{display:flex;justify-content:center;align-items:center}.new-chat-button{background:#ffffff1a;color:var(--text-secondary);border:1px solid var(--glass-border);padding:8px 16px;border-radius:20px;display:flex;align-items:center;font-size:.85rem;cursor:pointer;transition:all .2s}.new-chat-button:hover{background:#fff3;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.new-chat-button .icon{font-size:1rem}
