*{margin:0;padding:0;box-sizing:border-box}:root{--color-bg:#f5f7fa;--color-surface:#fff;--color-border:#e1e8ed;--color-text:#1a202c;--color-text-secondary:#718096;--color-primary:#3182ce;--color-primary-hover:#2c5aa0;--color-accent:#38a169;--color-success:#48bb78;--color-warning:#ed8936;--color-error:#f56565;--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--spacing-2xl:48px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--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)}body,html{overflow-y:auto}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Kaku Gothic ProN,Hiragino Sans,Meiryo,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.container,body{min-height:100vh}.container{max-width:1600px;margin:0 auto;display:flex;flex-direction:column;background:var(--color-surface);box-shadow:var(--shadow-xl);border-radius:0}.header{border-bottom:1px solid var(--color-border);padding:var(--spacing-xl) var(--spacing-2xl);background:linear-gradient(135deg,var(--color-surface) 0,var(--color-bg) 100%);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-content{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.header-main{flex:1 1}.header h1{font-size:28px;font-weight:600;color:var(--color-text);margin-bottom:var(--spacing-xs);letter-spacing:-.02em}.header p{font-size:15px;color:var(--color-text-secondary);font-weight:400}.github-link{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);text-decoration:none;font-size:14px;font-weight:600;transition:all .2s ease;box-shadow:var(--shadow-sm)}.github-link:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.github-link svg{width:18px;height:18px}.header-badge{display:flex;align-items:center;gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);flex-wrap:wrap}.badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-md);background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);color:#fff;border-radius:var(--radius-md);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;box-shadow:var(--shadow-sm);white-space:nowrap}.badge-text{font-size:13px;color:var(--color-text-secondary);font-weight:500;line-height:1.5}.badge-text:before{content:"→ ";color:var(--color-primary);font-weight:600}.main-content{display:flex;flex:1 1;min-height:0;gap:1px;background:var(--color-border)}.avatar-section{flex:0 0 55%;display:flex;flex-direction:column;padding:var(--spacing-2xl);background:var(--color-surface);min-width:0}.avatar-wrapper{flex:1 1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:0}.avatar-container{width:100%;max-width:100%;height:100%;max-height:800px;min-height:600px;background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:var(--radius-xl);aspect-ratio:1;box-shadow:var(--shadow-xl);border:1px solid var(--color-border)}.subtitle-container{margin-top:var(--spacing-lg);padding:var(--spacing-lg);background:var(--color-bg);border-radius:var(--radius-lg);font-size:15px;line-height:1.6;color:var(--color-text);text-align:center;min-height:64px;max-height:120px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-border);width:100%;overflow-y:auto;word-wrap:break-word}.subtitle-container::-webkit-scrollbar{width:6px}.subtitle-container::-webkit-scrollbar-track{background:transparent}.subtitle-container::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.subtitle-container::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.chat-section{flex:0 0 45%;display:flex;flex-direction:column;padding:var(--spacing-2xl);background:var(--color-surface);min-width:0;overflow:hidden;gap:var(--spacing-md)}.chat-messages{flex:1 1;overflow-y:auto;overflow-x:hidden;margin-bottom:var(--spacing-lg);padding-right:var(--spacing-md);padding-left:var(--spacing-sm);display:flex;flex-direction:column;min-height:0}.chat-messages::-webkit-scrollbar{width:8px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.message{margin-bottom:var(--spacing-md);padding:var(--spacing-md) var(--spacing-lg);border-radius:var(--radius-lg);font-size:15px;line-height:1.6;word-wrap:break-word;max-width:85%}.message.user{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);color:#fff;align-self:flex-end;margin-left:auto;margin-right:0;width:-moz-fit-content;width:fit-content;box-shadow:var(--shadow-md)}.message.assistant{background:var(--color-bg);color:var(--color-text);align-self:flex-start;margin-right:auto;margin-left:0;border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.chat-input-container{display:flex;gap:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);flex-shrink:0}.user-input{flex:1 1;padding:var(--spacing-md) var(--spacing-lg);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);font-size:15px;font-family:inherit;background:var(--color-surface);color:var(--color-text);outline:none;transition:all .2s ease;box-shadow:var(--shadow-sm)}.user-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px rgba(49,130,206,.1),var(--shadow-md);transform:translateY(-1px)}.user-input::placeholder{color:var(--color-text-secondary)}.chat-button{padding:var(--spacing-md) var(--spacing-xl);background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;box-shadow:var(--shadow-md);letter-spacing:.3px}.chat-button:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary-hover) 0,var(--color-primary) 100%);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.chat-button:active:not(:disabled){transform:scale(.98)}.chat-button:disabled{opacity:.5;cursor:not-allowed}.loading{display:inline-flex;align-items:center;justify-content:center;gap:8px}.loading-spinner{width:18px;height:18px;border-radius:50%;border:3px solid hsla(0,0%,100%,.2);border-top-color:#fff;animation:spin .8s linear infinite}.loading-text{font-size:14px;font-weight:500}@keyframes spin{to{transform:rotate(1turn)}}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;opacity:0;pointer-events:none;transition:opacity .3s ease}.loading-overlay.active{opacity:1;pointer-events:all}.loading-card{background:var(--color-surface);padding:var(--spacing-2xl);border-radius:var(--radius-xl);box-shadow:0 20px 60px rgba(0,0,0,.3);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-lg);min-width:280px}.loading-card-spinner{width:48px;height:48px;border-radius:50%;border:4px solid var(--color-border);border-top-color:var(--color-primary);animation:spin .8s linear infinite}.loading-card-text{font-size:16px;color:var(--color-text)}.loading-card-text,.status{font-weight:500;text-align:center}.status{font-size:12px;color:var(--color-text-secondary);flex-shrink:0;padding:var(--spacing-xs) 0}.controls-panel{padding:var(--spacing-lg);background:linear-gradient(135deg,var(--color-bg) 0,var(--color-surface) 100%);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);max-height:350px;overflow-y:auto;flex-shrink:0}.controls-panel::-webkit-scrollbar{width:6px}.controls-panel::-webkit-scrollbar-track{background:transparent}.controls-panel::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.controls-panel::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.controls-panel h3{font-size:13px;font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-md);margin-top:var(--spacing-md);text-transform:uppercase;letter-spacing:.8px}.controls-panel h3:first-child{margin-top:0}.controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));grid-gap:var(--spacing-sm);gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.control-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.control-group label{font-size:12px;color:var(--color-text-secondary);font-weight:500}.control-button{padding:var(--spacing-sm) var(--spacing-md);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:13px;font-weight:600;color:var(--color-text);cursor:pointer;transition:all .2s ease;text-align:center;box-shadow:var(--shadow-sm)}.control-button:hover:not(:disabled){background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);color:#fff;border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.control-button:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.control-button:disabled{opacity:.4;cursor:not-allowed;background:var(--color-bg)}.control-button.active{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);color:#fff;border-color:var(--color-primary);box-shadow:var(--shadow-md)}@media (max-width:1024px){.container{height:auto;min-height:100vh}.main-content{flex-direction:column}.avatar-section,.chat-section{flex:1 1}.avatar-section,.chat-section{padding:var(--spacing-xl)}.avatar-container{max-height:500px;min-height:400px}}@media (max-width:768px){.container{min-height:100vh;height:auto}.header{padding:var(--spacing-md) var(--spacing-lg)}.header-content{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.header h1{font-size:20px}.github-link{width:100%;justify-content:center}.header-badge{flex-direction:column;align-items:flex-start;gap:var(--spacing-xs)}.avatar-section,.chat-section{padding:var(--spacing-lg);min-height:0}.avatar-section,.chat-section{overflow:visible}.avatar-container{min-height:300px}.message{font-size:14px}.message,.message.user{max-width:90%}.chat-input-container{flex-direction:column}.chat-button{width:100%}.controls-panel{padding:var(--spacing-md)}.controls-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-xs)}.control-button{font-size:12px;padding:var(--spacing-xs) var(--spacing-sm)}}