:root{--primary:#6c5ce7;--primary-light:#a29bfe;--primary-dark:#5541d7;--accent:#00cec9;--accent-light:#81ecec;--pink:#fd79a8;--orange:#fdcb6e;--green:#00b894;--red:#e17055;--bg:#f8f9ff;--card-bg:#fff;--text:#2d3436;--text-light:#636e72;--border:#dfe6e9;--shadow:0 4px 15px #6c5ce71f;--shadow-hover:0 8px 25px #6c5ce733;--radius:16px;--radius-sm:10px;color:var(--text);background:var(--bg);font-family:Segoe UI,system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.5}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);min-height:100dvh;margin:0}#root{max-width:960px;margin:0 auto;padding:0 16px}button{cursor:pointer;border:none;font-family:inherit;font-size:15px;transition:all .2s}.primary-btn{background:var(--primary);color:#fff;border-radius:var(--radius-sm);padding:10px 20px;font-weight:600}.primary-btn:hover:not(:disabled){background:var(--primary-dark);box-shadow:var(--shadow-hover);transform:translateY(-1px)}.primary-btn:disabled{opacity:.5;cursor:not-allowed}.primary-btn.big{border-radius:var(--radius);padding:14px 28px;font-size:17px}.primary-btn.small{padding:6px 14px;font-size:13px}.secondary-btn{background:var(--card-bg);color:var(--primary);border:2px solid var(--primary-light);border-radius:var(--radius-sm);padding:8px 18px;font-weight:600}.secondary-btn:hover{background:var(--primary);color:#fff}.text-btn{color:var(--text-light);background:0 0;padding:8px;text-decoration:underline}.delete-btn{color:var(--red);border-radius:var(--radius-sm);background:0 0;padding:4px 10px;font-size:18px}.delete-btn:hover{background:#e170551a}.group-btn{background:var(--green)!important}.group-btn:hover:not(:disabled){background:#00a884!important}input[type=text],input[type=password],textarea{border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);width:100%;color:var(--text);padding:12px 16px;font-family:inherit;font-size:15px;transition:border-color .2s}input:focus,textarea:focus{border-color:var(--primary-light);outline:none}textarea{resize:vertical}label{color:var(--text-light);text-align:left;margin-bottom:16px;font-size:14px;font-weight:600;display:block}label input,label textarea{margin-top:6px}.error{color:var(--red);margin:8px 0;font-size:14px}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:var(--primary-light);border-radius:3px}.model-loader{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100dvh;padding:20px;display:flex}.model-loader h1{background:linear-gradient(135deg, var(--primary), var(--pink));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2.5rem}.loader-spinner{border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loader-status{color:var(--primary);font-size:16px;font-weight:600}.loader-hint{color:var(--text-light);max-width:400px;font-size:13px}.access-gate{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100dvh;display:flex}.access-gate h1{background:linear-gradient(135deg, var(--primary), var(--pink));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2.5rem}.access-gate p{color:var(--text-light);margin-bottom:8px}.access-gate form{gap:8px;display:flex}.access-gate input{text-align:center;letter-spacing:4px;width:160px;font-size:18px}.app{min-height:100dvh;padding-bottom:32px}.app-header{text-align:center;padding:40px 0 24px}.app-header h1{background:linear-gradient(135deg, var(--primary), var(--pink));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:2.5rem;font-weight:700}.app-header p{color:var(--text-light);font-size:1.1rem}.app-footer{text-align:center;padding:32px 0}.home-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:24px;display:flex}.hint{text-align:center;color:var(--text-light);margin-bottom:16px;font-size:14px}.board-hint{text-align:center;margin-bottom:16px}.board-hint h3{color:var(--primary);margin-bottom:4px;font-size:1.3rem}.board-hint p{color:var(--text-light);font-size:14px}.add-card{cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:180px;transition:all .2s;display:flex;border:3px dashed var(--border)!important;box-shadow:none!important;background:0 0!important}.add-card:hover{transform:translateY(-3px);border-color:var(--primary-light)!important}.add-card-icon{color:var(--text-light);font-size:3rem;font-weight:300;line-height:1}.add-card:hover .add-card-icon{color:var(--primary)}.add-card-text{color:var(--text-light);font-size:14px;font-weight:600}.empty-state{text-align:center;color:var(--text-light);padding:60px 20px;font-size:1.1rem}.player-section{text-align:center;margin-bottom:24px}.make-me-prompt{flex-direction:column;align-items:center;gap:8px;display:flex}.make-me-btn{background:linear-gradient(135deg, var(--primary), var(--pink))!important;padding:16px 40px!important;font-size:1.2rem!important}.make-me-btn:hover{transform:translateY(-2px)!important;box-shadow:0 8px 30px #6c5ce74d!important}.make-me-hint{color:var(--text-light);font-size:13px}.make-me .make-me-subtitle{color:var(--text-light);text-align:center;margin-bottom:24px}.make-me-avatar{flex-direction:column;justify-content:center;align-items:center!important}.make-me-avatar .avatar-preview img{width:150px;height:150px}.make-me-avatar .avatar-placeholder-large{width:150px;height:150px;font-size:4rem}.player-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;border:2px solid var(--primary-light);align-items:center;gap:12px;padding:12px 20px;transition:all .2s;display:inline-flex}.player-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-1px)}.player-avatar img{object-fit:cover;border-radius:50%;width:48px;height:48px}.small-placeholder{width:48px!important;height:48px!important;font-size:1.4rem!important}.player-info{text-align:left;flex-direction:column;display:flex}.player-desc{color:var(--text-light);font-size:12px}.edit-hint{color:var(--primary-light);font-size:12px;font-style:italic}.character-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;padding:0 8px;display:grid}.character-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;text-align:center;border:3px solid #0000;padding:20px;transition:all .25s}.character-card:hover{box-shadow:var(--shadow-hover);transform:translateY(-3px)}.character-card.selected{border-color:var(--green);background:#00b8940d}.card-avatar img{object-fit:cover;border:3px solid var(--primary-light);border-radius:12px;width:140px;height:140px}.avatar-placeholder{background:linear-gradient(135deg, var(--primary-light), var(--pink));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;margin:0 auto;font-size:2.5rem;font-weight:700;display:flex}.selected-badge{background:var(--green);color:#fff;border-radius:20px;margin-top:6px;padding:2px 10px;font-size:11px;font-weight:600;display:inline-block}.character-card h3{margin:12px 0 4px;font-size:1.1rem}.card-personality{color:var(--text-light);margin-bottom:12px;font-size:13px}.card-actions{justify-content:center;align-items:center;gap:8px;display:flex}.token-setup{justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex}.token-card{background:var(--card-bg);border-radius:var(--radius);width:100%;max-width:480px;box-shadow:var(--shadow-hover);text-align:center;padding:40px}.token-card h1{background:linear-gradient(135deg, var(--primary), var(--pink));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:2rem}.token-card .subtitle{color:var(--text-light);margin-bottom:24px}.setup-steps{text-align:left;background:var(--bg);border-radius:var(--radius-sm);margin-bottom:24px;padding:16px 20px}.setup-steps h3{margin-bottom:8px;font-size:15px}.setup-steps ol{color:var(--text-light);margin:0;padding-left:20px;font-size:14px}.setup-steps li{margin-bottom:4px}.setup-steps a{color:var(--primary)}.token-card form{flex-direction:column;gap:12px;display:flex}.token-card button[type=submit]{background:var(--primary);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:12px;font-size:16px;font-weight:600}.token-card button[type=submit]:hover{background:var(--primary-dark)}.privacy-note{color:var(--text-light);margin-top:16px;font-size:12px}.character-creator{max-width:560px;margin:0 auto;padding:32px 0}.character-creator h2{text-align:center;color:var(--primary);margin-bottom:20px;font-size:1.8rem}.templates{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:24px;display:flex}.template-btn{background:var(--card-bg);border:2px solid var(--border);color:var(--text);border-radius:20px;padding:8px 16px;font-size:14px;font-weight:500}.template-btn:hover{border-color:var(--primary-light);color:var(--primary)}.character-creator form{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px}.character-creator details{margin-bottom:16px}.character-creator summary{cursor:pointer;color:var(--primary);margin-bottom:12px;font-size:14px}.avatar-section{background:var(--bg);border-radius:var(--radius-sm);align-items:center;gap:20px;margin-bottom:16px;padding:16px;display:flex}.avatar-preview img{border-radius:var(--radius-sm);object-fit:cover;border:3px solid var(--primary-light);width:120px;height:120px}.avatar-placeholder-large{border-radius:var(--radius-sm);background:var(--border);width:120px;height:120px;color:var(--text-light);justify-content:center;align-items:center;font-size:3rem;display:flex}.avatar-controls{flex-direction:column;flex:1;gap:8px;display:flex}.avatar-hint{color:var(--text-light);font-size:12px}.gen-progress{color:var(--primary);font-size:13px;font-weight:600;animation:1.5s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}select{border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--card-bg);width:100%;color:var(--text);cursor:pointer;margin-top:6px;padding:10px 14px;font-family:inherit;font-size:15px}select:focus{border-color:var(--primary-light);outline:none}.secondary-btn.small{padding:6px 12px;font-size:13px}.creator-actions{justify-content:center;gap:12px;margin-top:8px;display:flex}.chat-room{flex-direction:column;max-width:700px;height:100dvh;margin:0 auto;display:flex}.chat-header{border-bottom:2px solid var(--border);align-items:center;gap:12px;padding:12px 0;display:flex}.back-btn{color:var(--primary);border-radius:var(--radius-sm);background:0 0;padding:4px 12px;font-size:24px}.back-btn:hover{background:#6c5ce714}.chat-character-info{align-items:center;gap:10px;display:flex}.chat-avatar{object-fit:cover;border-radius:50%;width:42px;height:42px}.chat-avatar.small{width:28px;height:28px}.chat-character-info h3{margin:0;font-size:16px}.chat-personality{color:var(--text-light);font-size:12px}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:16px 0;display:flex;overflow-y:auto}.message{border-radius:var(--radius);max-width:80%;padding:10px 16px;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message.user{background:var(--primary);color:#fff;align-self:flex-end}.message.assistant{background:var(--card-bg);box-shadow:var(--shadow);align-self:flex-start}.message.clickable-msg{cursor:pointer}.message.clickable-msg:hover{outline:2px solid var(--primary-light);outline-offset:-2px}.message.system,.message.narrator{color:var(--text-light);background:#6c5ce714;align-self:center;max-width:90%;font-size:14px;font-style:italic}.message-speaker{text-transform:uppercase;letter-spacing:.5px;opacity:.7;margin-bottom:2px;font-size:11px;font-weight:700;display:block}.message.user .message-speaker{text-align:right}.message-text{font-size:15px;line-height:1.5}.message-text.typing{color:var(--text-light);font-style:italic}.message-avatar-row{align-items:center;gap:6px;margin-bottom:4px;display:flex}.message-avatar{object-fit:cover;cursor:pointer;border-radius:10px;width:44px;height:44px;transition:transform .15s}.message-avatar:hover{transform:scale(1.1)}.avatar-zoom-overlay{z-index:400;cursor:pointer;background:#000c;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.avatar-zoom-img{border-radius:var(--radius);max-width:90vw;max-height:80vh;box-shadow:0 8px 40px #00000080}.avatar-zoom-name{text-align:center;color:#fff;text-shadow:0 2px 8px #0009;width:100%;font-size:1.2rem;font-weight:700;position:absolute;bottom:10%}.chat-input{border-top:2px solid var(--border);gap:10px;padding:12px 0;display:flex}.chat-input input{flex:1}.chat-input button{background:var(--primary);color:#fff;border-radius:var(--radius-sm);padding:10px 20px;font-weight:600}.chat-input button:hover:not(:disabled){background:var(--primary-dark)}.chat-input button:disabled{opacity:.4;cursor:not-allowed}.message-image-wrapper{flex-direction:column;gap:8px;display:flex}.message-image{border-radius:var(--radius-sm);cursor:pointer;max-width:280px}.message-image:hover{opacity:.9}.regenerate-btn{color:var(--primary);background:#6c5ce71a;border-radius:20px;align-self:flex-start;padding:4px 14px;font-size:12px;font-weight:600}.regenerate-btn:hover:not(:disabled){background:#6c5ce733}.regenerate-btn:disabled{opacity:.4;cursor:not-allowed}.image-gen-bar{border-top:1px solid var(--border);gap:8px;padding:10px 0;animation:.2s fadeIn;display:flex}.image-gen-bar input{flex:1}.image-gen-bar button{border-radius:var(--radius-sm);padding:8px 16px;font-size:14px;font-weight:600}.image-gen-bar button:first-of-type{background:var(--pink);color:#fff}.image-gen-bar button:first-of-type:hover:not(:disabled){background:#e8608f}.image-gen-bar button:first-of-type:disabled{opacity:.4;cursor:not-allowed}.chat-bottom{border-top:2px solid var(--border)}.chat-bottom .chat-input{border-top:none}.image-btn{border-radius:var(--radius-sm);color:#fff;padding:10px 16px;font-weight:600;background:var(--pink)!important}.image-btn:hover:not(:disabled){background:#e8608f!important}.multi-chat-characters{flex-wrap:wrap;gap:12px;display:flex}.mini-character{align-items:center;gap:6px;font-size:14px;font-weight:600;display:flex}.conversation-setup{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:40px 20px;display:flex}.conversation-setup h3{color:var(--primary);font-size:1.3rem}.conversation-setup input{max-width:400px}.multi-chat-controls{justify-content:center;gap:10px;padding:8px 0;display:flex}.emotion-ring{border:3px solid #0000;border-radius:50%;padding:2px;transition:border-color .5s}.mini-character{flex-direction:column;align-items:center;gap:2px;display:flex}.mini-char-name{text-overflow:ellipsis;white-space:nowrap;max-width:60px;font-size:11px;font-weight:600;overflow:hidden}.multi-chat-characters .chat-avatar{width:44px!important;height:44px!important}.mini-avatar-placeholder{background:var(--primary-light);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;font-size:18px;font-weight:700;display:flex}.topic-btn{color:var(--primary);background:#6c5ce71a;border-radius:20px;margin-left:auto;padding:6px 12px;font-size:12px;font-weight:600}.topic-btn:hover{background:#6c5ce733}.topic-bar{border-bottom:1px solid var(--border);gap:8px;padding:8px 0;animation:.2s fadeIn;display:flex}.topic-bar input{flex:1;padding:8px 12px;font-size:14px}.safety-warning{border-radius:var(--radius-sm);color:#856404;background:#fff3cd;border:1px solid #ffc107;align-items:center;gap:12px;margin:8px 0;padding:12px 16px;font-size:13px;display:flex}.safety-warning p{flex:1;margin:0}.safety-warning button{color:#856404;background:0 0;border-radius:4px;padding:4px 12px;font-size:12px;font-weight:600}.safety-warning button:hover{background:#0000000d}.pm-indicator{background:var(--pink);color:#fff;cursor:pointer;z-index:50;border:2px solid #fff3;border-radius:24px;padding:10px 18px;font-size:13px;font-weight:700;animation:.3s fadeIn;position:fixed;bottom:80px;right:16px;box-shadow:0 4px 16px #fd79a866}.pm-indicator:hover{transform:scale(1.05);box-shadow:0 6px 20px #fd79a880}.pm-panel{background:var(--card-bg);border-left:2px solid var(--border);z-index:100;flex-direction:column;width:320px;max-width:85vw;height:100dvh;animation:.2s slideIn;display:flex;position:fixed;top:0;right:0;box-shadow:-4px 0 20px #0000004d}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.pm-panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.pm-panel-header h4{color:var(--pink);flex:1;margin:0;font-size:16px}.pm-clear-btn{color:var(--text-light);background:0 0;border-radius:4px;padding:4px 8px;font-size:12px}.pm-clear-btn:hover{color:var(--red)}.pm-tabs{border-bottom:1px solid var(--border);gap:2px;padding:8px 8px 0;display:flex;overflow-x:auto}.pm-tab{color:var(--text-light);cursor:pointer;white-space:nowrap;background:0 0;border-bottom:2px solid #0000;border-radius:8px 8px 0 0;align-items:center;gap:4px;padding:6px 12px;font-size:12px;font-weight:600;display:flex}.pm-tab.active{color:var(--pink);border-bottom-color:var(--pink);background:#fd79a80d}.pm-tab-avatar{object-fit:cover;border-radius:50%;width:18px;height:18px}.pm-tab.has-messages{color:var(--text)}.pm-panel-messages{flex-direction:column;flex:1;gap:8px;padding:12px;display:flex;overflow-y:auto}.pm-msg{border-radius:12px;padding:8px 12px;font-size:13px}.pm-sent{background:#6c5ce71a;align-self:flex-end;max-width:85%}.pm-received{background:#fd79a814;align-self:flex-start;max-width:85%}.pm-from-label{color:var(--pink);margin-bottom:2px;font-size:10px;font-weight:700;display:block}.pm-sent .pm-from-label{color:var(--primary)}.pm-text{margin:0;line-height:1.4}.pm-empty{text-align:center;color:var(--text-light);padding:20px;font-size:13px;font-style:italic}.pm-input{border-top:1px solid var(--border);gap:8px;padding:10px 12px;display:flex}.pm-input input{flex:1;padding:8px 12px;font-size:13px}.pm-input button{background:var(--pink);color:#fff;border-radius:var(--radius-sm);padding:8px 16px;font-size:13px;font-weight:600}.pm-input button:disabled{opacity:.4}.message.interrupted .message-text{opacity:.6;font-style:italic}.message.interrupted:after{content:"interrupted";color:var(--orange);margin-top:2px;font-size:10px;font-weight:600;display:block}.stage-direction{color:var(--text-light);opacity:.7;margin-bottom:2px;font-size:12px;font-style:italic}.message-addressed{color:var(--primary);background:#6c5ce714;border-radius:10px;margin-bottom:2px;padding:1px 8px;font-size:11px;font-weight:600;display:inline-block}.message.beat{box-shadow:none!important;background:0 0!important;align-self:center!important;max-width:95%!important;padding:12px 20px!important}.message.beat .message-text{color:var(--text);text-align:center;opacity:.75;font-family:Georgia,Times New Roman,serif;font-size:14px;font-style:italic;line-height:1.7}.message-cue{opacity:.6;font-size:10px;font-style:italic;font-weight:400}.mini-character.is-typing span{color:var(--primary);font-weight:700}.mini-character.is-typing:after{content:" typing...";color:var(--text-light);font-size:11px;font-style:italic}.typing-dots span{font-size:24px;line-height:1;animation:1.4s infinite blink}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,20%{opacity:.2}50%{opacity:1}80%,to{opacity:.2}}.cursor{color:var(--primary);font-weight:300;animation:.6s infinite cursorBlink}@keyframes cursorBlink{0%,49%{opacity:1}50%,to{opacity:0}}.image-message{max-width:90%!important;padding:4px!important}.chat-image-post{border-radius:var(--radius-sm);overflow:hidden}.chat-generated-image{border-radius:var(--radius-sm);width:100%;max-width:300px;display:block}.start-screen{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:40px 20px;display:flex}.start-screen h3{color:var(--primary);font-size:1.4rem}.scene-section{text-align:left;width:100%;max-width:500px}.scene-label{color:var(--text-light);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.scene-row{align-items:center;gap:8px;width:100%;max-width:500px;display:flex}.scene-input-short{border:2px solid var(--border);border-radius:var(--radius-sm);color:var(--text);background:var(--card-bg);flex:1;padding:10px 14px;font-size:15px}.scene-input-short:focus{border-color:var(--primary-light);outline:none}.start-divider{width:100%;max-width:500px;color:var(--text-light);align-items:center;gap:12px;font-size:12px;display:flex}.start-divider:before,.start-divider:after{content:"";background:var(--border);flex:1;height:1px}.start-form{gap:10px;width:100%;max-width:500px;display:flex}.start-form input{flex:1}.speed-control{align-items:center;gap:8px;display:flex}.speed-label{color:var(--text-light);text-align:right;min-width:55px;font-size:11px;font-weight:600}.speed-slider{appearance:none;background:var(--border);border-radius:2px;outline:none;width:80px;height:4px}.speed-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary);cursor:pointer;border-radius:50%;width:16px;height:16px}.auto-chat-btn{background:var(--accent);color:#fff;border-radius:20px;padding:8px 20px;font-weight:600}.auto-chat-btn:hover{background:#00b8b4}.auto-chat-btn.active{background:var(--red)}.auto-chat-btn.active:hover{background:#d35400}.time-nudge{background:linear-gradient(135deg, var(--orange), var(--pink));color:#fff;z-index:100;justify-content:center;align-items:center;gap:16px;padding:12px 20px;font-weight:600;animation:.5s slideDown;display:flex;position:fixed;top:0;left:0;right:0}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.time-nudge button{color:#fff;background:#ffffff4d;border-radius:20px;padding:6px 16px;font-weight:600}.clear-section{text-align:center;padding:32px 0 16px}.text-btn.danger{color:var(--red)}.text-btn.danger:hover{color:#c0392b}.settings-btn{color:var(--primary);background:#6c5ce71a;border-radius:50%;margin-left:4px;padding:6px 10px;font-size:18px;line-height:1}.settings-btn:hover{background:#6c5ce733}.settings-overlay{z-index:200;background:#00000080;justify-content:flex-end;align-items:flex-start;padding:60px 12px 12px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.settings-panel{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-hover);width:280px;max-width:90vw;overflow:hidden}.settings-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px 12px;display:flex}.settings-header h3{margin:0;font-size:16px}.settings-close{color:var(--text-light);background:0 0;padding:0 4px;font-size:22px;line-height:1}.settings-close:hover{color:var(--text)}.settings-body{padding:12px 20px 20px}.settings-row{cursor:pointer;justify-content:space-between;align-items:center;padding:10px 0;display:flex}.settings-row+.settings-row{border-top:1px solid var(--border)}.settings-label{flex-direction:column;gap:2px;display:flex}.settings-label span:first-child{font-size:14px;font-weight:600}.settings-hint{color:var(--text-light);font-size:12px}.settings-slider{width:90px}.settings-divider{text-transform:uppercase;letter-spacing:1px;color:var(--text-light);border-top:1px solid var(--border);margin-top:8px;padding:12px 0 4px;font-size:11px;font-weight:700}.clear-account-confirm{border:1px solid var(--red);border-radius:var(--radius-sm);background:#e74c3c0d;margin-top:8px;padding:12px}.clear-account-confirm p{color:var(--text-light);margin:0 0 8px;font-size:13px}.clear-account-confirm input{width:100%;margin-bottom:8px;font-size:14px}.toggle-switch{background:var(--border);cursor:pointer;border-radius:12px;flex-shrink:0;width:44px;height:24px;transition:background .2s;position:relative}.toggle-switch.on{background:var(--primary)}.toggle-knob{background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .2s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0003}.toggle-switch.on .toggle-knob{transform:translate(20px)}.auth-overlay{z-index:300;background:#0009;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.auth-modal{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-hover);text-align:center;width:100%;max-width:400px;padding:32px;position:relative}.auth-close{color:var(--text-light);background:0 0;font-size:24px;line-height:1;position:absolute;top:12px;right:16px}.auth-close:hover{color:var(--text)}.auth-modal h3{color:var(--primary);margin-bottom:8px;font-size:1.4rem}.auth-reason{border-radius:var(--radius-sm);color:var(--primary);background:#6c5ce714;margin-bottom:12px;padding:8px 16px;font-size:14px}.auth-subtitle{color:var(--text-light);margin-bottom:20px;font-size:14px}.auth-modal form{flex-direction:column;gap:12px;display:flex}.auth-modal input{text-align:center;font-size:16px}.auth-error{color:var(--red);margin:0;font-size:13px}.auth-sent{padding:12px 0}.auth-icon{margin-bottom:12px;font-size:48px}.auth-sent h3{margin-bottom:8px}.auth-sent p{color:var(--text-light);font-size:14px}.auth-hint{margin-top:12px;font-size:12px!important}.auth-bar{margin-top:8px}.auth-info{justify-content:center;align-items:center;gap:8px;font-size:13px;display:flex}.auth-email{color:var(--text-light)}.auth-badge{background:linear-gradient(135deg, var(--primary), var(--pink));color:#fff;text-transform:uppercase;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700}.auth-signin{font-weight:600;color:var(--primary)!important}.nsfw-toggle{cursor:pointer;align-items:center;display:flex}.nsfw-toggle input{display:none}.nsfw-label{background:var(--green);color:#fff;border-radius:6px;padding:2px 8px;font-size:11px;font-weight:800;transition:all .2s}.nsfw-label.on{background:var(--red)}.limit-banner{border:1px solid var(--primary-light);border-radius:var(--radius-sm);text-align:center;background:linear-gradient(135deg,#6c5ce71a,#fd79a81a);margin:8px 0;padding:12px 16px;font-size:14px}.limit-banner .text-btn{color:var(--primary);font-weight:700;text-decoration:underline}.limit-notice{text-align:center;border-radius:var(--radius-sm);color:var(--text-light);background:#6c5ce70f;margin-bottom:16px;padding:8px 16px;font-size:14px}.limit-notice .text-btn{color:var(--primary);font-weight:600}.starter-picker{max-width:700px;margin:0 auto;padding:32px 0}.starter-header{text-align:center;margin-bottom:24px}.starter-header h2{color:var(--primary);margin-bottom:4px;font-size:1.8rem}.starter-header p{color:var(--text-light);font-size:14px}.starter-tabs{background:var(--bg);border-radius:12px;justify-content:center;gap:4px;max-width:300px;margin-bottom:20px;margin-left:auto;margin-right:auto;padding:4px;display:flex}.starter-tab{color:var(--text-light);background:0 0;border-radius:10px;flex:1;padding:8px 16px;font-size:14px;font-weight:600;transition:all .2s}.starter-tab.active{background:var(--primary);color:#fff}.starter-tab:hover:not(.active){color:var(--text)}.starter-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-bottom:24px;padding:0 8px;display:grid}.starter-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;border:2px solid #0000;align-items:flex-start;gap:14px;padding:14px;transition:all .2s;display:flex}.starter-card:hover{box-shadow:var(--shadow-hover);border-color:var(--primary-light);transform:translateY(-2px)}.starter-card.owned{opacity:.4;pointer-events:none;position:relative}.starter-card.owned:after{content:"Added";background:var(--green);color:#fff;border-radius:10px;padding:2px 8px;font-size:10px;font-weight:700;position:absolute;top:8px;right:8px}.starter-avatar img{object-fit:cover;border-radius:10px;flex-shrink:0;width:72px;height:72px}.starter-info{flex:1;min-width:0}.starter-info h3{margin:0 0 4px;font-size:15px}.starter-personality{color:var(--text-light);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:12px;line-height:1.4;display:-webkit-box;overflow:hidden}.starter-ability{color:var(--primary);background:#6c5ce714;border-radius:10px;margin-top:4px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-block}.starter-actions{justify-content:center;gap:12px;display:flex}.starter-actions.top{margin-bottom:0}.starter-divider{max-width:300px;color:var(--text-light);align-items:center;gap:12px;margin:16px auto;font-size:13px;display:flex}.starter-divider:before,.starter-divider:after{content:"";background:var(--border);flex:1;height:1px}.confirm-modal{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-hover);text-align:center;width:100%;max-width:340px;padding:28px}.confirm-modal h3{margin:0 0 8px;font-size:1.2rem}.confirm-modal p{color:var(--text-light);margin:0 0 20px;font-size:14px}.confirm-actions{justify-content:center;gap:10px;display:flex}.danger-btn{background:var(--red)!important}.danger-btn:hover{background:#c0392b!important}.invite-grid{flex-wrap:wrap;justify-content:center;gap:8px;margin-bottom:16px;display:flex}.invite-char{background:var(--bg);border:1px solid var(--border);cursor:pointer;border-radius:20px;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;display:flex}.invite-char:hover{border-color:var(--primary);color:var(--primary)}.invite-avatar{object-fit:cover;border-radius:50%;width:28px;height:28px}.idle-banner{text-align:center;border-top:1px solid var(--border);background:#6c5ce70f;justify-content:center;align-items:center;gap:12px;padding:12px 16px;display:flex}.idle-banner p{color:var(--text-light);margin:0;font-size:13px}.idle-banner .primary-btn{padding:6px 20px;font-size:13px}.mini-character.clickable{cursor:pointer}.mini-character.clickable:hover .emotion-ring{border-color:var(--primary)!important}.remove-char-btn{background:var(--red);color:#fff;cursor:pointer;border:2px solid var(--card-bg);border-radius:50%;justify-content:center;align-items:center;width:16px;height:16px;font-size:10px;line-height:1;display:none;position:absolute;top:-4px;right:-4px}.mini-character{position:relative}.mini-character:hover .remove-char-btn{display:flex}.mini-character.targeted{transform:scale(1.1)}.mini-character.targeted .mini-char-name{color:var(--primary);font-weight:700}.address-badge{background:var(--primary);color:#fff;cursor:pointer;white-space:nowrap;border-radius:16px;flex-shrink:0;padding:4px 10px;font-size:12px;font-weight:700;transition:background .2s}.address-badge:hover{background:var(--primary-dark)}.address-badge.pm-badge{background:var(--pink)}.pm-toggle{color:var(--pink);cursor:pointer;background:#fd79a81a;border:1px solid #0000;border-radius:8px;flex-shrink:0;padding:4px 8px;font-size:11px;font-weight:700}.pm-toggle:hover{border-color:var(--pink)}.pm-toggle.active{background:var(--pink);color:#fff}.at-menu{border-top:1px solid var(--border);gap:4px;padding:8px 4px;animation:.15s fadeIn;display:flex;overflow-x:auto}.at-menu-item{background:var(--card-bg);border:1px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:20px;align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:600;transition:all .15s;display:flex}.at-menu-item:hover{border-color:var(--primary);color:var(--primary)}.at-menu-avatar{object-fit:cover;border-radius:50%;width:22px;height:22px}.starter-scroll-section{border-top:1px solid var(--border);margin-top:40px;padding:32px 0}.starter-tagline{text-align:center;margin-bottom:24px;padding:0 20px}.starter-tagline h2{background:linear-gradient(135deg, var(--primary), var(--pink));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:8px;font-size:1.6rem}.starter-tagline p{color:var(--text-light);max-width:500px;margin:0 auto;font-size:14px;line-height:1.5}.starter-scroll-track{width:100%;padding-top:12px;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 5% 95%,#0000);mask-image:linear-gradient(90deg,#0000,#000 5% 95%,#0000)}.starter-scroll-inner{gap:16px;width:max-content;animation:40s linear infinite starterScroll;display:flex}.starter-scroll-inner:hover{animation-play-state:paused}@keyframes starterScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.scroll-card{cursor:pointer;flex-direction:column;flex-shrink:0;align-items:center;gap:6px;transition:transform .2s;display:flex}.scroll-card:hover{transform:scale(1.1)}.scroll-avatar{object-fit:cover;border:3px solid var(--border);border-radius:50%;width:90px;height:90px;transition:border-color .2s}.scroll-card:hover .scroll-avatar{border-color:var(--primary)}.scroll-avatar-placeholder{background:linear-gradient(135deg, var(--primary-light), var(--pink));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:2rem;font-weight:700;display:flex}.scroll-name{color:var(--text);font-size:12px;font-weight:600}.quick-name-prompt{text-align:center;padding:12px 0}.quick-name-avatar{object-fit:cover;border:3px solid var(--primary-light);border-radius:50%;width:80px;height:80px;margin-bottom:12px}.quick-name-prompt h3{color:var(--primary);margin-bottom:4px}.quick-name-prompt p{color:var(--text-light);margin-bottom:16px;font-size:14px}.quick-name-prompt form{flex-direction:column;gap:12px;display:flex}.quick-name-prompt input{text-align:center;font-size:18px}.app-footer{text-align:center;border-top:1px solid var(--border);flex-direction:column;align-items:center;gap:8px;margin-top:40px;padding:32px 20px 24px;display:flex}.age-badge{background:var(--primary);color:#fff;letter-spacing:1px;border-radius:6px;padding:3px 10px;font-size:11px;font-weight:800}.footer-sep{color:var(--text-light);font-size:13px}.footer-links{gap:16px;display:flex}.footer-links a{color:var(--text-light);font-size:12px;text-decoration:none}.footer-links a:hover{color:var(--primary)}@media (width<=600px){.app-header h1{font-size:1.8rem}.character-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.card-avatar img,.avatar-placeholder{width:70px;height:70px;font-size:2rem}.token-card{padding:24px}.message{max-width:90%}}
