:root{font-family:Inter,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;width:100%;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}}*{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f1a;--surface: #1a1a2e;--surface2: #16213e;--accent: #7c3aed;--accent2: #a78bfa;--text: #e2e8f0;--text-muted: #94a3b8;--border: rgba(255,255,255,.1);--radius: 12px}body{background:var(--bg);color:var(--text);font-family:Hiragino Sans,Meiryo,sans-serif;min-height:100vh}#root{max-width:100%;padding:0;text-align:left}input,textarea,select{background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text);padding:10px 14px;width:100%;font-size:.95rem;outline:none;transition:border-color .2s}input:focus,textarea:focus,select:focus{border-color:var(--accent2)}button{cursor:pointer;font-family:inherit}.loading{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--text-muted);font-size:1.1rem}.auth-page{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:40px;width:100%;max-width:400px}.auth-title{font-size:1.5rem;font-weight:700;margin-bottom:28px;text-align:center}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.85rem;color:var(--text-muted)}.auth-btn{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:12px;font-size:1rem;font-weight:600;margin-top:8px;transition:opacity .2s}.auth-btn:hover{opacity:.85}.auth-btn:disabled{opacity:.5;cursor:not-allowed}.auth-error{color:#f87171;font-size:.85rem;text-align:center}.auth-link{text-align:center;margin-top:20px;font-size:.85rem;color:var(--text-muted)}.auth-link a{color:var(--accent2);text-decoration:none}.dashboard{display:flex;flex-direction:column;min-height:100vh;max-width:900px;margin:0 auto;padding:0 24px 40px}.dashboard-header{display:flex;align-items:center;justify-content:space-between;padding:20px 0;border-bottom:1px solid var(--border);margin-bottom:24px}.dashboard-header h1{font-size:1.3rem}.btn-secondary{background:transparent;border:1px solid var(--border);color:var(--text-muted);border-radius:8px;padding:8px 16px;font-size:.85rem;transition:border-color .2s}.btn-secondary:hover{border-color:var(--text-muted)}.chat-url-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:24px}.chat-url-label{font-size:.8rem;color:var(--text-muted);display:block;margin-bottom:8px}.chat-url-row{display:flex;gap:8px}.chat-url-input{flex:1;font-size:.85rem}.btn-copy,.btn-open{padding:8px 14px;border-radius:8px;font-size:.85rem;font-weight:600;white-space:nowrap;text-decoration:none;display:inline-flex;align-items:center}.btn-copy{background:var(--surface2);border:1px solid var(--border);color:var(--text)}.btn-open{background:var(--accent);border:none;color:#fff}.dashboard-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:0}.dashboard-tab{background:transparent;border:none;color:var(--text-muted);padding:10px 18px;font-size:.9rem;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .2s,border-color .2s}.dashboard-tab.active{color:var(--accent2);border-bottom-color:var(--accent2)}.dashboard-tab:hover{color:var(--text)}.dashboard-content{flex:1;padding-top:4px}.tab-panel{display:flex;flex-direction:column;gap:20px}.tab-desc{font-size:.85rem;color:var(--text-muted);line-height:1.6}textarea{resize:vertical;line-height:1.6}.dashboard-footer{padding-top:24px;border-top:1px solid var(--border);margin-top:24px}.btn-save{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:12px 32px;font-size:1rem;font-weight:600;transition:opacity .2s}.btn-save:hover{opacity:.85}.btn-save:disabled{opacity:.5;cursor:not-allowed}.chat-page{display:flex;height:100vh;overflow:hidden}.chat-avatar-area{width:40%;max-width:480px;position:relative;display:flex;flex-direction:column;align-items:center;justify-content:flex-end}.chat-character-name{position:absolute;bottom:16px;left:50%;transform:translate(-50%);background:#0009;color:#fff;padding:4px 16px;border-radius:20px;font-size:.9rem;font-weight:600;white-space:nowrap}.chat-area{flex:1;display:flex;flex-direction:column;overflow:hidden}.chat-messages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.chat-empty{text-align:center;color:var(--text-muted);margin-top:40px}.chat-message{display:flex;flex-direction:column;gap:4px;max-width:75%}.chat-message.user{align-self:flex-start;align-items:flex-start}.chat-message.assistant{align-self:flex-end;align-items:flex-end}.chat-message-name{font-size:.75rem;color:var(--text-muted);padding:0 4px}.chat-message-bubble{padding:10px 14px;border-radius:12px;font-size:.95rem;line-height:1.6;white-space:pre-wrap}.chat-message.user .chat-message-bubble{background:var(--accent);color:#fff;border-bottom-left-radius:4px}.chat-message.assistant .chat-message-bubble{background:var(--surface);border:1px solid var(--border);border-bottom-right-radius:4px}.chat-thinking{color:var(--text-muted);font-style:italic}.chat-input-area{display:flex;gap:8px;padding:16px;border-top:1px solid var(--border)}.chat-input{flex:1;resize:none;border-radius:10px;font-size:.95rem;line-height:1.5}.chat-send-btn{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:0 20px;font-size:.95rem;font-weight:600;align-self:flex-end;height:44px;transition:opacity .2s}.chat-send-btn:hover{opacity:.85}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed}.preview-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.preview-canvas-wrapper{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative}.preview-canvas{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.avatar-layer{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:contain}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideInFromTop{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideOutToBottom{0%{transform:translateY(0);opacity:1}to{transform:translateY(10px);opacity:0}}.cf-fade-in{animation:fadeIn var(--duration, .15s) ease forwards}.cf-fade-out{animation:fadeOut var(--duration, .15s) ease forwards}.cf-eye-slide-in{animation:slideInFromTop var(--duration, .15s) ease forwards}.cf-eye-slide-out{animation:slideOutToBottom var(--duration, .15s) ease forwards}.slots-container{padding:8px 0}.slots-title{font-size:1.1rem;margin-bottom:20px}.slot-group{margin-bottom:24px}.slot-group h3{font-size:.9rem;color:var(--text-muted);margin-bottom:12px}.drop-zones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.drop-zone{background:var(--surface2);border:2px dashed var(--border);border-radius:10px;padding:16px 8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:100px;position:relative;transition:border-color .2s}.drop-zone:hover,.drop-zone.drag-active{border-color:var(--accent2)}.drop-zone-icon{font-size:1.5rem}.drop-zone-label{font-size:.75rem;color:var(--text-muted);text-align:center}.drop-zone-image{width:100%;height:80px;object-fit:contain;border-radius:6px}.drop-zone-clear{position:absolute;top:4px;right:6px;background:#0009;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:12px;display:flex;align-items:center;justify-content:center}.bg-toggle-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:8px;padding:10px;font-size:.85rem;transition:border-color .2s}.bg-toggle-btn:hover{border-color:var(--accent2)}@media (max-width: 640px){.chat-page{flex-direction:column}.chat-avatar-area{width:100%;height:40vh;max-width:100%}.chat-area{height:60vh}.dashboard-tabs{overflow-x:auto}}.anim-tab{padding:0!important}.anim-layout{display:flex;gap:24px;align-items:flex-start}.anim-preview-col{display:flex;flex-direction:column;align-items:center;gap:12px;flex-shrink:0}.anim-preview-wrap{width:280px;height:360px;border-radius:12px;overflow:hidden;position:relative}.anim-preview-wrap .preview-container,.anim-preview-wrap .preview-canvas-wrapper,.anim-preview-wrap .preview-canvas{width:100%;height:100%}.btn-preview{background:var(--accent);color:#fff;border:none;border-radius:8px;padding:8px 20px;font-size:.9rem;cursor:pointer;transition:opacity .2s}.btn-preview:hover{opacity:.85}.anim-settings-col{flex:1;display:flex;flex-direction:column;gap:16px}.anim-settings-col .form-group label input[type=checkbox]{margin-right:6px}
