@import "https://fonts.googleapis.com/css2?family=Noto+Sans+Sinhala:wght@400;500;600;700&family=Inter:wght@400;500;600;700;800&display=swap";:root{--bg:#0d1117;--surface:#161b22;--surface-elevated:#1c2128;--border:#30363d;--border-active:#484f58;--accent:#7c3aed;--accent-hover:#6d28d9;--accent-secondary:#06b6d4;--text-primary:#e6edf3;--text-secondary:#8b949e;--text-muted:#484f58;--sidebar-width:360px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;overflow:hidden}body{background:var(--bg);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,Noto Sans Sinhala,system-ui,sans-serif;line-height:1.6}:lang(si),.si{font-family:Noto Sans Sinhala,system-ui,sans-serif}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:99px}::-webkit-scrollbar-thumb:hover{background:var(--border-active)}.app-layout{flex-direction:column;height:100%;display:flex}.app-body{flex:1;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);border-right:1px solid var(--border);background:var(--surface);flex-shrink:0;overflow-y:auto}.main-area{flex-direction:column;flex:1;display:flex;overflow:hidden}@media (width<=768px){.app-body{flex-direction:column}.sidebar{border-right:none;border-bottom:1px solid var(--border);width:100%;max-height:40vh}}.app-header{background:var(--surface);border-bottom:1px solid var(--border);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;padding:.9rem 1.5rem;display:flex}.header-brand{cursor:pointer;border-radius:10px;align-items:center;gap:.75rem;margin:-.25rem -.5rem;padding:.25rem .5rem;transition:background .15s;display:flex}.header-brand:hover{background:var(--surface-elevated)}.brand-logo{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;overflow:hidden}.brand-logo--img{background:0 0}.brand-logo-img{object-fit:contain;border-radius:10px;width:100%;height:100%}.brand-logo--text{background:linear-gradient(135deg, var(--accent), var(--accent-secondary));flex-direction:column;gap:0;line-height:1}.brand-logo-text{color:#fff;letter-spacing:.02em;font-size:.6rem;font-weight:800}.brand-logo-si{color:#ffffffe6;font-family:Noto Sans Sinhala,sans-serif;font-size:.65rem;font-weight:700}.brand-name{color:var(--text-primary);letter-spacing:-.02em;font-size:1.1rem;font-weight:800}.brand-tagline{color:var(--text-muted);font-size:.7rem;font-weight:400}.header-actions{gap:.5rem;display:flex}.reset-btn{background:var(--surface-elevated);border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:8px;padding:.4rem .9rem;font-family:inherit;font-size:.8rem;transition:all .15s}.reset-btn:hover{border-color:var(--accent);color:var(--accent)}.selection-panel{padding:2rem}.selection-title{color:var(--text-primary);margin:0 0 .4rem;font-size:1.5rem;font-weight:700}.selection-subtitle{color:var(--text-muted);margin:0 0 2rem;font-size:.9rem}.steps-grid{flex-direction:column;gap:1rem;display:flex}.step-card{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:1.25rem;transition:border-color .2s,box-shadow .2s}.step-card.locked{opacity:.55;pointer-events:none}.step-card.active{border-color:var(--border-active)}.step-card.done{border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb, var(--accent) 20%, transparent)}.step-header{align-items:center;gap:.9rem;margin-bottom:.9rem;display:flex}.step-badge{background:var(--surface-elevated);border:2px solid var(--border);width:32px;height:32px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;transition:all .2s;display:flex}.step-badge.active{border-color:var(--accent);color:var(--accent)}.step-badge.done{background:var(--accent);border-color:var(--accent);color:#fff}.step-label{color:var(--text-primary);font-size:.95rem;font-weight:600}.step-label-en{color:var(--text-muted);font-size:.75rem}.optional-tag{color:var(--accent-secondary);font-weight:500}.option-list{flex-wrap:wrap;gap:.5rem;display:flex}.option-btn{background:var(--surface-elevated);border:1.5px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:10px;align-items:center;gap:.4rem;padding:.5rem 1rem;font-family:inherit;font-size:.875rem;transition:all .15s;display:flex}.option-btn:hover{border-color:var(--accent);color:var(--text-primary);background:color-mix(in srgb, var(--accent) 8%, var(--surface-elevated))}.option-btn.selected{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.option-btn.full-width{justify-content:flex-start;width:100%}.item-icon{font-size:1rem}.step-hint{color:var(--text-muted);margin:0;font-size:.8rem;font-style:italic}.step-content{flex-direction:column;gap:.4rem;display:flex}.chat-panel{background:var(--bg);flex-direction:column;height:100%;display:flex}.chat-panel--locked{justify-content:center;align-items:center;padding:2rem}.locked-msg{text-align:center;max-width:320px}.locked-icon{margin-bottom:1rem;font-size:4rem;animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.locked-msg h3{color:var(--text-primary);margin:0 0 .5rem;font-size:1.25rem;font-weight:700}.locked-msg p{color:var(--text-muted);margin:0;font-size:.9rem;line-height:1.6}.context-badge{background:var(--surface);border-bottom:1px solid var(--border);color:var(--text-secondary);align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.8rem;font-weight:500;display:flex}.context-dot{background:var(--accent);width:8px;height:8px;box-shadow:0 0 6px var(--accent);border-radius:50%;flex-shrink:0;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.messages-area{scroll-behavior:smooth;flex-direction:column;flex:1;gap:1.25rem;padding:1.5rem;display:flex;overflow-y:auto}.empty-chat{text-align:center;color:var(--text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:3rem 1rem;display:flex}.empty-icon{opacity:.6;margin-bottom:1rem;font-size:3rem}.empty-chat p{margin:.25rem 0;font-size:.95rem}.empty-hint{opacity:.7;font-size:.8rem!important}.message{align-items:flex-start;gap:.8rem;animation:.25s slide-in;display:flex}@keyframes slide-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message--user{flex-direction:row-reverse}.message-avatar{flex-shrink:0;margin-top:2px;font-size:1.4rem}.message-bubble{border-radius:14px;max-width:80%;padding:.9rem 1.1rem;font-size:.9rem;line-height:1.7}.message--user .message-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.message--assistant .message-bubble{background:var(--surface);border:1px solid var(--border);color:var(--text-primary);border-bottom-left-radius:4px}.message--assistant .message-bubble p{margin:.4rem 0}.message--assistant .message-bubble h1,.message--assistant .message-bubble h2,.message--assistant .message-bubble h3{color:var(--text-primary);margin:.75rem 0 .4rem;font-size:1rem;font-weight:700}.message--assistant .message-bubble ul,.message--assistant .message-bubble ol{margin:.4rem 0;padding-left:1.25rem}.message--assistant .message-bubble li{margin:.2rem 0}.message--assistant .message-bubble strong{color:var(--accent)}.message--assistant .message-bubble table{border-collapse:collapse;width:100%;margin:.75rem 0;font-size:.82rem}.message--assistant .message-bubble th,.message--assistant .message-bubble td{border:1px solid var(--border);text-align:left;padding:.4rem .6rem}.message--assistant .message-bubble th{background:var(--surface-elevated);font-weight:600}.message--assistant .message-bubble blockquote{border-left:3px solid var(--accent);color:var(--text-muted);margin:.5rem 0;padding-left:.75rem}.typing-bubble{align-items:center;gap:4px;display:flex;padding:.75rem 1rem!important}.typing-dot{background:var(--text-muted);border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite typing}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-8px)}}.error-msg{color:#f87171;background:#ef44441f;border:1px solid #ef444466;border-radius:10px;align-items:flex-start;gap:.5rem;padding:.75rem 1rem;font-size:.85rem;display:flex}.input-bar{border-top:1px solid var(--border);background:var(--surface);align-items:flex-end;gap:.75rem;padding:1rem 1.25rem;display:flex}.question-input{background:var(--surface-elevated);border:1.5px solid var(--border);color:var(--text-primary);resize:none;border-radius:12px;outline:none;flex:1;padding:.65rem .9rem;font-family:inherit;font-size:.9rem;line-height:1.5;transition:border-color .2s}.question-input:focus{border-color:var(--accent)}.question-input::placeholder{color:var(--text-muted)}.send-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;height:44px;padding:0 1.1rem;transition:background .15s,transform .1s;display:flex}.send-btn:hover:not(:disabled){background:var(--accent-hover);transform:scale(1.04)}.send-btn:disabled{opacity:.4;cursor:not-allowed}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}
