*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #0f0d13;--bg-secondary: #1a1626;--bg-tertiary: #231e30;--accent-primary: #c084fc;--accent-secondary: #f472b6;--text-primary: #f3e8ff;--text-secondary: #a78bca;--text-muted: #6b5b8e;--border: #2d2440;--bubble-user: #3b2d5e;--bubble-Maiden: #1e1830}html{font-size:20px}html,body{height:100vh;height:100dvh;background:var(--bg-primary);color:var(--text-primary);font-family:Segoe UI,system-ui,-apple-system,sans-serif;overflow:hidden}#app{display:flex;height:100vh;height:100dvh}#image-panel{width:38%;min-width:220px;background:var(--bg-secondary);border-right:1px solid var(--border);overflow:hidden;position:relative}#character-iframe{display:block;width:100%;height:100%;border:none;background:transparent}#chat-panel{flex:1;display:flex;flex-direction:column;height:100vh;height:100dvh;min-width:0;overflow:hidden}#chat-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;background:var(--bg-secondary);border-bottom:1px solid var(--border);flex-shrink:0}.header-name{font-size:1.15rem;font-weight:700;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-subtitle{font-size:.72rem;color:var(--text-muted);margin-top:1px}.header-actions{display:flex;gap:.5rem;align-items:center}#clear-btn,#enable-notifications-btn{background:transparent;border:1px solid var(--border);color:var(--text-muted);padding:.35rem .7rem;border-radius:6px;cursor:pointer;font-size:.75rem;transition:border-color .2s,color .2s}#clear-btn:hover,#enable-notifications-btn:hover{border-color:var(--accent-secondary);color:var(--accent-secondary)}#chat-messages{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:.6rem;scrollbar-width:thin;scrollbar-color:var(--border) transparent}#chat-messages::-webkit-scrollbar{width:4px}#chat-messages::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.message{max-width:78%;padding:.65rem .95rem;border-radius:14px;line-height:1.55;font-size:.88rem;word-wrap:break-word;white-space:pre-wrap}.message-user{background:var(--bubble-user);border:1px solid rgba(192,132,252,.25);align-self:flex-end;border-bottom-right-radius:4px}.message-assistant{background:var(--bubble-Maiden);border:1px solid var(--border);align-self:flex-start;border-bottom-left-radius:4px}.typing-indicator{display:flex;gap:5px;align-items:center;padding:.65rem .95rem}.typing-indicator span{display:block;width:7px;height:7px;border-radius:50%;background:var(--text-muted);animation:bounce 1.3s infinite ease-in-out}.typing-indicator span:nth-child(2){animation-delay:.18s}.typing-indicator span:nth-child(3){animation-delay:.36s}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-7px)}}#chat-input-area{display:flex;gap:.65rem;align-items:flex-end;padding:.85rem 1.5rem;background:var(--bg-secondary);border-top:1px solid var(--border);flex-shrink:0}#message-input{flex:1;background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);padding:.65rem 1rem;border-radius:10px;font-size:.88rem;font-family:inherit;resize:none;line-height:1.5;min-height:40px;max-height:120px;outline:none;overflow-y:auto;transition:border-color .2s}#message-input:focus{border-color:var(--accent-primary)}#message-input::placeholder{color:var(--text-muted)}#message-input:disabled{opacity:.5}#send-btn{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;color:#fff;padding:.65rem 1.2rem;border-radius:10px;cursor:pointer;font-size:.88rem;font-weight:600;white-space:nowrap;transition:opacity .2s,transform .1s;flex-shrink:0}#send-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}#send-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}#login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;display:flex;align-items:center;justify-content:center;z-index:100}#login-form{display:flex;flex-direction:column;gap:.85rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:14px;padding:2rem 2.2rem;width:min(360px,calc(100% - 2rem));box-shadow:0 20px 60px #00000080}.login-subtitle{font-size:.78rem;color:var(--text-muted);text-align:center;margin-bottom:.4rem}#password-input{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);padding:.7rem 1rem;border-radius:10px;font-size:.95rem;font-family:inherit;outline:none;transition:border-color .2s}#password-input:focus{border-color:var(--accent-primary)}#login-form button{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;color:#fff;padding:.7rem 1rem;border-radius:10px;cursor:pointer;font-size:.95rem;font-weight:600;transition:opacity .2s,transform .1s}#login-form button:hover{opacity:.88;transform:translateY(-1px)}#login-error{color:#f472b6;font-size:.8rem;text-align:center}@media (max-width: 600px){#app{flex-direction:column}#image-panel{width:100%;height:45dvh;min-width:0;border-right:none;border-bottom:1px solid var(--border)}#chat-panel{height:55dvh;min-height:0}.message{max-width:90%}#send-btn,#clear-btn{min-height:44px;padding:.8rem 1.2rem}#message-input{min-height:44px;font-size:16px}}@media (min-width: 601px) and (max-width: 900px){#image-panel{width:30%;min-width:160px}}
