:root{--primary-color: #4338ca;--primary-light: #818cf8;--primary-dark: #312e81;--secondary-color: #059669;--secondary-light: #34d399;--secondary-dark: #047857;--neutral-50: #fafafa;--neutral-100: #f4f4f5;--neutral-200: #e4e4e7;--neutral-300: #d4d4d8;--neutral-400: #a1a1aa;--neutral-500: #71717a;--neutral-600: #52525b;--neutral-700: #3f3f46;--neutral-800: #27272a;--neutral-900: #18181b;--danger: #dc2626;--warning: #d97706;--success: #16a34a;--info: #2563eb;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--radius-sm: .125rem;--radius-md: .375rem;--radius-lg: .5rem;--radius-xl: .75rem;--radius-2xl: 1rem;--radius-full: 9999px;font-family:var(--font-family);line-height:1.5;font-weight:400;color-scheme:light dark;color:var(--neutral-800);background-color:var(--neutral-50);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{line-height:1.6;margin:0;display:flex;min-width:320px;min-height:100vh;background-color:var(--neutral-50);color:var(--neutral-800)}#root{width:100%}a{font-weight:500;color:var(--primary-color);text-decoration:none;transition:color .2s ease}a:hover{color:var(--primary-light)}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:600}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}button{border-radius:var(--radius-md);border:1px solid transparent;padding:.6em 1.2em;font-size:var(--font-size-md);font-weight:500;font-family:inherit;background-color:var(--primary-color);color:#fff;cursor:pointer;transition:background-color .25s,transform .2s}button:hover{background-color:var(--primary-light)}button:focus,button:focus-visible{outline:2px solid var(--primary-light);outline-offset:2px}button:active{transform:translateY(1px)}input,select,textarea{font-family:inherit;font-size:inherit;padding:.5em .8em;border-radius:var(--radius-md);border:1px solid var(--neutral-300);background-color:#fff;color:var(--neutral-800);transition:border-color .2s,box-shadow .2s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e526}@media (prefers-color-scheme: dark){:root{color:var(--neutral-100);background-color:var(--neutral-900)}input,select,textarea{background-color:var(--neutral-800);border-color:var(--neutral-700);color:var(--neutral-100)}a:hover{color:var(--primary-light)}}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}body{font-family:Inter,sans-serif;margin:0;padding:0;background:#f4f4f4}.app-container{width:100%;min-height:100vh;display:flex;justify-content:center;align-items:flex-start;padding:20px 0}.text-sm{font-size:.875rem;line-height:1.25rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.bg-gray-100{background-color:#f7fafc}.p-2{padding:.5rem}.m-4{margin:1rem}.rounded-lg{border-radius:.5rem}.card{background:#fff;border-radius:8px;box-shadow:0 4px 8px #0000001a;width:100%;padding:1rem;overflow:hidden;text-align:center;transition:transform .3s ease;cursor:pointer}.card:hover{transform:translateY(-5px)}.card img{width:100%;max-width:50px;height:auto;margin-bottom:.5rem}.image-placeholder{width:60px;height:60px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-2xl);font-weight:600;color:var(--neutral-500);background-color:var(--neutral-200);border-radius:var(--radius-full);transition:all .3s ease}.scenario-card:hover .image-placeholder{background-color:var(--primary-color);color:#fff}.text-xs{font-size:.75rem;line-height:1rem}.scenario-card{position:relative;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;padding:var(--space-4) var(--space-3);cursor:pointer;border:1px solid var(--neutral-200);text-align:center;height:100%;min-height:200px}.scenario-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg);border-color:var(--primary-light)}.scenario-card:active{transform:translateY(0)}.scenario-img-container{width:70px;height:70px;margin-bottom:var(--space-3);display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);background-color:var(--neutral-100);padding:var(--space-2);transition:all .3s ease;overflow:hidden}.scenario-card:hover .scenario-img-container{background-color:var(--primary-color);transform:scale(1.05)}.scenario-card img{width:100%;height:auto;object-fit:contain;transition:all .3s ease;filter:drop-shadow(0 4px 3px rgba(0,0,0,.07))}.scenario-card:hover img{filter:brightness(0) invert(1)}.scenario-title{font-weight:600;font-size:var(--font-size-md);color:var(--neutral-800);margin-bottom:var(--space-2);transition:color .3s ease}.scenario-card:hover .scenario-title{color:var(--primary-color)}.scenario-status{position:absolute;top:12px;right:12px;font-size:var(--font-size-xs);font-weight:500;padding:4px 8px;border-radius:var(--radius-full);background-color:var(--neutral-100);color:var(--neutral-600)}.status-free{background-color:var(--success);color:#fff}@keyframes cardAppear{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.scenario-card{animation:cardAppear .5s ease-out forwards}.scenario-icon{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.scenario-icon svg{width:32px;height:32px;transition:all .3s ease}.scenario-card:hover .scenario-icon svg{stroke:#fff;transform:scale(1.1)}.scenario-description{font-size:var(--font-size-sm);color:var(--neutral-700);margin:var(--space-1) 0 var(--space-3);line-height:1.5;min-height:50px;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.scenario-start-btn{background-color:var(--primary-dark);color:#fff;padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;margin-top:auto;transition:all .2s ease;box-shadow:var(--shadow-sm);width:80%}.scenario-card:hover .scenario-start-btn{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.max-w-md{max-width:28rem;margin:0 auto}.text-center{text-align:center}.my-3{margin-top:.75rem;margin-bottom:.75rem}.text-2xl{font-size:1.5rem;line-height:2rem}.font-bold{font-weight:700}.text-gray-800{color:#2d3748}.flex{display:flex}.justify-between{justify-content:space-between}.bg-white{background-color:#fff}.p-4{padding:1rem}.rounded-t-lg{border-top-left-radius:.5rem;border-top-right-radius:.5rem}.shadow{box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.font-semibold{font-weight:600}.language-select{padding:.375rem .75rem;color:#4a5568;background-color:#fff;border:1px solid #e2e8f0;border-radius:.25rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;font-size:.875rem;line-height:1.25rem}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.gap-2{gap:.5rem}.card-container{padding:1rem}.home-container{max-width:1200px;margin:0 auto;padding:var(--space-4) var(--space-2);background-color:var(--neutral-50)}.header{text-align:center;margin-bottom:var(--space-6);padding:0 var(--space-2)}.app-title{font-size:var(--font-size-3xl);font-weight:700;color:var(--primary-dark);margin-bottom:var(--space-2);position:relative;display:inline-block}.app-title:after{content:"";position:absolute;bottom:-8px;left:50%;width:60px;height:4px;background-color:var(--secondary-dark);transform:translate(-50%);border-radius:var(--radius-full)}.app-subtitle{font-size:var(--font-size-lg);color:var(--neutral-700);margin-top:var(--space-3);max-width:600px;margin-left:auto;margin-right:auto}.control-panel{display:flex;justify-content:space-between;align-items:center;background-color:#fff;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg) var(--radius-lg) 0 0;box-shadow:var(--shadow-md);border:1px solid var(--neutral-200);border-bottom:none;margin:0 var(--space-2)}.panel-title{font-weight:600;font-size:var(--font-size-lg);color:var(--neutral-800);display:flex;align-items:center;gap:var(--space-2)}.panel-title .icon{color:var(--primary-color)}.language-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-color:#fff;border:1px solid var(--neutral-300);padding:.5rem 2.5rem .5rem 1rem;border-radius:var(--radius-md);font-weight:500;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%233f3f46'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:1rem;cursor:pointer;transition:border-color .15s ease-in-out,box-shadow .15s ease-in-out}.language-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e526;outline:none}.scenarios-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:var(--space-3);padding:var(--space-4);background-color:#fff;border-radius:0 0 var(--radius-lg) var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--neutral-200);margin:0 var(--space-2)}.home-footer{margin-top:var(--space-4);padding:var(--space-3);text-align:center;color:var(--neutral-500);font-size:var(--font-size-sm)}@media (max-width: 768px){.scenarios-container{grid-template-columns:repeat(2,1fr);padding:var(--space-3);gap:var(--space-2)}.app-title{font-size:var(--font-size-2xl)}.app-subtitle{font-size:var(--font-size-md)}}@media (max-width: 480px){.scenarios-container{grid-template-columns:1fr}.control-panel{flex-direction:column;gap:var(--space-3);align-items:flex-start}.language-select{width:100%}}@media (min-width: 1024px){.scenarios-container{grid-template-columns:repeat(3,1fr)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.app-title{animation:fadeIn .8s ease-out forwards}.app-subtitle{animation:fadeIn .8s ease-out .2s forwards;opacity:0}.control-panel{animation:fadeIn .8s ease-out .4s forwards;opacity:0}.scenarios-container{animation:fadeIn .8s ease-out .6s forwards;opacity:0}.objectives-panel{position:absolute;right:0;top:0;height:100%;width:100%;max-width:320px;background:var(--neutral-50);box-shadow:-5px 0 15px #0000001a;z-index:100;display:flex;flex-direction:column;animation:slideIn .3s ease forwards;transform-origin:right center}.objectives-panel.closing{animation:slideOut .3s ease forwards}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{0%{transform:translate(0);opacity:1}to{transform:translate(100%);opacity:0}}.objectives-header{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff;padding:var(--space-4);display:flex;justify-content:space-between;align-items:center}.objectives-title{font-weight:600;font-size:var(--font-size-lg);display:flex;align-items:center;gap:var(--space-2)}.objectives-title:before{content:"🎯";font-size:var(--font-size-xl)}.close-btn{background:#fff3;border:none;color:#fff;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-md);cursor:pointer;transition:all .2s ease}.close-btn:hover{background:#ffffff4d;transform:rotate(90deg)}.objectives-content{padding:var(--space-4);flex:1;overflow-y:auto}.section-title{font-weight:600;font-size:var(--font-size-md);color:var(--neutral-800);margin-bottom:var(--space-2);display:flex;align-items:center;gap:var(--space-2)}.section-title.scenario:before{content:"📝"}.section-title.objectives:before{content:"✅"}.scenario-description{font-size:var(--font-size-sm);color:var(--neutral-700);margin-bottom:var(--space-4);line-height:1.5;padding:var(--space-3);background-color:#fff;border-radius:var(--radius-md);border-left:3px solid var(--primary-light);box-shadow:var(--shadow-sm)}.objectives-list{list-style:none;padding:0;margin:0}.objective-item{display:flex;align-items:center;padding:var(--space-2) 0;border-bottom:1px solid var(--neutral-200);transition:all .2s ease}.objective-item:last-child{border-bottom:none}.objective-checkbox{position:relative;width:20px;height:20px;margin-right:var(--space-3);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:2px solid var(--neutral-400);border-radius:var(--radius-sm);transition:all .2s ease;flex-shrink:0}.objective-checkbox:checked{background-color:var(--success);border-color:var(--success)}.objective-checkbox:checked:after{content:"✓";position:absolute;color:#fff;font-size:12px;font-weight:700;top:50%;left:50%;transform:translate(-50%,-50%)}.objective-label{font-size:var(--font-size-sm);color:var(--neutral-700);cursor:pointer;transition:all .2s ease;flex:1;text-align:left}.objective-item.completed .objective-label{text-decoration:line-through;color:var(--neutral-500)}.progress-bar-container{margin-top:var(--space-4);background-color:var(--neutral-200);height:8px;border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--success));transition:width .3s ease}@media (max-width: 768px){.objectives-panel{max-width:100%}}.user-message{display:flex;justify-content:flex-end;margin:var(--space-3) 0;animation:messageSlideIn .3s ease forwards;max-width:90%;margin-left:auto}.user-message-content{background-color:var(--primary-dark);color:#fff;padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg) var(--radius-lg) 0 var(--radius-lg);max-width:90%;box-shadow:var(--shadow-md);position:relative;overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.user-message-content.is-practice{background-color:var(--warning)}.ai-message{display:flex;justify-content:flex-start;margin:var(--space-3) 0;animation:messageSlideIn .3s ease forwards;max-width:90%}.ai-message-content{background-color:#fff;color:var(--neutral-800);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg) var(--radius-lg) var(--radius-lg) 0;max-width:90%;box-shadow:var(--shadow-md);position:relative;overflow-wrap:break-word;word-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.ai-message-content.has-correction{border-left:3px solid var(--warning)}.english-message{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-2);line-height:1.5}.correction-section{margin-top:var(--space-3);border-top:1px dashed var(--neutral-300);padding-top:var(--space-2)}.correction-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;color:var(--warning);font-weight:500;font-size:var(--font-size-sm);padding:var(--space-1) 0;transition:all .2s ease}.correction-header:hover{color:var(--primary-color)}.correction-text{margin-top:var(--space-2);padding:var(--space-3);background-color:var(--neutral-50);border-radius:var(--radius-md);display:flex;justify-content:space-between;align-items:center;gap:var(--space-2);transition:all .3s ease;animation:fadeIn .3s ease;border:1px solid var(--warning)}.correct-phrase{font-weight:500;color:var(--neutral-800);position:relative;padding:2px 0}.correct-phrase:after{content:"";position:absolute;bottom:-2px;left:0;width:100%;height:2px;background-color:var(--warning);transform:scaleX(0);transition:transform .3s ease;transform-origin:left}.correction-text:hover .correct-phrase:after{transform:scaleX(1)}.practice-btn{background-color:var(--warning);color:#fff;border:none;border-radius:var(--radius-md);padding:var(--space-1) var(--space-2);font-size:var(--font-size-xs);font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap;display:flex;align-items:center;gap:4px}.practice-btn:before{content:"⟳";font-size:12px}.practice-btn:hover{background-color:var(--primary-color);transform:translateY(-1px)}.translation-message{margin-top:var(--space-2);padding:var(--space-2) var(--space-3);background-color:var(--neutral-50);border-radius:var(--radius-md);color:var(--neutral-700);font-style:italic;font-size:var(--font-size-sm);border-left:3px solid var(--primary-light);animation:fadeIn .3s ease;text-align:left!important;direction:ltr;width:100%;display:block}.hint-button{background:none;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;margin-left:var(--space-2);transition:all .2s ease;flex-shrink:0;color:inherit;font-size:18px;background:transparent;border:none;box-shadow:none;padding:0}.hint-button:hover{transform:scale(1.2)}.hint-button:active{transform:scale(.95)}.toggle-btn{background:none;border:none;cursor:pointer;color:var(--warning);transition:transform .2s ease;padding:0}.toggle-btn:hover{transform:translateY(-1px)}.typing-indicator{display:inline-flex;padding:var(--space-2) var(--space-4);background-color:#fff;border-radius:var(--radius-full);box-shadow:var(--shadow-md);animation:fadeIn .3s ease}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.message-time{font-size:var(--font-size-xs);color:#00000073;margin-top:var(--space-1);text-align:right;font-weight:500}.user-message-content .message-time{color:#fffc}.message-avatar{width:36px;height:36px;border-radius:50%;background-color:var(--neutral-300);display:flex;align-items:center;justify-content:center;margin-right:var(--space-2);font-weight:700;color:var(--neutral-800);font-size:var(--font-size-sm)}.ai-avatar{background-color:var(--primary-dark);color:#fff}.chat-container{display:flex;position:fixed;z-index:5;left:0;top:0;right:0;bottom:0;flex-direction:column;max-width:900px;margin:auto;border-radius:var(--radius-lg);overflow:hidden;background-color:var(--neutral-50);box-shadow:var(--shadow-xl);animation:fadeIn .5s ease}.chat-header{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));padding:var(--space-4);display:flex;justify-content:space-between;align-items:center;color:#fff}.header-content{display:flex;align-items:center}.chat-title{font-size:var(--font-size-xl);font-weight:700;text-transform:capitalize;display:flex;align-items:center;gap:var(--space-2)}.language-indicator{font-size:var(--font-size-xs);background-color:#fff3;padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);margin-left:var(--space-2);text-transform:capitalize;font-weight:600;border:1px solid rgba(255,255,255,.3);box-shadow:0 1px 3px #0000001a;position:relative}.language-indicator:before{content:"";display:inline-block;width:6px;height:6px;background-color:#22c55e;border-radius:50%;margin-right:4px;vertical-align:middle}.back-button{background-color:#ffffff26;color:#fff;border:none;border-radius:var(--radius-md);width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-md);cursor:pointer;transition:all .2s ease;margin-right:var(--space-3);padding:0}.back-button:hover{background-color:#ffffff40;transform:translate(-3px)}.back-button:before{content:"◀";font-weight:900;font-size:1.2em}.chat-title:before{content:"";display:inline-block;width:10px;height:10px;background-color:var(--secondary-light);border-radius:50%;animation:pulse 2s infinite}.chat-controls{display:flex;align-items:center;gap:var(--space-3)}.llm-model{padding:var(--space-2) var(--space-3);border:none;border-radius:var(--radius-md);background-color:#ffffff40;color:#fff;font-size:var(--font-size-sm);font-weight:600;cursor:pointer;transition:background-color .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:120px;box-shadow:0 1px 3px #0000001a}.llm-model:hover{background-color:#ffffff59;transform:translateY(-1px)}.llm-model:focus{outline:none;box-shadow:0 0 0 2px #fff9}.llm-model option{background-color:var(--primary-dark);color:#fff;font-weight:500}.objectives-btn{background-color:#ffffff26;color:#fff;border:none;border-radius:var(--radius-md);width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl);cursor:pointer;transition:all .2s ease}.objectives-btn:hover{background-color:#ffffff40;transform:scale(1.05)}.chat-messages{position:relative;flex:1;padding:var(--space-4);overflow-y:auto;background-color:var(--neutral-100);scroll-behavior:smooth;scrollbar-width:thin;scrollbar-color:var(--primary-light) var(--neutral-200);background-size:cover;background-position:center;background-repeat:no-repeat;background-blend-mode:overlay}.chat-messages.over-a-phone-call{background-image:url(/assets/over_a_phone_call_bg-sHW9J1nj.png)}.chat-messages.restaurant{background-image:url(/assets/restaurant_bg-D7VkrhL7.png)}.chat-messages.nike-store{background-image:url(/assets/nike_store_bg-DRUlx7BZ.png)}.chat-messages.coffee-shop{background-image:url(/assets/coffee_shop_bg-DC8xNBT4.png)}.chat-messages.birthday-celebration{background-image:url(/assets/birthday_party_bg-BWcJFgIl.png)}.chat-messages.first-day-class{background-image:url(/assets/first_day_class_bg-DN1bvxeC.png)}.chat-messages:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-color:#ffffffd9;z-index:-1}.chat-messages::-webkit-scrollbar{width:10px}.chat-messages::-webkit-scrollbar-track{background:var(--neutral-200);border-radius:10px}.chat-messages::-webkit-scrollbar-thumb{background-color:var(--primary-light);border-radius:10px;border:2px solid var(--neutral-200)}.chat-messages::-webkit-scrollbar-thumb:hover{background-color:var(--primary-color)}.chat-messages::-webkit-scrollbar-button{display:none}#chatCanvas{position:absolute;top:0;left:0;width:100%;height:100%;background-color:var(--neutral-100);z-index:-1}.chat-input-container{display:flex;padding:var(--space-4);background-color:var(--neutral-50);border-top:1px solid var(--neutral-200);position:relative}.chat-input-container:before{content:"";position:absolute;top:-10px;left:0;right:0;height:10px;background:linear-gradient(to bottom,rgba(0,0,0,.03),transparent);pointer-events:none}.chat-input-container input{flex:1;padding:var(--space-3) var(--space-4);border:1px solid var(--neutral-300);border-radius:var(--radius-md);transition:all .3s ease;font-size:var(--font-size-md);background-color:#fff;color:var(--neutral-800)}.chat-input-container input:focus{border-color:var(--primary-color);box-shadow:0 0 0 4px #4f46e51a;outline:none}.chat-input-container input.practice-mode{border-color:var(--warning);background-color:#f59e0b0d}.chat-input-container input:disabled{background-color:var(--neutral-100);cursor:not-allowed}.chat-input-container button{margin-left:var(--space-3);padding:var(--space-3) var(--space-4);background-color:var(--primary-dark);color:#fff;border:none;border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.chat-input-container button:after{content:"▶";font-size:1.4em;font-weight:900;transition:transform .2s ease;margin-left:2px}.chat-input-container button:hover:not(:disabled):after{transform:translate(3px)}.chat-input-container button:hover:not(:disabled){background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 6px #32325d1c,0 1px 3px #00000014}.chat-input-container button:active:not(:disabled){transform:translateY(1px);box-shadow:none}.chat-input-container button:disabled{background-color:var(--neutral-400);cursor:not-allowed;opacity:.7}.chat-input-container button.sending{background-color:var(--success)}.chat-input-container button.sending:after{content:"";animation:sendingDots 1.4s infinite}.chat-input-container button.practice-mode{background-color:var(--warning)}.typing-indicator{display:inline-flex;align-items:center;background-color:#fff;padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);margin:var(--space-2) 0;box-shadow:var(--shadow-md)}.typing-dots{display:flex;align-items:center}.typing-dots span{height:8px;width:8px;margin:0 2px;background-color:var(--primary-color);border-radius:50%;display:inline-block;animation:typing-dot 1.4s infinite ease-in-out both}.typing-dots span:nth-child(1){animation-delay:-.32s}.typing-dots span:nth-child(2){animation-delay:-.16s}@keyframes typing-dot{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}@keyframes sendingDots{0%,20%{content:"."}40%,60%{content:".."}80%,to{content:"..."}}@keyframes pulse{0%{transform:scale(.8);opacity:.5}50%{transform:scale(1.2);opacity:1}to{transform:scale(.8);opacity:.5}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.error-banner{position:absolute;top:0;left:0;right:0;background-color:var(--danger);color:#fff;padding:var(--space-3);display:flex;justify-content:space-between;align-items:center;z-index:1000;animation:slideDown .3s ease-out;box-shadow:var(--shadow-md)}.error-banner.info{background-color:var(--info)}.close-error{background:none;border:none;color:#fff;font-size:var(--font-size-lg);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:.8;transition:opacity .2s}.close-error:hover{opacity:1;background:none}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@media (max-width: 1000px){.chat-container{max-width:100%;left:0;top:0;right:0;bottom:0;border-radius:0}.chat-header{padding:var(--space-3)}.chat-title{font-size:var(--font-size-lg)}.chat-input-container,.chat-messages{padding:var(--space-3)}}
