:root{font-family:Hiragino Sans,Hiragino Kaku Gothic ProN,Noto Sans JP,-apple-system,BlinkMacSystemFont,sans-serif;color-scheme:light;--bg:#f7f8fa;--fg:#1a1a2e;--fg-muted:#6b7280;--border:#e5e7eb;--user-bg:#4f46e5;--user-fg:#ffffff;--assistant-bg:#ffffff;--assistant-fg:#1a1a2e;--accent:#4f46e5;--accent-hover:#4338ca;--surface:#ffffff;--sidebar-bg:#111827;--sidebar-fg:#e5e7eb;--sidebar-fg-muted:#9ca3af;--sidebar-hover:#1f2937;--sidebar-active:#374151;--sidebar-width:280px;--shadow-sm:0 1px 2px rgba(0,0,0,0.05);--shadow-md:0 4px 12px rgba(0,0,0,0.08);--radius-sm:8px;--radius-md:16px;--radius-lg:24px}*{margin:0;padding:0;box-sizing:border-box}body,html{height:100dvh;background-color:var(--bg);color:var(--fg)}.app-layout{position:relative}.app-layout,.sidebar{display:flex;height:100%}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);color:var(--sidebar-fg);flex-direction:column;flex-shrink:0;transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:30}@media (max-width:768px){.sidebar{position:fixed;left:0;top:0;transform:translateX(-100%)}.sidebar.sidebar-open{transform:translateX(0)}}@media (min-width:769px){.sidebar{position:relative;transform:none}.menu-btn{display:none!important}}.sidebar-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:20;animation:fadeIn .2s ease}@media (min-width:769px){.sidebar-overlay{display:none}}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 16px 12px;border-bottom:1px solid rgba(255,255,255,.08)}.sidebar-header h2{font-size:15px;font-weight:600;color:var(--sidebar-fg)}.sidebar-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--sidebar-fg-muted);cursor:pointer;transition:all .15s ease}.sidebar-close-btn:hover{background:var(--sidebar-hover);color:var(--sidebar-fg)}@media (min-width:769px){.sidebar-close-btn{display:none}}.sidebar-new{padding:12px 12px 8px}.new-chat-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;border:1px dashed rgba(255,255,255,.15);border-radius:var(--radius-sm);background:transparent;color:var(--sidebar-fg);font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s ease}.new-chat-btn:hover{background:var(--sidebar-hover);border-color:rgba(255,255,255,.25)}.sidebar-threads{flex:1 1;overflow-y:auto;padding:4px 12px 16px}.thread-list-item{display:flex;align-items:center;gap:4px;margin-bottom:2px;border-radius:var(--radius-sm);transition:background .15s ease}.thread-list-item:hover{background:var(--sidebar-hover)}.thread-list-item-active{background:var(--sidebar-active)}.thread-list-item-trigger{flex:1 1;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;background:transparent;color:var(--sidebar-fg-muted);font-size:13px;font-family:inherit;cursor:pointer;text-align:left;min-width:0;transition:color .15s ease}.thread-list-item-active .thread-list-item-trigger,.thread-list-item:hover .thread-list-item-trigger{color:var(--sidebar-fg)}.thread-list-item-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.thread-list-item-edit{flex:1 1;min-width:0;background:var(--bg);color:var(--fg);border:1px solid var(--accent);border-radius:4px;padding:2px 6px;font-size:.85rem;outline:none}.thread-list-item-menu-wrapper{position:relative;flex-shrink:0;margin-right:6px}.thread-list-item-menu-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:6px;background:transparent;color:var(--sidebar-fg-muted);cursor:pointer;opacity:0;transition:all .15s ease}.thread-list-item:hover .thread-list-item-menu-btn{opacity:1}.thread-list-item-menu-btn:hover{background:rgba(255,255,255,.1);color:var(--sidebar-fg)}.thread-list-item-dropdown{position:absolute;right:0;top:100%;z-index:50;min-width:120px;background:var(--sidebar-bg);border:1px solid rgba(255,255,255,.12);border-radius:8px;padding:4px;box-shadow:0 4px 12px rgba(0,0,0,.3)}.dropdown-item{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;border:none;border-radius:4px;background:transparent;color:var(--sidebar-fg);font-size:.8rem;cursor:pointer;transition:background .15s ease}.dropdown-item:hover{background:rgba(255,255,255,.1)}.dropdown-item-danger:hover{background:rgba(239,68,68,.15);color:#ef4444}.sidebar-empty{text-align:center;color:var(--sidebar-fg-muted);font-size:13px;padding:20px 0}.chat-container{flex-direction:column;flex:1 1;min-width:0;height:100%}.chat-container,.chat-header{display:flex;background:var(--surface)}.chat-header{align-items:center;gap:12px;padding:14px 24px;border-bottom:1px solid var(--border);box-shadow:var(--shadow-sm);position:-webkit-sticky;position:sticky;top:0;z-index:10}.menu-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--fg);cursor:pointer;transition:background .15s ease}.menu-btn:hover{background:#f3f4f6}.header-icon{justify-content:center;width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--accent),#7c3aed);color:white;flex-shrink:0}.header-icon,.header-text{display:flex;align-items:center}.header-text{gap:10px}.header-spacer{flex:1 1}.chat-header h1{font-size:17px;font-weight:700;letter-spacing:-.01em}.header-badge{font-size:11px;font-weight:600;color:var(--accent);background:#eef2ff;padding:2px 8px;border-radius:100px;letter-spacing:.02em}.signout-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--fg-muted);font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s ease;flex-shrink:0}.signout-btn:hover{background:#fef2f2;border-color:#fca5a5;color:#dc2626}.chat-thread{flex:1 1;min-height:0}.thread-root{display:flex;flex-direction:column;height:100%}.thread-viewport{flex:1 1;overflow-y:auto;padding:24px 20px;scroll-behavior:smooth}@media (min-width:769px){.thread-viewport{padding:24px 48px}}.thread-empty{flex-direction:column;height:100%;gap:12px;padding:40px 20px}.empty-icon,.thread-empty{display:flex;align-items:center;justify-content:center}.empty-icon{width:72px;height:72px;border-radius:20px;background:linear-gradient(135deg,#eef2ff,#e0e7ff);color:var(--accent);margin-bottom:8px}.empty-title{font-size:22px;font-weight:700;color:var(--fg)}.empty-subtitle{font-size:15px;color:var(--fg-muted);margin-bottom:12px}.suggestions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;max-width:520px}.suggestion-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border:1px solid var(--border);border-radius:var(--radius-lg);font-size:13px;font-weight:500;color:var(--fg);background:var(--surface);cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow-sm)}.suggestion-btn:hover{background-color:#f5f3ff;border-color:var(--accent);color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-1px)}.message{margin-bottom:20px;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message-row{display:flex;align-items:flex-start;gap:10px;max-width:780px;margin:0 auto}.message-row-user{justify-content:flex-end}.message-row-assistant{justify-content:flex-start}.avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:10px;flex-shrink:0;margin-top:2px}.avatar-user{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:white}.avatar-assistant{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:var(--accent)}.message-bubble{padding:12px 16px;line-height:1.65;font-size:14px;word-break:break-word;max-width:75%}.message-bubble-user{background:linear-gradient(135deg,var(--user-bg),#6366f1);color:var(--user-fg);border-radius:var(--radius-md) var(--radius-md) 4px var(--radius-md);box-shadow:0 2px 8px rgba(79,70,229,.2)}.message-bubble-wrapper{max-width:80%;min-width:0}.message-bubble-assistant{background:var(--assistant-bg);color:var(--assistant-fg);border-radius:var(--radius-md) var(--radius-md) var(--radius-md) 4px;border:1px solid var(--border);box-shadow:var(--shadow-sm);max-width:100%}.message-bubble-assistant p{margin:0 0 10px}.message-bubble-assistant p:last-child{margin-bottom:0}.message-bubble-assistant ol,.message-bubble-assistant ul{margin:8px 0;padding-left:20px}.message-bubble-assistant code{background:#f3f4f6;padding:2px 6px;border-radius:4px;font-size:13px}.message-bubble-assistant pre{background:#1e1e2e;color:#cdd6f4;padding:14px;border-radius:var(--radius-sm);overflow-x:auto;margin:10px 0;font-size:13px}.message-bubble-assistant pre code{background:none;padding:0;color:inherit}.source-pages{font-size:12px;color:var(--fg-muted);margin-top:6px;padding-left:2px}.thinking-indicator{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--assistant-bg);border:1px solid var(--border);border-radius:var(--radius-md) var(--radius-md) var(--radius-md) 4px;box-shadow:var(--shadow-sm);animation:fadeIn .3s ease}.thinking-dots{display:flex;gap:4px;align-items:center}.thinking-dots .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);opacity:.4;animation:pulse 1.4s ease-in-out infinite}.thinking-dots .dot:nth-child(2){animation-delay:.2s}.thinking-dots .dot:nth-child(3){animation-delay:.4s}@keyframes pulse{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.thinking-label{font-size:13px;color:var(--fg-muted);font-weight:500}.action-bar{display:flex;gap:2px;margin-top:6px;padding-left:2px}.action-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:none;border-radius:var(--radius-sm);background:transparent;color:#aaa;cursor:pointer;transition:all .15s ease}.action-btn:hover{background-color:#f3f4f6;color:var(--fg)}.composer-area{padding:0 20px 16px;background:var(--surface)}@media (min-width:769px){.composer-area{padding:0 48px 20px}}.composer{display:flex;align-items:center;gap:10px;padding:8px 8px 8px 18px;border:2px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);max-width:780px;margin:0 auto;transition:border-color .2s ease,box-shadow .2s ease}.composer:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,70,229,.1)}.composer-input{flex:1 1;padding:8px 0;border:none;font-size:14px;outline:none;font-family:inherit;color:var(--fg);background:transparent}.composer-input::placeholder{color:#9ca3af}.composer-send{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border:none;border-radius:12px;background:linear-gradient(135deg,var(--accent),#6366f1);color:white;cursor:pointer;transition:all .2s ease;flex-shrink:0}.composer-send:hover{background:linear-gradient(135deg,var(--accent-hover),#4f46e5);box-shadow:0 2px 8px rgba(79,70,229,.3);transform:scale(1.05)}.composer-send:disabled{background:#d1d5db;cursor:default;box-shadow:none;transform:none}.composer-loading{display:flex;align-items:center;justify-content:center;width:38px;height:38px;flex-shrink:0}.spinner{width:22px;height:22px;border:2.5px solid #e5e7eb;border-top:2.5px solid var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.composer-note{text-align:center;font-size:11px;color:#9ca3af;margin-top:8px}.login-container{justify-content:center;min-height:100dvh;background:var(--bg);padding:20px}.login-card,.login-container{display:flex;flex-direction:column;align-items:center}.login-card{gap:24px;padding:48px 40px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);max-width:400px;width:100%}.login-icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;border-radius:20px;background:linear-gradient(135deg,var(--accent),#7c3aed);color:white}.login-card h1{font-size:22px;font-weight:700;color:var(--fg)}.login-card p{font-size:14px;color:var(--fg-muted);text-align:center}.login-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 24px;border:none;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent),#6366f1);color:white;font-size:15px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-hover),#4f46e5);box-shadow:0 2px 8px rgba(79,70,229,.3);transform:translateY(-1px)}.login-btn:disabled{opacity:.7;cursor:default;transform:none}.login-form{width:100%;gap:16px}.login-field,.login-form{display:flex;flex-direction:column}.login-field{gap:6px}.login-label{font-size:13px;font-weight:600;color:var(--fg)}.login-input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:inherit;color:var(--fg);background:var(--surface);outline:none;transition:border-color .2s ease,box-shadow .2s ease}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,70,229,.1)}.login-input::placeholder{color:#9ca3af}.login-error{font-size:13px;color:#dc2626;text-align:center;padding:8px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm)}.spinner-sm{width:16px;height:16px;border-width:2px}