.avatar-upload{position:relative;border-radius:50%;overflow:visible;margin:0 auto}.avatar-preview{width:100%;height:100%;border-radius:50%;overflow:hidden;background-color:var(--surface-hover);cursor:pointer;position:relative;border:2px dashed var(--border-color);transition:all .2s;display:flex;align-items:center;justify-content:center}.avatar-preview:hover{border-color:var(--primary-color);opacity:.9}.avatar-image{width:100%;height:100%;object-fit:cover}.avatar-placeholder{font-size:2rem;color:var(--text-secondary)}.avatar-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center}.avatar-upload .spinner{width:20px;height:20px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;animation:avatar-spin 1s linear infinite}@keyframes avatar-spin{to{transform:rotate(360deg)}}.avatar-error{position:absolute;bottom:-25px;left:50%;transform:translate(-50%);color:var(--error-color);font-size:.8rem;white-space:nowrap}.crop-modal{position:fixed;inset:0;background:#000000e6;z-index:3000;display:flex;align-items:center;justify-content:center;padding:1rem}.crop-container{background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;max-width:500px;overflow:hidden;display:flex;flex-direction:column}.crop-area{position:relative;height:300px;background:#000}.crop-controls{padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.zoom-control{display:flex;align-items:center;gap:1rem;color:var(--text-secondary)}.zoom-range{flex:1;accent-color:var(--primary-color)}.crop-actions{display:flex;justify-content:flex-end;gap:1rem}.crop-button{padding:.6rem 1.25rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;text-transform:uppercase;transition:all .2s}.crop-button.primary{background:var(--primary-color);color:#000;border:1px solid var(--primary-color)}.crop-button.primary:hover:not(:disabled){background:var(--primary-dark)}.crop-button.secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.crop-button.secondary:hover{border-color:var(--text-primary);color:var(--text-primary)}.crop-button:disabled{opacity:.5;cursor:not-allowed}:root{--bg-color: #050505;--surface-color: #0f1115;--surface-hover: #1a1d23;--border-color: #2a2f3a;--primary-color: #00f3ff;--primary-glow: rgba(0, 243, 255, .3);--primary-dark: #00a8b0;--secondary-color: #bc13fe;--secondary-glow: rgba(188, 19, 254, .3);--text-primary: #e0e6ed;--text-secondary: #94a3b8;--text-muted: #64748b;--success-color: #00ff9d;--error-color: #ff0055;--warning-color: #ffbd00;--header-height: 64px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .6);--glow-primary: 0 0 10px var(--primary-glow);--glow-text: 0 0 5px rgba(255, 255, 255, .5)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6;color:var(--text-primary);background-color:var(--bg-color);background-image:radial-gradient(circle at 15% 50%,rgba(188,19,254,.05),transparent 25%),radial-gradient(circle at 85% 30%,rgba(0,243,255,.05),transparent 25%);background-attachment:fixed;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app{display:flex;flex-direction:column;height:100vh;max-width:1400px;margin:0 auto;background-color:var(--bg-color);box-shadow:0 0 50px #00000080;border-left:1px solid var(--border-color);border-right:1px solid var(--border-color)}.app-header{height:var(--header-height);padding:0 1.5rem;background-color:#0f1115cc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100}.app-header h1{font-size:1.25rem;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--primary-color);text-shadow:0 0 10px var(--primary-glow);display:flex;align-items:center;gap:.5rem}.app-header h1:before{content:"";display:block;width:8px;height:8px;background-color:var(--primary-color);border-radius:50%;box-shadow:0 0 10px var(--primary-color)}.new-conversation-button{padding:.5rem 1rem;border:1px solid var(--primary-color);border-radius:var(--radius-sm);background-color:#00f3ff1a;color:var(--primary-color);font-size:.85rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:all .2s ease}.new-conversation-button:hover:not(:disabled){background-color:var(--primary-color);color:var(--bg-color);box-shadow:0 0 15px var(--primary-glow)}.new-conversation-button:disabled{opacity:.5;cursor:not-allowed;border-color:var(--text-muted);color:var(--text-muted);background-color:transparent}.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative}.error-display{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background-color:#ff00551a;color:var(--error-color);border-bottom:1px solid rgba(255,0,85,.3);border-left:4px solid var(--error-color)}.error-message{flex:1;font-size:.9rem;font-family:Courier New,monospace}.error-dismiss{background:none;border:none;font-size:1.25rem;cursor:pointer;color:var(--error-color);padding:0 .5rem;opacity:.8;transition:opacity .2s}.error-dismiss:hover{opacity:1}button{font-family:inherit}input,textarea,select{font-family:inherit;background-color:var(--surface-color);color:var(--text-primary);border:1px solid var(--border-color)}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 1px var(--primary-glow)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes pulse{0%{box-shadow:0 0 #00f3ff66}70%{box-shadow:0 0 0 10px #00f3ff00}to{box-shadow:0 0 #00f3ff00}}@media(max-width:768px){.app{border:none}.app-header{padding:0 1rem}}.gallery-page{min-height:100vh;background-color:var(--bg-color)}.gallery-header{padding:1.5rem 2rem;background-color:#0f111599;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;gap:1rem;position:sticky;top:0;z-index:90;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.gallery-header h1{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:.75rem}.gallery-header h1:after{content:"beta";font-size:.75rem;padding:.25rem .5rem;background-color:#00f3ff1a;color:var(--primary-color);border:1px solid var(--primary-color);border-radius:var(--radius-sm);letter-spacing:1px}.gallery-header-actions{display:flex;align-items:center;gap:1rem}.gallery-search{padding:.6rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);font-size:.9rem;min-width:300px;transition:all .3s ease;background-color:#0000004d;color:var(--text-primary);font-family:Courier New,monospace}.gallery-search:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 10px #00f3ff1a;background-color:#00000080}.gallery-search::placeholder{color:var(--text-muted)}.upload-button{padding:.6rem 1.25rem;border:1px solid var(--secondary-color);border-radius:var(--radius-sm);background:#bc13fe1a;color:var(--secondary-color);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:.5rem}.upload-button:hover:not(:disabled){background:var(--secondary-color);color:#fff;box-shadow:0 0 15px var(--secondary-glow)}.upload-button:disabled{opacity:.5;cursor:not-allowed;border-color:var(--text-muted);color:var(--text-muted);background:transparent}.auth-button{padding:.6rem 1.25rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#0000004d;color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.auth-button:hover{background:var(--surface-hover);color:var(--text-primary);border-color:var(--text-primary);box-shadow:0 0 10px #ffffff1a}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#0000004d;color:var(--text-primary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:none}.user-menu-trigger:hover{background:var(--surface-hover);border-color:var(--primary-color);box-shadow:0 0 10px #00f3ff1a}.user-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#000}.user-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-arrow{font-size:.6rem;opacity:.7;transition:transform .2s ease}.user-menu-trigger[aria-expanded=true] .user-menu-arrow{transform:rotate(180deg)}.user-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:240px;background:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 8px 32px #000c;z-index:1000;animation:slideDown .2s ease-out;overflow:hidden}.user-menu-dropdown:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color))}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{padding:1rem;background:#0003}.user-menu-email{font-size:.85rem;color:var(--text-secondary);margin-bottom:.25rem;word-break:break-all}.user-menu-username{font-size:.9rem;color:var(--primary-color);font-weight:600;font-family:Courier New,monospace}.user-menu-divider{height:1px;background:var(--border-color);margin:.5rem 0}.user-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-align:left}.user-menu-item:hover{background:var(--surface-hover);color:var(--text-primary)}.user-menu-icon{font-size:1.1rem;opacity:.8}.user-menu-item-danger{color:var(--error-color)}.user-menu-item-danger:hover{background:#ff00551a;color:var(--error-color)}.gallery-loading,.gallery-error{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.gallery-loading{font-size:1.1rem;color:var(--primary-color);text-transform:uppercase;letter-spacing:2px;animation:pulse 2s infinite}.gallery-error{color:var(--error-color);border:1px solid var(--error-color);margin:2rem;background:#ff00550d;border-radius:var(--radius-md)}.gallery-error button{margin-top:1rem;padding:.5rem 1.5rem;border:1px solid var(--error-color);border-radius:var(--radius-sm);background-color:transparent;color:var(--error-color);cursor:pointer;font-size:.9rem;text-transform:uppercase;transition:all .3s ease}.gallery-error button:hover{background-color:var(--error-color);color:#fff;box-shadow:0 0 10px #f056}.gallery-empty{text-align:center;padding:4rem 2rem;color:var(--text-muted);font-size:1.1rem;border:1px dashed var(--border-color);margin:2rem;border-radius:var(--radius-md);background:#0003}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;padding:2rem}.character-card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.5rem;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden;display:flex;flex-direction:column;height:100%}.character-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));transform:scaleX(0);transition:transform .3s ease;transform-origin:left}.character-card:hover{transform:translateY(-4px);border-color:var(--primary-color);box-shadow:0 4px 20px #00000080,0 0 0 1px #00f3ff33;background-color:var(--surface-hover)}.character-card:hover:before{transform:scaleX(1)}.card-image{display:flex;justify-content:center;margin-bottom:1.25rem;position:relative}.card-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#1a1d23,#0f1115);border:2px solid var(--border-color);display:flex;align-items:center;justify-content:center;color:var(--primary-color);font-size:2rem;font-weight:600;box-shadow:0 0 15px #00000080;transition:all .3s ease;position:relative;z-index:1}.character-card:hover .card-avatar{border-color:var(--primary-color);box-shadow:0 0 15px var(--primary-glow);color:#fff;text-shadow:0 0 5px var(--primary-color)}.card-content{text-align:center;flex:1;display:flex;flex-direction:column;min-height:0}.card-name{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;letter-spacing:.5px;flex-shrink:0}.character-card:hover .card-name{color:var(--primary-color)}.card-scrollable-content{flex:1;overflow-y:auto;overflow-x:hidden;min-height:0;max-height:200px;padding-right:.5rem;margin-right:-.5rem}.card-scrollable-content::-webkit-scrollbar{width:4px}.card-scrollable-content::-webkit-scrollbar-track{background:transparent}.card-scrollable-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px;opacity:0;transition:opacity .3s ease}.card-scrollable-content:hover::-webkit-scrollbar-thumb{opacity:1}.card-scrollable-content::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.card-description{font-size:.85rem;color:var(--text-secondary);margin-bottom:1rem;line-height:1.5;text-align:left;word-wrap:break-word;overflow-wrap:break-word}.card-personality{font-size:.75rem;color:var(--text-muted);font-style:italic;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.05);text-align:left;word-wrap:break-word;overflow-wrap:break-word}.search-highlight{background-color:#ffbd0033;color:var(--warning-color);padding:0 2px;border-radius:2px}.card-history-badge{margin-top:1rem;padding:.5rem;background:#00f3ff0d;border:1px solid rgba(0,243,255,.1);border-radius:var(--radius-sm);display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.5rem;font-size:.75rem}.badge-count{color:var(--primary-color);font-weight:600}.badge-time{color:var(--text-muted)}.card-actions{position:absolute;top:.75rem;right:.75rem;z-index:10}.card-actions-button{background:#00000080;border:1px solid transparent;border-radius:var(--radius-sm);font-size:1.5rem;cursor:pointer;color:var(--text-muted);padding:.5rem .75rem;min-width:40px;min-height:40px;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center}.card-actions-button:hover{background:var(--surface-hover);color:var(--text-primary);border-color:var(--border-color)}.card-menu{position:absolute;top:calc(100% + .5rem);right:0;background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);min-width:140px;z-index:20;overflow:hidden;animation:fadeIn .2s ease-out}.card-menu button{display:block;width:100%;padding:.75rem 1rem;text-align:left;background:none;border:none;border-radius:0;cursor:pointer;font-size:.85rem;color:var(--text-secondary);transition:background-color .2s ease;text-transform:uppercase;letter-spacing:.5px}.card-menu button:hover{background-color:var(--surface-hover);color:var(--primary-color)}.card-menu button:not(:last-child){border-bottom:1px solid var(--border-color)}.modal-overlay{position:fixed;inset:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-in-out;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.modal-content{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 0 40px #000c;max-width:900px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s cubic-bezier(.4,0,.2,1);position:relative}.modal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--primary-color),transparent)}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--border-color);background:#0003}.modal-header h2{font-size:1.25rem;font-weight:600;color:var(--primary-color);margin:0;text-transform:uppercase;letter-spacing:1px}.modal-close{background:none;border:1px solid transparent;font-size:1.5rem;cursor:pointer;color:var(--text-muted);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all .2s ease}.modal-close:hover{background-color:#ffffff0d;color:var(--text-primary);border-color:var(--border-color)}.modal-body{padding:1.5rem}.modal-error{padding:.75rem 1rem;background-color:#ff00551a;color:var(--error-color);border-radius:var(--radius-sm);margin-bottom:1rem;font-size:.9rem;border:1px solid rgba(255,0,85,.3);font-family:Courier New,monospace}.upload-instructions{margin-bottom:1.5rem}.upload-instructions p{margin-bottom:.5rem;color:var(--text-secondary);line-height:1.5}.upload-instructions .upload-hint{font-size:.85rem;color:var(--text-muted);font-style:italic}.file-input{display:block;width:100%;padding:2rem;border:2px dashed var(--border-color);border-radius:var(--radius-md);background-color:#0003;cursor:pointer;transition:all .3s ease;font-size:.9rem;text-align:center;color:var(--text-secondary)}.file-input:hover:not(:disabled){border-color:var(--primary-color);background-color:#00f3ff0d;color:var(--primary-color)}.file-input:disabled{opacity:.5;cursor:not-allowed}.upload-progress{margin-top:1rem;padding:.75rem;background:#00f3ff1a;color:var(--primary-color);border-radius:var(--radius-sm);text-align:center;font-weight:500;border:1px solid rgba(0,243,255,.2);text-transform:uppercase;letter-spacing:1px;font-size:.85rem}.modal-footer{padding:1rem 1.5rem;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:.75rem;background:#0003}.modal-button{padding:.6rem 1.25rem;border:1px solid transparent;border-radius:var(--radius-sm);font-size:.9rem;cursor:pointer;transition:all .3s ease;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.modal-button-primary{background-color:var(--primary-color);color:#000;border-color:var(--primary-color)}.modal-button-primary:hover:not(:disabled){background-color:var(--primary-dark);border-color:var(--primary-dark);box-shadow:0 0 15px var(--primary-glow)}.modal-button-secondary{background-color:transparent;border-color:var(--border-color);color:var(--text-secondary)}.modal-button-secondary:hover:not(:disabled){background-color:#ffffff0d;color:var(--text-primary);border-color:var(--text-muted)}.modal-button-destructive{background-color:#ff00551a;color:var(--error-color);border-color:#ff00554d}.modal-button-destructive:hover:not(:disabled){background-color:var(--error-color);color:#fff;box-shadow:0 0 15px #f056}.auth-prompt{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);background:#0f1115f2;border:1px solid var(--primary-color);border-radius:var(--radius-md);padding:1rem 1.5rem;display:flex;align-items:center;gap:.75rem;box-shadow:0 0 30px #00f3ff4d;z-index:1000;animation:slideUpFade .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes slideUpFade{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.auth-prompt-icon{font-size:1.25rem}.auth-prompt-text{color:var(--text-primary);font-size:.9rem;font-weight:500}.modal-button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:1024px){.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.25rem}}@media(max-width:768px){.gallery-header{flex-direction:column;align-items:flex-start;padding:1rem;position:static;height:auto}.gallery-header-actions{width:100%;flex-direction:column;margin-top:1rem}.gallery-search{width:100%;min-width:unset}.upload-button{width:100%;justify-content:center}.gallery-grid{grid-template-columns:1fr;padding:1rem}}.chat-page{display:flex;flex-direction:column;height:100vh;background-color:var(--bg-color)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;height:var(--header-height);background:#0f1115cc;border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);gap:1rem;flex-shrink:0;z-index:100}.chat-title{font-size:1.1rem;font-weight:600;margin:0;flex:1;text-align:center;color:var(--text-primary);text-transform:uppercase;letter-spacing:1px;display:flex;align-items:center;justify-content:center;gap:.5rem}.chat-title:before{content:"•";color:var(--success-color);font-size:1.5rem;line-height:0;text-shadow:0 0 5px var(--success-color)}.back-button{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .3s ease;white-space:nowrap;display:flex;align-items:center;gap:.5rem;text-transform:uppercase;letter-spacing:.5px}.back-button:hover{background-color:#ffffff0d;color:var(--primary-color);border-color:var(--primary-color);box-shadow:0 0 10px #00f3ff1a}.new-conversation-button{padding:.5rem 1rem;border:1px solid var(--primary-color);border-radius:var(--radius-sm);background-color:#00f3ff1a;color:var(--primary-color);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}.new-conversation-button:hover:not(:disabled){background-color:var(--primary-color);color:#000;box-shadow:0 0 15px var(--primary-glow)}.new-conversation-button:disabled{opacity:.5;cursor:not-allowed;border-color:var(--text-muted);color:var(--text-muted);background:transparent}.chat-header .auth-button{padding:.5rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#0000004d;color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;white-space:nowrap;text-transform:uppercase;letter-spacing:.5px}.chat-header .auth-button:hover{background:var(--surface-hover);color:var(--text-primary);border-color:var(--text-primary);box-shadow:0 0 10px #ffffff1a}.chat-header .user-menu{position:relative}.chat-header .user-menu-trigger{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#0000004d;color:var(--text-primary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:none;white-space:nowrap}.chat-header .user-menu-trigger:hover{background:var(--surface-hover);border-color:var(--primary-color);box-shadow:0 0 10px #00f3ff1a}.chat-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg-color);position:relative}.chat-content:before{content:"";position:absolute;inset:0;background:linear-gradient(#050505e6,#050505e6),repeating-linear-gradient(0deg,transparent,transparent 1px,rgba(0,243,255,.03) 1px,rgba(0,243,255,.03) 2px);background-size:100% 100%,100% 4px;pointer-events:none;z-index:0}.chat-loading,.chat-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:2rem;text-align:center;position:relative;z-index:1}.chat-loading{color:var(--primary-color);font-size:1.1rem;text-transform:uppercase;letter-spacing:2px;animation:pulse 2s infinite}.chat-error{color:var(--error-color)}.chat-error p{margin-bottom:1rem;font-size:1rem;line-height:1.5;font-family:Courier New,monospace}.chat-error button{padding:.6rem 1.5rem;border:1px solid var(--error-color);border-radius:var(--radius-sm);background-color:#ff00551a;color:var(--error-color);cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease;text-transform:uppercase}.chat-error button:hover{background-color:var(--error-color);color:#fff;box-shadow:0 0 15px #f056}.auth-required-overlay{display:flex;align-items:center;justify-content:center;min-height:400px;padding:2rem;position:relative;z-index:1}.auth-required-content{text-align:center;max-width:500px;padding:3rem 2rem;background:#0f1115e6;border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 0 30px #00000080;position:relative}.auth-required-content:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color))}.auth-required-content h2{font-size:1.5rem;font-weight:700;color:var(--primary-color);margin:0 0 1rem;text-transform:uppercase;letter-spacing:1px}.auth-required-content p{font-size:1rem;color:var(--text-secondary);margin:0 0 2rem;line-height:1.6}.auth-required-button{padding:.875rem 2rem;border:1px solid var(--primary-color);border-radius:var(--radius-sm);background:var(--primary-color);color:#000;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.auth-required-button:hover{background:var(--primary-dark);box-shadow:0 0 20px var(--primary-glow);transform:translateY(-2px)}.character-greeting{padding:1.5rem;background:#00f3ff0d;border-left:2px solid var(--primary-color);margin:1.5rem auto;border-radius:0 var(--radius-md) var(--radius-md) 0;box-shadow:0 0 20px #0000004d;animation:slideInFromTop .4s ease-out;max-width:900px;width:95%;position:relative;z-index:1}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.greeting-label{font-size:.75rem;font-weight:600;color:var(--primary-color);text-transform:uppercase;margin-bottom:.75rem;letter-spacing:1px;display:flex;align-items:center;gap:.5rem}.greeting-label:before{content:">";font-weight:700}.greeting-content{font-size:1rem;color:var(--text-primary);line-height:1.6}.chat-display{flex:1;overflow-y:auto;padding:1rem;scroll-behavior:smooth;position:relative;z-index:1}.messages{display:flex;flex-direction:column;gap:1.5rem;max-width:900px;margin:0 auto;width:100%;padding-bottom:2rem}.message{padding:1.25rem 1.5rem;border-radius:var(--radius-md);max-width:85%;animation:messageSlideIn .3s ease-out;position:relative}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message-user{align-self:flex-end;background:#bc13fe1a;border:1px solid rgba(188,19,254,.3);color:var(--text-primary);border-radius:var(--radius-lg) var(--radius-lg) 0 var(--radius-lg)}.message-user .message-role{color:var(--secondary-color);text-align:right}.message-assistant{align-self:flex-start;background:#0f1115cc;border:1px solid var(--border-color);color:var(--text-primary);border-radius:var(--radius-lg) var(--radius-lg) var(--radius-lg) 0;box-shadow:0 4px 12px #0003}.message-assistant .message-role{color:var(--primary-color)}.message-role{font-size:.7rem;opacity:.9;margin-bottom:.5rem;text-transform:uppercase;font-weight:600;letter-spacing:1px;display:flex;align-items:center;gap:.5rem}.message-content{word-wrap:break-word;line-height:1.7;font-size:.95rem}.message-timestamp{font-size:.7rem;opacity:.5;margin-top:.75rem;text-align:right;font-family:Courier New,monospace}.typing-indicator{opacity:.8}.typing-dots{display:flex;align-items:center;gap:.4rem;padding:.5rem 0}.typing-dot{width:8px;height:8px;border-radius:50%;background-color:var(--primary-color);animation:typingBounce 1.4s infinite ease-in-out;box-shadow:0 0 4px var(--primary-glow)}.typing-dot:nth-child(1){animation-delay:0s}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.empty-state{text-align:center;color:var(--text-muted);padding:4rem 2rem;font-size:1rem;position:relative;z-index:1}.empty-state:before{content:"[ SYSTEM READY ]";display:block;font-family:Courier New,monospace;color:var(--primary-color);margin-bottom:1rem;letter-spacing:2px;opacity:.7}.chat-input-form{display:flex;gap:1rem;padding:1.5rem;border-top:1px solid var(--border-color);background-color:#0f1115f2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0;position:relative;z-index:100;max-width:1000px;margin:0 auto;width:100%}.chat-input{flex:1;padding:1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;transition:all .3s ease;background-color:#0000004d;resize:none;font-family:inherit;line-height:1.5;color:var(--text-primary)}.chat-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 15px #00f3ff1a;background-color:#00000080}.chat-input::placeholder{color:var(--text-muted)}.chat-button{padding:0 1.5rem;border:none;border-radius:var(--radius-md);font-size:.9rem;cursor:pointer;transition:all .3s ease;font-weight:600;white-space:nowrap;text-transform:uppercase;letter-spacing:1px;display:flex;align-items:center;justify-content:center}.chat-button-submit{background:var(--primary-color);color:#000;box-shadow:0 0 10px var(--primary-glow)}.chat-button-submit:hover:not(:disabled){background-color:var(--primary-dark);box-shadow:0 0 20px var(--primary-glow);transform:translateY(-1px)}.chat-button-submit:disabled{opacity:.5;cursor:not-allowed;background-color:var(--border-color);color:var(--text-muted);box-shadow:none}.chat-button-cancel{background-color:#ff00551a;color:var(--error-color);border:1px solid var(--error-color)}.chat-button-cancel:hover{background-color:var(--error-color);color:#fff;box-shadow:0 0 15px #f056}@media(max-width:768px){.chat-header{padding:0 1rem}.chat-title{font-size:1rem}.back-button span{display:none}.back-button{padding:.5rem}.messages{gap:1rem}.message{max-width:90%;padding:1rem}.chat-input-form{padding:1rem;flex-direction:column;gap:.75rem}.chat-button{padding:.8rem;width:100%}}dm,marquee{display:inline-block;white-space:nowrap;overflow:hidden;box-sizing:border-box;animation:marquee 10s linear infinite;padding-left:100%;color:var(--text-secondary);font-family:Courier New,monospace}@keyframes marquee{0%{transform:translate(0)}to{transform:translate(-100%)}}zbj{display:block;height:150px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:.5rem;background:#0003;margin-top:.5rem}nxxf{display:block;background:#00f3ff1a;border-left:2px solid var(--primary-color);padding:.5rem .75rem;margin-bottom:.5rem;color:var(--text-primary);font-size:.9rem}gz{display:inline-block;background:#ffffff1a;padding:.2rem .5rem;border-radius:var(--radius-sm);font-size:.8rem;color:var(--text-secondary);margin-right:.5rem}details{background:#ffffff08;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.5rem;margin:.5rem 0}summary{cursor:pointer;padding:.5rem;font-weight:600;color:var(--primary-color);outline:none;-webkit-user-select:none;user-select:none}summary:hover{background:#ffffff0d;border-radius:var(--radius-sm)}.chat-controls{display:flex;align-items:center;gap:1rem;flex-shrink:0}.toggle-container{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.85rem;cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.toggle-switch{position:relative;width:36px;height:20px;background-color:#ffffff26;border-radius:20px;transition:all .3s ease;border:1px solid var(--border-color)}.toggle-switch.active{background-color:#00f3ff33;border-color:var(--primary-color)}.toggle-thumb{position:absolute;top:2px;left:2px;width:14px;height:14px;background-color:var(--text-muted);border-radius:50%;transition:all .3s ease}.toggle-switch.active .toggle-thumb{left:18px;background-color:var(--primary-color);box-shadow:0 0 8px var(--primary-glow)}.toggle-input{display:none}.message-content.streaming>div:after{content:"▋";display:inline-block;vertical-align:baseline;animation:cursor-blink 1s step-end infinite;color:var(--primary-color);margin-left:2px;font-size:.9em}@keyframes cursor-blink{0%,to{opacity:1}50%{opacity:0}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0a0c10,#1a1d23);padding:1rem;position:relative;overflow:hidden}.auth-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(0,243,255,.03) 0%,transparent 70%);animation:pulse 8s ease-in-out infinite}.auth-container{width:100%;max-width:420px;position:relative;z-index:1}.auth-card{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:2.5rem;box-shadow:0 0 40px #000c;position:relative;overflow:hidden}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color))}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem;letter-spacing:.5px;text-transform:uppercase}.auth-header p{color:var(--text-muted);font-size:.9rem;margin:0}.auth-form{display:flex;flex-direction:column;gap:1.25rem}.auth-input-group{display:flex;flex-direction:column;gap:.5rem}.auth-label{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.auth-input{padding:.875rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:#0000004d;color:var(--text-primary);font-size:.95rem;font-family:Courier New,monospace;transition:all .3s ease}.auth-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 10px #00f3ff33;background-color:#00000080}.auth-input::placeholder{color:var(--text-muted)}.auth-error{padding:.875rem 1rem;background-color:#ff00551a;color:var(--error-color);border:1px solid rgba(255,0,85,.3);border-radius:var(--radius-sm);font-size:.85rem;text-align:center;animation:shake .3s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.auth-submit{padding:.875rem 1.5rem;border:1px solid var(--primary-color);border-radius:var(--radius-sm);background:var(--primary-color);color:#000;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px;margin-top:.5rem}.auth-submit:hover:not(:disabled){background:var(--primary-dark);box-shadow:0 0 20px var(--primary-glow);transform:translateY(-2px)}.auth-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.auth-divider span{color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:1px}.auth-toggle{text-align:center;margin-top:1.5rem}.auth-toggle-button{background:none;border:none;color:var(--primary-color);font-size:.9rem;cursor:pointer;transition:all .2s ease;text-decoration:none;padding:0}.auth-toggle-button:hover{color:var(--primary-dark);text-decoration:underline}@media(max-width:480px){.auth-card{padding:2rem 1.5rem}.auth-header h2{font-size:1.5rem}}.username-setup-overlay{position:fixed;inset:0;background-color:#000000e6;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s ease-in-out;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:1rem}.username-setup-modal{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 0 40px #000c;max-width:500px;width:100%;max-height:90vh;display:flex;flex-direction:column;position:relative;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.username-setup-modal:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color))}.username-setup-header{text-align:center;padding:2.5rem 2rem 1.5rem;background:#0003;border-bottom:1px solid var(--border-color);flex-shrink:0}.username-setup-header h2{font-size:1.5rem;font-weight:700;color:var(--primary-color);margin:0 0 .75rem;text-transform:uppercase;letter-spacing:1px}.username-setup-header p{color:var(--text-secondary);font-size:.9rem;margin:0;line-height:1.5}.username-setup-form{padding:2rem;display:flex;flex-direction:column;gap:1.5rem;overflow-y:auto}.username-input-group{display:flex;flex-direction:column;gap:.5rem}.username-label{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.username-input{padding:.875rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:#0000004d;color:var(--text-primary);font-size:1rem;font-family:Courier New,monospace;transition:all .3s ease}.username-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 10px #00f3ff33;background-color:#00000080}.username-hint{font-size:.8rem;color:var(--text-muted);font-style:italic}.username-hint code{background:#00f3ff1a;color:var(--primary-color);padding:.125rem .375rem;border-radius:3px;font-family:Courier New,monospace;font-size:.85em}.username-error{padding:.75rem 1rem;background-color:#ff00551a;color:var(--error-color);border:1px solid rgba(255,0,85,.3);border-radius:var(--radius-sm);font-size:.85rem;animation:shake .3s ease-in-out}.username-actions{display:flex;gap:1rem;margin-top:.5rem}.username-submit{flex:1;padding:.875rem 1.5rem;border:1px solid var(--primary-color);border-radius:var(--radius-sm);background:var(--primary-color);color:#000;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px}.username-submit:hover:not(:disabled){background:var(--primary-dark);box-shadow:0 0 20px var(--primary-glow);transform:translateY(-2px)}.username-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.username-skip{padding:.875rem 1.5rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.username-skip:hover:not(:disabled){background:#ffffff0d;color:var(--text-primary);border-color:var(--text-muted)}.username-skip:disabled{opacity:.5;cursor:not-allowed}.page-enter{opacity:0;transform:translateY(20px)}.page-enter-active{opacity:1;transform:translateY(0);transition:opacity .4s ease-out,transform .4s ease-out}.page-exit{opacity:1;transform:translateY(0)}.page-exit-active{opacity:0;transform:translateY(-20px);transition:opacity .3s ease-in,transform .3s ease-in}.character-card{transition:all .3s cubic-bezier(.4,0,.2,1)}.character-card:hover{animation:cardFloat .3s ease-out forwards}@keyframes cardFloat{0%{transform:translateY(0);box-shadow:0 2px 8px #00000014}to{transform:translateY(-8px);box-shadow:0 8px 24px #00000026}}.character-card:hover .card-avatar{animation:avatarPulse .6s ease-in-out}@keyframes avatarPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.card-content{animation:fadeInUp .4s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card-history-badge{animation:slideInFromBottom .4s ease-out .1s backwards}@keyframes slideInFromBottom{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal-overlay{animation:modalFadeIn .3s ease-out}.modal-overlay.closing{animation:modalFadeOut .2s ease-in forwards}@keyframes modalFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}to{opacity:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}}@keyframes modalFadeOut{0%{opacity:1;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}to{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}}.modal-content{animation:modalSlideUp .4s cubic-bezier(.4,0,.2,1)}.modal-overlay.closing .modal-content{animation:modalSlideDown .3s cubic-bezier(.4,0,.6,1) forwards}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(60px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes modalSlideDown{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(40px) scale(.95)}}.upload-button,.modal-button-primary,.chat-button-submit{transition:all .3s cubic-bezier(.4,0,.2,1)}.upload-button:hover:not(:disabled),.modal-button-primary:hover:not(:disabled),.chat-button-submit:hover:not(:disabled){animation:buttonLift .3s ease-out forwards}@keyframes buttonLift{0%{transform:translateY(0)}to{transform:translateY(-3px)}}.upload-button:active:not(:disabled),.modal-button:active:not(:disabled),.chat-button:active:not(:disabled){animation:buttonPress .1s ease-out}@keyframes buttonPress{0%{transform:translateY(-3px)}to{transform:translateY(-1px)}}.gallery-search{transition:all .3s ease}.gallery-search:focus{animation:inputFocusGlow .4s ease-out}@keyframes inputFocusGlow{0%{box-shadow:0 0 #667eea66}50%{box-shadow:0 0 0 6px #667eea1a}to{box-shadow:0 0 0 3px #667eea1a}}.gallery-grid .character-card{animation:cardStaggerIn .5s ease-out backwards}.gallery-grid .character-card:nth-child(1){animation-delay:.05s}.gallery-grid .character-card:nth-child(2){animation-delay:.1s}.gallery-grid .character-card:nth-child(3){animation-delay:.15s}.gallery-grid .character-card:nth-child(4){animation-delay:.2s}.gallery-grid .character-card:nth-child(5){animation-delay:.25s}.gallery-grid .character-card:nth-child(6){animation-delay:.3s}.gallery-grid .character-card:nth-child(7){animation-delay:.35s}.gallery-grid .character-card:nth-child(8){animation-delay:.4s}.gallery-grid .character-card:nth-child(9){animation-delay:.45s}.gallery-grid .character-card:nth-child(n+10){animation-delay:.5s}@keyframes cardStaggerIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.message{animation:messageSlideIn .4s cubic-bezier(.4,0,.2,1)}.message-user{animation:messageSlideInRight .4s cubic-bezier(.4,0,.2,1)}.message-assistant{animation:messageSlideInLeft .4s cubic-bezier(.4,0,.2,1)}@keyframes messageSlideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes messageSlideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}.character-greeting{animation:greetingExpand .5s cubic-bezier(.4,0,.2,1)}@keyframes greetingExpand{0%{opacity:0;transform:scaleY(.8);transform-origin:top}to{opacity:1;transform:scaleY(1)}}.error-display{animation:errorShake .5s ease-out}@keyframes errorShake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.gallery-loading:after,.chat-loading:after{content:"";display:inline-block;width:20px;height:20px;margin-left:10px;border:3px solid rgba(102,126,234,.3);border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.back-button{transition:all .3s cubic-bezier(.4,0,.2,1)}.back-button:hover{animation:backButtonSlide .3s ease-out forwards}@keyframes backButtonSlide{0%{transform:translate(0)}to{transform:translate(-6px)}}.card-menu{animation:menuDropdown .3s cubic-bezier(.4,0,.2,1)}@keyframes menuDropdown{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.search-highlight{animation:highlightPulse 1s ease-in-out}@keyframes highlightPulse{0%,to{background-color:#fff3cd}50%{background-color:#ffe69c}}.upload-progress{animation:progressPulse 1.5s ease-in-out infinite}@keyframes progressPulse{0%,to{opacity:1}50%{opacity:.7}}html{scroll-behavior:smooth}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}*:focus-visible{outline:3px solid #667eea;outline-offset:2px;border-radius:4px}button,input,select,textarea,a{transition:all .2s ease}.character-card:before{transition:transform .3s cubic-bezier(.4,0,.2,1)}.character-card:hover:before{animation:borderGradientSlide .3s ease-out forwards}@keyframes borderGradientSlide{0%{transform:scaleX(0);transform-origin:left}to{transform:scaleX(1);transform-origin:left}}.gallery-header{animation:headerFadeIn .5s ease-out}@keyframes headerFadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.chat-header{animation:chatHeaderSlideIn .4s ease-out}@keyframes chatHeaderSlideIn{0%{opacity:0;transform:translateY(-100%)}to{opacity:1;transform:translateY(0)}}.gallery-empty,.empty-state{animation:emptyStateFadeIn .6s ease-out}@keyframes emptyStateFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.confirm-dialog .modal-content{animation:confirmBounce .5s cubic-bezier(.68,-.55,.265,1.55)}@keyframes confirmBounce{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}.typing-indicator{display:inline-flex;gap:4px}.typing-indicator span{width:8px;height:8px;border-radius:50%;background-color:#667eea;animation:typingDot 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typingDot{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.generate-character-page{min-height:100vh;background-color:var(--bg-color);padding-bottom:2rem}.generate-header{padding:1.5rem 2rem;background-color:#0f111599;border-bottom:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:90;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.generate-header h1{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:.75rem}.generate-header h1:before{content:"✨";font-size:1.25rem}.back-button{padding:.6rem 1.25rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:#0000004d;color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px}.back-button:hover:not(:disabled){border-color:var(--primary-color);color:var(--primary-color);background:#00f3ff1a}.back-button:disabled{opacity:.5;cursor:not-allowed}.generate-error{margin:1.5rem 2rem;padding:1rem 1.5rem;background-color:#ff00551a;border:1px solid rgba(255,0,85,.3);border-left:4px solid var(--error-color);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:space-between;animation:slideUp .3s ease}.generate-error p{color:var(--error-color);font-family:Courier New,monospace;font-size:.9rem;margin:0}.generate-error button{padding:.4rem 1rem;border:1px solid var(--error-color);border-radius:var(--radius-sm);background:transparent;color:var(--error-color);font-size:.85rem;cursor:pointer;transition:all .2s ease}.generate-error button:hover{background:var(--error-color);color:#fff}.character-generator{max-width:900px;margin:2rem auto;padding:0 2rem;animation:fadeIn .5s ease}.generator-instructions{margin-bottom:2rem;padding:1.5rem;background:linear-gradient(135deg,#00f3ff0d,#bc13fe0d);border:1px solid var(--border-color);border-radius:var(--radius-md)}.generator-instructions h2{color:var(--primary-color);font-size:1.25rem;margin:0 0 .75rem;text-shadow:0 0 10px var(--primary-glow)}.generator-instructions p{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin:0}.generator-form{background-color:var(--surface-color);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:2rem;box-shadow:var(--shadow-md)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;color:var(--text-primary);font-weight:600;font-size:.95rem;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.form-hint{font-size:.85rem;color:var(--text-muted);margin-top:.4rem}.template-selector{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:#0000004d;color:var(--text-primary);font-size:.95rem;cursor:pointer;transition:all .2s ease}.template-selector:hover{border-color:var(--primary-color);background-color:#00000080}.template-selector:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 10px #00f3ff33}.prompt-input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-sm);background-color:#0000004d;color:var(--text-primary);font-size:.95rem;font-family:Courier New,monospace;line-height:1.6;resize:vertical;transition:all .2s ease}.prompt-input:hover{border-color:var(--primary-color);background-color:#00000080}.prompt-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 10px #00f3ff33}.prompt-input::placeholder{color:var(--text-muted);font-style:italic}.word-count{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem;font-size:.85rem;color:var(--text-secondary)}.count-error{color:var(--error-color);font-weight:600}.count-requirement{color:var(--text-muted)}.form-error{padding:.75rem 1rem;background-color:#ff00551a;border:1px solid rgba(255,0,85,.3);border-radius:var(--radius-sm);color:var(--error-color);font-size:.9rem;margin-bottom:1rem}.form-actions{display:flex;justify-content:flex-end;margin-top:2rem}.generate-button{padding:.75rem 2rem;border:1px solid var(--primary-color);border-radius:var(--radius-sm);background:linear-gradient(135deg,#00f3ff33,#00f3ff1a);color:var(--primary-color);font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:1px;position:relative;overflow:hidden}.generate-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:#00f3ff4d;transform:translate(-50%,-50%);transition:width .6s,height .6s}.generate-button:hover:not(:disabled):before{width:300px;height:300px}.generate-button:hover:not(:disabled){background:var(--primary-color);color:var(--bg-color);box-shadow:0 0 20px var(--primary-glow);transform:translateY(-2px)}.generator-examples{margin-top:2rem;padding:1.5rem;background-color:#0003;border:1px solid var(--border-color);border-radius:var(--radius-md)}.generator-examples h3{color:var(--secondary-color);font-size:1rem;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.5px}.generator-examples ul{list-style:none;padding:0;margin:0}.generator-examples li{padding:.75rem 0;color:var(--text-secondary);font-size:.9rem;line-height:1.6;border-bottom:1px solid rgba(42,47,58,.5)}.generator-examples li:last-child{border-bottom:none}.generator-examples strong{color:var(--primary-color);font-weight:600;margin-right:.5rem}.generation-progress{max-width:700px;margin:4rem auto;padding:0 2rem;animation:fadeIn .5s ease}.progress-container{background:linear-gradient(135deg,#00f3ff0d,#bc13fe0d);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;box-shadow:var(--shadow-lg)}.progress-spinner{margin:0 auto 2rem;width:80px;height:80px}.spinner{width:80px;height:80px;border:4px solid rgba(0,243,255,.1);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;box-shadow:0 0 20px var(--primary-glow)}@keyframes spin{to{transform:rotate(360deg)}}.progress-title{color:var(--primary-color);font-size:1.5rem;font-weight:600;margin:0 0 1rem;text-shadow:0 0 10px var(--primary-glow)}.progress-description{color:var(--text-secondary);font-size:.95rem;line-height:1.6;margin:0 0 2rem;max-width:500px;margin-left:auto;margin-right:auto}.progress-bar-container{margin:2rem 0}.progress-bar{width:100%;height:8px;background-color:#00000080;border-radius:4px;overflow:hidden;border:1px solid var(--border-color)}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));border-radius:4px;transition:width 1s ease;box-shadow:0 0 10px var(--primary-glow)}.progress-stats{display:flex;justify-content:space-around;margin:1.5rem 0;padding:1rem;background-color:#0000004d;border-radius:var(--radius-sm)}.elapsed-time,.estimated-time{font-family:Courier New,monospace;font-size:.9rem;color:var(--text-secondary)}.elapsed-time{color:var(--primary-color);font-weight:600}.progress-tips{margin-top:2rem;padding:1.5rem;background-color:#0000004d;border-radius:var(--radius-md);border:1px solid var(--border-color);text-align:left}.progress-tips h3{color:var(--secondary-color);font-size:.95rem;margin:0 0 1rem;text-transform:uppercase;letter-spacing:.5px}.progress-tips ul{list-style:none;padding:0;margin:0}.progress-tips li{color:var(--text-secondary);font-size:.85rem;line-height:1.5;position:relative;padding:.5rem 0 .5rem 1.5rem}.progress-tips li:before{content:"→";position:absolute;left:0;color:var(--primary-color);font-weight:700}.generation-complete{max-width:800px;margin:2rem auto;padding:0 2rem;animation:slideUp .5s ease}.completion-message{background:linear-gradient(135deg,#00f3ff0d,#bc13fe0d);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:2rem;margin-bottom:1.5rem;text-align:center}.completion-message h2{color:var(--success-color);font-size:1.75rem;margin:0 0 .5rem;text-shadow:0 0 10px rgba(0,255,157,.3)}.completion-message h2:before{content:"✓ "}.completion-message p{color:var(--text-muted);font-size:.9rem;margin:0 0 1.5rem}.character-preview{background-color:#0000004d;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1.5rem;text-align:left}.character-preview h3{color:var(--primary-color);font-size:1.25rem;margin:0 0 .75rem}.character-description{color:var(--text-secondary);font-size:.9rem;line-height:1.6;margin:0}.completion-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.completion-actions button{padding:.75rem 1.5rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;border:1px solid var(--border-color);background:#0000004d;color:var(--text-secondary)}.edit-button{border-color:var(--secondary-color);background:#bc13fe1a;color:var(--secondary-color)}.edit-button:hover{background:var(--secondary-color);color:#fff;box-shadow:0 0 15px var(--secondary-glow)}.save-button,.chat-button{border-color:var(--primary-color);background:#00f3ff1a;color:var(--primary-color)}.save-button:hover,.chat-button:hover{background:var(--primary-color);color:var(--bg-color);box-shadow:0 0 15px var(--primary-glow)}.discard-button{border-color:var(--error-color);background:#ff00551a;color:var(--error-color)}.discard-button:hover{background:var(--error-color);color:#fff}.generate-button{padding:.6rem 1.25rem;border:1px solid var(--primary-color);border-radius:var(--radius-sm);background:#00f3ff1a;color:var(--primary-color);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:.5rem}.generate-button:hover:not(:disabled){background:var(--primary-color);color:#fff;box-shadow:0 0 15px var(--primary-glow)}.generate-button:disabled{opacity:.5;cursor:not-allowed;border-color:var(--text-muted);color:var(--text-muted);background:transparent}@media(max-width:768px){.generate-header{padding:1rem;flex-direction:column;align-items:flex-start;gap:1rem}.character-generator,.generation-progress,.generation-complete{padding:0 1rem}.generator-form{padding:1.5rem}.completion-actions{flex-direction:column}.completion-actions button{width:100%}}
