:root{--font-display:"Kaisei Opti", serif;--font-body:"M PLUS Rounded 1c", sans-serif;--font-ui:"Inter", sans-serif;--bg-primary:#0a0a14;--text-primary:#e8e4df;--text-secondary:#e8e4dfb3;--text-muted:#e8e4df66;--accent:#ff6b9d;--accent-hover:#ff85b1;--panel-bg:#0f0c14d9;--panel-border:#ffffff14;--panel-glow:#ff6b9d26;--panel-radius:16px;--panel-radius-sm:10px;--panel-blur:12px;--ambient-hue:280;--ambient-saturation:30%;--glow-color:#ff6b9d;--msg-user-bg:#ff6b9d26;--msg-user-border:#ff6b9d40;--msg-assistant-bg:#ffffff0d;--msg-assistant-border:#ffffff14;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:40px;--space-2xl:64px;--z-background:0;--z-particles:10;--z-overlay:20;--z-content:30;--z-panel:40;--z-modal:50;--z-splash:100;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.5s ease}[data-location=home]{--ambient-hue:320;--panel-bg:#140f1ed1;--panel-border:#ffb4dc1a;--panel-glow:#ff96c826;--glow-color:#f9c;--accent:#ff6b9d;--accent-hover:#ff85b1;--msg-user-bg:#ff6b9d26;--msg-user-border:#ff6b9d40}[data-location=cafe]{--ambient-hue:30;--panel-bg:#2d190fd9;--panel-border:#ffa0501f;--panel-glow:#f943;--glow-color:#f94;--accent:#ffb347;--accent-hover:#ffc56e;--msg-user-bg:#ffb34726;--msg-user-border:#ffb34740}[data-location=rooftop]{--ambient-hue:200;--panel-bg:#0f192dcc;--panel-border:#88bbff1a;--panel-glow:#88bbff26;--glow-color:#8bf;--accent:#f86;--accent-hover:#ffa088;--msg-user-bg:#ff886626;--msg-user-border:#ff886640}[data-location=library]{--ambient-hue:35;--panel-bg:#23190fe0;--panel-border:#c8a45c1a;--panel-glow:#ddaa5526;--glow-color:#da5;--accent:#c8a45c;--accent-hover:#d4b474;--msg-user-bg:#c8a45c26;--msg-user-border:#c8a45c40}[data-location=training-grounds]{--ambient-hue:120;--panel-bg:#0f1e0fd1;--panel-border:#66cc661a;--panel-glow:#66cc6626;--glow-color:#6c6;--accent:#7d7;--accent-hover:#90e890;--msg-user-bg:#77dd7726;--msg-user-border:#77dd7740}[data-location=dorm]{--ambient-hue:260;--panel-bg:#140f23de;--panel-border:#aa88ff1a;--panel-glow:#aa88ff26;--glow-color:#a8f;--accent:#b9f;--accent-hover:#caf;--msg-user-bg:#bb99ff26;--msg-user-border:#bb99ff40}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes pulse-glow{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}@keyframes slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes typewriter-cursor{0%,to{opacity:1}50%{opacity:0}}@keyframes bounce-dot{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}@keyframes gentle-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes scale-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden}body{font-family:var(--font-body);color:var(--text-primary);background:var(--bg-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.6}#root{height:100%;position:relative}::selection{background:var(--accent);color:var(--bg-primary)}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--panel-border);border-radius:2px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.scene-background{z-index:var(--z-background);background-color:var(--bg-primary);position:fixed;inset:0}.scene-background__image{object-fit:cover;object-position:center;opacity:0;-webkit-user-select:none;user-select:none;pointer-events:none;width:100%;height:100%;transition:opacity .8s;position:absolute;inset:0}.scene-background__image--loaded{opacity:1}.scene-background__vignette{pointer-events:none;background:radial-gradient(#0000 40%,#00000059 100%);position:absolute;inset:0}.day-night-overlay{z-index:var(--z-overlay);pointer-events:none;transition:background-color 2s,opacity 2s;position:fixed;inset:0}.scene-layout{width:100%;height:100vh;position:fixed;inset:0}.scene-layout__content{z-index:var(--z-content);flex-direction:column;display:flex;position:absolute;inset:0;overflow-y:auto}.splash{z-index:var(--z-splash);cursor:pointer;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.splash__bg{background:radial-gradient(at 50% 40%,#ff6b9d14 0%,#0000 50%),radial-gradient(at 30% 70%,#aa88ff0f 0%,#0000 40%),linear-gradient(#08060f 0%,#0a0a14 50%,#0d0818 100%);position:absolute;inset:0}.splash__content{z-index:1;align-items:center;gap:var(--space-md);flex-direction:column;display:flex;position:relative}.splash__title{font-family:var(--font-display);letter-spacing:.3em;color:#0000;background:linear-gradient(135deg,#ff6b9d 0%,#ffb347 25%,#ff6b9d 50%,#b9f 75%,#ff6b9d 100%) 0 0/200%;-webkit-background-clip:text;background-clip:text;font-size:clamp(3rem,8vw,5rem);font-weight:700;animation:4s linear infinite shimmer}.splash__subtitle{font-family:var(--font-display);color:var(--text-secondary);letter-spacing:.5em;margin-top:calc(-1 * var(--space-sm));font-size:clamp(1.5rem,4vw,2.5rem)}.splash__cta{font-family:var(--font-ui);color:var(--text-secondary);letter-spacing:.15em;text-transform:uppercase;margin-top:var(--space-xl);font-size:.875rem;font-weight:500;animation:2.5s ease-in-out infinite pulse-glow}.panel{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--panel-radius);-webkit-backdrop-filter:blur(var(--panel-blur));box-shadow:0 0 20px var(--panel-glow)}.panel--chat{border-radius:var(--panel-radius) var(--panel-radius) 0 0;border-bottom:none}.panel--card{box-shadow:0 0 20px var(--panel-glow), 0 8px 32px #0006}.panel--modal{box-shadow:0 0 40px var(--panel-glow), 0 16px 48px #0009}.btn{justify-content:center;align-items:center;gap:var(--space-sm);font-family:var(--font-ui);border-radius:var(--panel-radius-sm);cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-base), background-color var(--transition-base);-webkit-user-select:none;user-select:none;white-space:nowrap;border:none;font-weight:500;display:inline-flex}.btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none!important;transform:none!important}.btn--sm{padding:var(--space-xs) var(--space-md);font-size:.8125rem}.btn--md{padding:var(--space-sm) var(--space-lg);font-size:.9375rem}.btn--lg{padding:var(--space-md) var(--space-xl);font-size:1.0625rem}.btn--primary{background:var(--accent);color:var(--bg-primary)}.btn--primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 0 20px var(--panel-glow);transform:scale(1.02)}.btn--primary:active:not(:disabled){transform:scale(.98)}.btn--secondary{color:var(--accent);border:1px solid var(--accent);background:0 0}.btn--secondary:hover:not(:disabled){box-shadow:0 0 12px var(--panel-glow);background:#ff6b9d1a;transform:scale(1.02)}.btn--secondary:active:not(:disabled){transform:scale(.98)}.btn--ghost{color:#fff;text-shadow:0 1px 4px #0009;background:#0000004d;font-weight:700}.btn--ghost:hover:not(:disabled){color:#fff;background:#00000073}.btn--ghost:active:not(:disabled){transform:scale(.98)}.text-input{gap:var(--space-xs);flex-direction:column;display:flex}.text-input__label{font-family:var(--font-ui);color:var(--text-secondary);letter-spacing:.03em;font-size:.8125rem;font-weight:500}.text-input__field{font-family:var(--font-body);color:var(--text-primary);border:1px solid var(--panel-border);border-radius:var(--panel-radius-sm);padding:var(--space-sm) var(--space-md);transition:border-color var(--transition-base), box-shadow var(--transition-base);background:#ffffff0a;outline:none;font-size:.9375rem}.text-input__field::placeholder{color:var(--text-muted)}.text-input__field:focus{border-color:var(--accent);box-shadow:0 0 12px var(--panel-glow)}.text-input__field--textarea{resize:vertical;min-height:80px;line-height:1.5}.text-input--error .text-input__field{border-color:#f46}.text-input__error{font-family:var(--font-ui);color:#f46;font-size:.75rem}.audio-control{bottom:var(--space-lg);right:var(--space-lg);z-index:var(--z-modal);background:var(--panel-bg);border:1px solid var(--panel-border);width:40px;height:40px;color:var(--text-primary);cursor:pointer;-webkit-backdrop-filter:blur(var(--panel-blur));transition:box-shadow var(--transition-base), transform var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed}.audio-control:hover{box-shadow:0 0 16px var(--panel-glow);transform:scale(1.05)}.audio-control:active{transform:scale(.95)}.edit-toggle{bottom:var(--space-lg);right:calc(var(--space-lg) + 52px);z-index:var(--z-modal);background:var(--panel-bg);border:1px solid var(--panel-border);width:40px;height:40px;color:var(--text-primary);cursor:pointer;-webkit-backdrop-filter:blur(var(--panel-blur));transition:box-shadow var(--transition-base), transform var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;display:flex;position:fixed}.edit-toggle:hover{box-shadow:0 0 16px var(--panel-glow);transform:scale(1.05)}.edit-toggle:active{transform:scale(.95)}.edit-controls{bottom:var(--space-lg);right:calc(var(--space-lg) + 52px);z-index:var(--z-modal);gap:var(--space-sm);display:flex;position:fixed}.edit-circle{cursor:pointer;width:40px;height:40px;-webkit-backdrop-filter:blur(var(--panel-blur));transition:box-shadow var(--transition-base), transform var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;display:flex}.edit-circle:hover{transform:scale(1.1)}.edit-circle:active{transform:scale(.9)}.edit-circle--cancel{background:var(--panel-bg);border:1px solid var(--panel-border);color:var(--text-secondary)}.edit-circle--cancel:hover{color:#ff6b6b;box-shadow:0 0 12px #ff6b6b33}.edit-circle--apply{background:var(--accent);border:1px solid var(--accent);color:var(--bg-primary)}.edit-circle--apply:hover{box-shadow:0 0 16px var(--panel-glow)}.profile-menu{z-index:500;position:fixed;top:.75rem;right:.75rem}.profile-menu__avatar{cursor:pointer;background:linear-gradient(135deg,#6b7bff,#a855f7);border:2px solid #b482ff66;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;transition:border-color .2s,box-shadow .2s;display:flex;overflow:hidden}.profile-menu__avatar:hover{border-color:#b482ffcc;box-shadow:0 0 12px #9b59b666}.profile-menu__avatar-img{object-fit:cover;border-radius:50%;width:100%;height:100%}.profile-menu__avatar-initial{color:#fff;font-size:.85rem;font-weight:700;font-family:var(--font-display);-webkit-user-select:none;user-select:none}.profile-menu__dropdown{-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0c081cf2;border:1px solid #b482ff40;border-radius:12px;width:220px;position:absolute;top:calc(100% + .5rem);right:0;overflow:hidden;box-shadow:0 8px 32px #00000080}.profile-menu__user{flex-direction:column;gap:.15rem;padding:.75rem 1rem;display:flex}.profile-menu__name{color:#e8d5ff;font-size:.85rem;font-weight:600}.profile-menu__email{color:#7060a0;text-overflow:ellipsis;white-space:nowrap;font-size:.72rem;overflow:hidden}.profile-menu__pro-badge{color:#fff;letter-spacing:.08em;background:linear-gradient(135deg,#ff6b9d,#a855f7);border-radius:6px;width:fit-content;margin-top:.2rem;padding:.1rem .4rem;font-size:.6rem;font-weight:700;display:inline-block}.profile-menu__divider{background:#b482ff1f;height:1px}.profile-menu__item{text-align:left;color:#d4b3ff;cursor:pointer;background:0 0;border:none;width:100%;padding:.55rem 1rem;font-size:.8rem;transition:background .15s;display:block}.profile-menu__item:hover{background:#783cc833}.profile-menu__item--muted{color:#7060a0;font-size:.75rem}.profile-menu__item--danger{color:#ff6b6b}.profile-menu__item--danger:hover{background:#ff3c3c1f}.coin-balance{z-index:500;-webkit-backdrop-filter:blur(8px);cursor:pointer;-webkit-user-select:none;user-select:none;height:36px;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:#00000073;border:1px solid #ffcc4426;border-radius:14px;align-items:center;gap:3px;padding:3px 8px 3px 6px;display:flex;position:fixed;top:.75rem;right:3.5rem}.coin-balance:hover{border-color:#fc46;box-shadow:0 0 10px #ffcc4426}.coin-balance__icon{filter:drop-shadow(0 1px 2px #0006);flex-shrink:0}.coin-balance__count{font-family:var(--font-ui);color:#fc4;text-shadow:0 1px 4px #00000080;font-size:.72rem;font-weight:700}.mascot{pointer-events:none;justify-content:center;display:flex}.mascot__image{object-fit:contain;filter:drop-shadow(0 4px 12px #00000040);width:clamp(64px,12vw,112px);height:auto;animation:3s ease-in-out infinite mascot-idle}@keyframes mascot-idle{0%,to{transform:translateY(0)rotate(0)}30%{transform:translateY(-6px)rotate(2deg)}60%{transform:translateY(-3px)rotate(-1.5deg)}}.home{height:100%;padding:var(--space-md);flex-direction:column;width:60%;max-width:none;margin:0 auto;display:flex;overflow:hidden}.home__header{justify-content:space-between;align-items:center;gap:var(--space-md);flex-shrink:0;display:flex}.home__title{font-family:var(--font-display);color:#fff;text-shadow:0 2px 6px #000000e6,0 0 24px #00000080;font-size:clamp(1.2rem,4vw,1.6rem);font-weight:700;line-height:1.15}.home__subtitle{font-family:var(--font-body);color:#fff;text-shadow:0 2px 6px #000000e6,0 0 24px #00000080;margin-top:2px;font-size:.75rem}.home__locations{flex:1;grid-template-rows:1fr 1fr;grid-template-columns:repeat(3,1fr);gap:12px;min-height:0;padding:2.5% 0;display:grid}@media (width<=600px){.home{width:92%}.home__locations{scrollbar-width:none;grid-template-rows:auto;grid-template-columns:repeat(2,1fr);gap:8px;padding:3% 0;overflow-y:auto}.home__loc-card{aspect-ratio:16/10;height:auto}}.home__status-msg{text-align:center;font-family:var(--font-ui);color:var(--text-muted);grid-column:1/-1;font-size:.8rem}.home__status-msg--error{color:#ff6b6bb3}.home__loc-card{cursor:pointer;aspect-ratio:auto;height:100%;transition:box-shadow var(--transition-base), border-color var(--transition-base);border-radius:14px;position:relative;overflow:hidden;-webkit-backdrop-filter:none!important;background:0 0!important;padding:0!important}.home__loc-card:hover{border:2px solid #ff6b9d99;box-shadow:0 0 30px #ff6b9d80,0 0 60px #a855f733}.home__loc-bg{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.home__loc-overlay{background:linear-gradient(#05020f1a 0%,#05020f4d 50%,#05020fd9 100%);position:absolute;inset:0}.home__loc-content{flex-direction:column;justify-content:flex-end;gap:8px;padding:14px;display:flex;position:absolute;inset:0}.home__loc-name{font-family:var(--font-display);color:#fff;text-shadow:0 1px 4px #0009;font-size:clamp(.8rem,2.5vw,1rem);font-weight:700;line-height:1.1}.home__loc-avatars{align-items:center;gap:0;display:flex}.home__loc-avatar{border:1.5px solid #05020f99;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;margin-left:-4px;display:flex;overflow:hidden}.home__loc-avatar:first-child{margin-left:0}.home__loc-avatar img{object-fit:cover;object-position:center 15%;width:100%;height:100%}.home__loc-more{font-family:var(--font-ui);color:#ffffff80;margin-left:4px;font-size:.55rem;font-weight:700}.home__ticker{padding:var(--space-sm) 0;flex-direction:column;flex-shrink:0;align-items:center;gap:6px;display:flex}.home__ticker-item{cursor:pointer;text-align:center;flex-wrap:wrap;justify-content:center;align-items:baseline;gap:6px;display:flex}.home__ticker-item:hover .home__ticker-name{color:var(--accent-hover)}.home__ticker-name{font-family:var(--font-display);color:#ffb3d0;text-shadow:0 0 10px #ff6b9db3,0 1px 4px #000c;transition:color var(--transition-fast);font-size:.85rem;font-weight:800}.home__ticker-text{font-family:var(--font-body);color:#fff;text-shadow:0 1px 6px #0009;font-size:.8rem;font-weight:700}.home__ticker-dots{justify-content:center;gap:4px;display:flex}.home__ticker-dot{width:4px;height:4px;transition:background var(--transition-fast), transform var(--transition-fast);background:#ffffff26;border-radius:50%}.home__ticker-dot--active{background:var(--accent);transform:scale(1.3)}.home__actions{flex-shrink:0;gap:10px;padding-bottom:0;display:flex}.home__action-btn{font-family:var(--font-ui);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid;border-radius:14px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px 20px;font-size:.85rem;font-weight:700;display:flex}.home__action-btn--create{color:#fff;background:linear-gradient(135deg,#ff6b9d,#a855f7);border-color:#ff6b9d99;box-shadow:0 4px 16px #ff6b9d4d}.home__action-btn--create:hover{background:linear-gradient(135deg,#ff85b1,#b96dfa);border-color:#ff6b9dcc;transform:translateY(-1px);box-shadow:0 6px 24px #ff6b9d66}.home__action-btn--gallery{color:var(--text-primary);background:#ffffff1f;border-color:#fff3}.home__action-btn--gallery:hover{color:#fff;background:#fff3;border-color:#ffffff4d;transform:translateY(-1px)}.portrait{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.portrait--sm{width:48px;height:48px}.portrait--md{width:80px;height:80px}.portrait--lg{width:120px;height:120px}.portrait--clickable{cursor:pointer}.portrait--clickable:hover .portrait__glow{opacity:.6}.portrait--clickable:hover{transform:scale(1.05)}.portrait__image{object-fit:cover;object-position:center 15%;opacity:0;border-radius:50%;width:100%;height:100%;transition:opacity .3s;position:absolute;inset:0}.portrait__image--loaded{opacity:1}.portrait__initial{font-family:var(--font-display);color:#ffffffe6;text-shadow:0 2px 8px #0000004d;-webkit-user-select:none;user-select:none;font-weight:700}.portrait--sm .portrait__initial{font-size:1.25rem}.portrait--md .portrait__initial{font-size:2rem}.portrait--lg .portrait__initial{font-size:3rem}.portrait__glow{background:inherit;filter:blur(12px);opacity:.3;z-index:-1;transition:opacity var(--transition-base);border-radius:50%;position:absolute;inset:-4px}.portrait--generating{animation:1.5s ease-in-out infinite portrait-shimmer}@keyframes portrait-shimmer{0%,to{opacity:.7}50%{opacity:1}}.sprite{z-index:var(--z-content);pointer-events:none;flex-direction:column;align-items:center;display:flex;position:absolute}.sprite--clickable{pointer-events:auto;cursor:pointer}.sprite--clickable:hover .sprite__image{filter:brightness(1.15) drop-shadow(0 0 12px var(--glow-color))}.sprite--clickable:hover .sprite__name{opacity:1}.sprite--editing{pointer-events:auto;cursor:grab;z-index:var(--z-modal)}.sprite--editing:active{cursor:grabbing}.sprite--editing .sprite__image{filter:drop-shadow(0 0 16px var(--accent)) drop-shadow(0 4px 12px #0000004d)}.sprite__image{object-fit:contain;filter:drop-shadow(0 4px 12px #0000004d);width:auto;height:24vh;max-height:224px;transition:filter var(--transition-base)}.sprite__name{font-family:var(--font-display);color:var(--text-primary);text-shadow:0 2px 8px #000000b3;opacity:.7;transition:opacity var(--transition-fast);margin-top:var(--space-xs);font-size:.875rem;font-weight:700}.sprite__drag-hint{font-family:var(--font-ui);color:var(--accent);background:var(--panel-bg);border-radius:8px;margin-top:4px;padding:2px 8px;font-size:.625rem;animation:1.5s ease-in-out infinite pulse-glow}@media (width<=768px){.sprite__image{height:18vh;max-height:157px}}.info-card-overlay{z-index:var(--z-modal);-webkit-backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.info-card-container{width:90%;max-width:360px}.info-card{align-items:center;gap:var(--space-md);padding:var(--space-xl) var(--space-lg);text-align:center;flex-direction:column;display:flex}.info-card__name{font-family:var(--font-display);color:var(--text-primary);margin-top:var(--space-sm);font-size:1.5rem;font-weight:700}.info-card__archetype{font-family:var(--font-ui);color:var(--accent);text-transform:capitalize;letter-spacing:.08em;font-size:.8125rem}.info-card__summary{color:var(--text-secondary);font-size:.875rem;line-height:1.6}.info-card__traits{gap:var(--space-xs);flex-wrap:wrap;justify-content:center;display:flex}.info-card__trait{font-family:var(--font-ui);padding:2px var(--space-sm);border:1px solid var(--panel-border);color:var(--text-secondary);background:#ffffff0f;border-radius:99px;font-size:.75rem}.info-card__talk-btn{margin-top:var(--space-sm);width:100%}.archetype-card{align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--panel-radius);cursor:pointer;text-align:center;transition:border-color var(--transition-base), box-shadow var(--transition-base);flex-direction:column;flex:1;min-width:140px;display:flex;position:relative}.archetype-card:hover{border-color:#ffffff26}.archetype-card--selected{border-color:var(--accent);box-shadow:0 0 20px var(--panel-glow), inset 0 0 20px #ff6b9d0d}.archetype-card__icon-ring{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.archetype-card__icon{filter:drop-shadow(0 2px 4px #0000004d);font-size:1.5rem}.archetype-card__label{font-family:var(--font-display);color:var(--text-primary);font-size:.8125rem;font-weight:700;line-height:1.3}.archetype-card__desc{font-family:var(--font-body);color:var(--text-muted);font-size:.6875rem;line-height:1.4}.archetype-card__check{top:var(--space-sm);right:var(--space-sm);background:var(--accent);width:22px;height:22px;color:var(--bg-primary);border-radius:50%;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex;position:absolute}.trait-picker__hint{font-family:var(--font-ui);color:var(--text-muted);margin-bottom:var(--space-sm);text-align:center;font-size:.75rem}.trait-picker__grid{gap:var(--space-sm);flex-wrap:wrap;justify-content:center;display:flex}.trait-chip{font-family:var(--font-ui);padding:var(--space-xs) var(--space-md);border:1px solid var(--panel-border);color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast);text-transform:capitalize;background:0 0;border-radius:20px;font-size:.8125rem;font-weight:500}.trait-chip:hover:not(:disabled){color:var(--text-primary);border-color:#fff3}.trait-chip--selected{border-color:var(--accent);color:var(--accent);box-shadow:0 0 8px var(--panel-glow);background:#ff6b9d26}.trait-chip--selected:hover:not(:disabled){border-color:var(--accent-hover);color:var(--accent-hover);background:#ff6b9d40}.trait-chip--disabled{opacity:.3;cursor:not-allowed}.location-picker{align-self:stretch;width:85vw;max-width:1200px;margin:0 auto}.location-picker__hint{font-family:var(--font-ui);color:var(--text-muted);margin-bottom:var(--space-sm);text-align:center;font-size:.75rem}.location-picker__grid{gap:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}.location-option{aspect-ratio:4/3;border-radius:var(--panel-radius-sm);cursor:pointer;text-align:center;width:100%;min-width:0;transition:border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);background:0 0;border:2px solid #ffffff14;padding:0;display:flex;position:relative;overflow:hidden}.location-option:hover{border-color:#fff6;box-shadow:0 0 12px #ffffff1a}.location-option--selected{border-color:var(--accent);border-width:3px;box-shadow:0 0 24px #ff6b9d66,0 0 48px #ff6b9d26}.location-option--selected .location-option__overlay{background:linear-gradient(#0000 0%,#05020f1a 40%,#ff6b9d40 100%)}.location-option__bg{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.location-option__overlay{background:linear-gradient(#0000 0%,#05020f26 40%,#05020fcc 100%);position:absolute;inset:0}.location-option__info{flex-direction:column;justify-content:flex-end;align-items:center;gap:2px;padding:10px;display:flex;position:absolute;inset:0}.location-option__name{font-family:var(--font-display);color:#fff;text-shadow:0 1px 4px #0009;font-size:1.1rem;font-weight:700}.location-option__mood{font-family:var(--font-ui);color:var(--accent);text-transform:capitalize;text-shadow:0 1px 4px #0009;font-size:.75rem}@media (width<=1000px) and (width>=701px){.location-picker__grid{grid-template-columns:repeat(2,1fr)}}@media (width<=700px){.location-picker{max-width:100%}.location-picker__grid{gap:var(--space-sm);grid-template-columns:1fr;max-width:400px;margin:0 auto}.location-option{aspect-ratio:16/9}}.appearance{gap:var(--space-md);flex-direction:column;display:flex}.appearance__hint{font-family:var(--font-ui);color:var(--text-muted);text-align:center;font-size:.75rem}.appearance__row{flex-direction:column;gap:6px;display:flex}.appearance__row--pair{grid-template-columns:1fr 1fr;gap:10px;display:grid}.appearance__field{flex-direction:column;gap:4px;display:flex}.appearance__label{font-family:var(--font-ui);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.65rem;font-weight:700}.appearance__label-hint{text-transform:none;letter-spacing:normal;color:var(--text-muted);opacity:.7;font-weight:400}.appearance__select{font-family:var(--font-ui);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;padding:8px 10px;font-size:.78rem}.appearance__select:focus{border-color:var(--accent);outline:none}.appearance__select option{color:var(--text-primary);background:#1a1525}.appearance__toggle-group{gap:6px;display:flex}.appearance__toggle{font-family:var(--font-ui);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0a;border:1px solid #ffffff14;border-radius:8px;flex-direction:column;flex:1;align-items:center;gap:2px;padding:8px;font-size:.75rem;font-weight:600;display:flex}.appearance__toggle:hover{border-color:#fff3}.appearance__toggle--active{border-color:var(--accent);color:var(--accent);background:#ff6b9d1f}.appearance__toggle-desc{color:var(--text-muted);font-size:.6rem;font-weight:400}.appearance__chip-group{flex-wrap:wrap;gap:6px;display:flex}.appearance__chip{font-family:var(--font-ui);color:var(--text-secondary);cursor:pointer;text-transform:capitalize;transition:all var(--transition-fast);background:#ffffff0a;border:1px solid #ffffff14;border-radius:20px;padding:5px 12px;font-size:.7rem}.appearance__chip:hover{border-color:#fff3}.appearance__chip--active{border-color:var(--accent);color:var(--accent);background:#ff6b9d1f}.appearance__styles{grid-template-columns:repeat(3,1fr);gap:6px;display:grid}@media (width<=480px){.appearance__styles{grid-template-columns:repeat(2,1fr)}}.appearance__style-card{cursor:pointer;transition:all var(--transition-fast);background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;flex-direction:column;align-items:center;gap:2px;padding:10px 6px;display:flex;position:relative}.appearance__style-card:hover:not(:disabled){border-color:#fff3}.appearance__style-card--active{border-color:var(--accent);background:#ff6b9d1f}.appearance__style-card:disabled{opacity:.4;cursor:not-allowed}.appearance__style-name{font-family:var(--font-ui);color:var(--text-primary);font-size:.72rem;font-weight:700}.appearance__style-desc{font-family:var(--font-ui);color:var(--text-muted);font-size:.58rem}.appearance__style-badge{font-family:var(--font-ui);color:#fff;background:linear-gradient(135deg,#ff6b9d,#a855f7);border-radius:4px;padding:1px 5px;font-size:.5rem;font-weight:700;position:absolute;top:4px;right:4px}.appearance__variant-group{gap:8px;display:flex}.appearance__variant{cursor:pointer;transition:all var(--transition-fast);background:#ffffff0a;border:1px solid #ffffff14;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:2px;padding:8px;display:flex;position:relative}.appearance__variant:hover:not(:disabled){border-color:#fff3}.appearance__variant--active{border-color:var(--accent);background:#ff6b9d1f}.appearance__variant:disabled{opacity:.4;cursor:not-allowed}.appearance__variant-num{font-family:var(--font-display);color:var(--text-primary);font-size:1rem;font-weight:700}.appearance__variant-cost{font-family:var(--font-ui);color:#fc4;font-size:.6rem}.appearance__advanced-toggle{color:var(--text-muted);font-family:var(--font-ui);cursor:pointer;text-align:center;transition:color var(--transition-fast);background:0 0;border:none;padding:4px;font-size:.7rem}.appearance__advanced-toggle:hover{color:var(--text-secondary)}.appearance__advanced{gap:var(--space-sm);padding:var(--space-sm);background:#ffffff05;border:1px solid #ffffff0d;border-radius:8px;flex-direction:column;display:flex}.appearance__textarea{font-family:var(--font-ui);color:var(--text-primary);resize:none;background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;padding:8px;font-size:.75rem}.appearance__textarea:focus{border-color:var(--accent);outline:none}.appearance__textarea::placeholder{color:var(--text-muted)}.appearance__cost{background:#ffcc440f;border:1px solid #ffcc4426;border-radius:10px;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 14px;display:flex}.appearance__cost--insufficient{background:#ff3c3c0f;border-color:#ff3c3c4d}.appearance__cost-label{font-family:var(--font-ui);color:var(--text-secondary);font-size:.75rem}.appearance__cost-value{font-family:var(--font-ui);color:#fc4;align-items:center;gap:4px;font-size:.85rem;font-weight:700;display:flex}.appearance__cost-icon{font-size:.75rem}.appearance__cost-warn{font-family:var(--font-ui);color:#ff6b6b;width:100%;font-size:.65rem}.gen-preview{align-items:center;gap:var(--space-lg);padding:var(--space-md) 0;flex-direction:column;display:flex}.gen-preview__title{font-family:var(--font-display);color:var(--text-primary);font-size:1.1rem;font-weight:700}.gen-preview__loading{align-items:center;gap:var(--space-lg);padding:var(--space-2xl) var(--space-xl);background:var(--panel-bg);min-height:300px;-webkit-backdrop-filter:blur(var(--panel-blur));border:1px solid var(--panel-border);border-radius:20px;flex-direction:column;justify-content:center;max-width:400px;margin:0 auto;display:flex}.gen-preview__loading-visual{justify-content:center;align-items:center;width:100px;height:100px;display:flex;position:relative}.gen-preview__loading-ring{border:2px solid #0000;border-top-color:var(--accent);border-bottom-color:#a855f74d;border-radius:50%;position:absolute;inset:0}.gen-preview__loading-ring--inner{border-top-color:#a855f799;border-bottom-color:#ff6b9d33;inset:10px}.gen-preview__loading-icon{color:var(--accent);animation:2s ease-in-out infinite pulse-glow}.gen-preview__loading-name{font-family:var(--font-display);color:var(--text-primary);font-size:1.15rem;font-weight:700}.gen-preview__loading-tip{font-family:var(--font-body);color:var(--text-secondary);min-height:1.4em;font-size:.9rem}.gen-preview__progress{background:#ffffff0f;border-radius:2px;width:200px;height:3px;overflow:hidden}.gen-preview__progress-fill{background:linear-gradient(90deg, var(--accent), #a855f7);border-radius:2px;height:100%}.gen-preview__loading-time{font-family:var(--font-ui);color:var(--text-muted);font-size:.7rem}.gen-preview__error{align-items:center;gap:var(--space-md);text-align:center;padding:var(--space-2xl) var(--space-xl);background:var(--panel-bg);max-width:400px;-webkit-backdrop-filter:blur(var(--panel-blur));border:1px solid var(--panel-border);border-radius:20px;flex-direction:column;margin:0 auto;display:flex}.gen-preview__error-icon{color:#ff6b6b;background:#ff6b6b1a;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.gen-preview__error-title{font-family:var(--font-display);color:var(--text-primary);font-size:1.15rem;font-weight:700}.gen-preview__error-msg{font-family:var(--font-body);color:var(--text-secondary);font-size:.88rem;line-height:1.5}.gen-preview__error-refund{font-family:var(--font-ui);color:#7d7;background:#77dd7714;border:1px solid #77dd7726;border-radius:10px;align-items:center;gap:6px;padding:8px 16px;font-size:.82rem;font-weight:600;display:flex}.gen-preview__error-action{font-family:var(--font-ui);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);margin-top:var(--space-sm);background:#ffffff0f;border:1px solid #ffffff1a;border-radius:12px;padding:10px 28px;font-size:.85rem;font-weight:600}.gen-preview__error-action:hover{background:#ffffff1a;border-color:#fff3}.gen-preview__grid{gap:10px;width:100%;max-width:500px;display:grid}.gen-preview__grid--1{grid-template-columns:1fr;max-width:280px}.gen-preview__grid--2{grid-template-columns:1fr 1fr}.gen-preview__grid--3{grid-template-columns:1fr 1fr 1fr}.gen-preview__grid--4{grid-template-columns:1fr 1fr}.gen-preview__variant{aspect-ratio:3/4;cursor:pointer;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:#ffffff08;border:2px solid #ffffff14;border-radius:12px;padding:0;position:relative;overflow:hidden}.gen-preview__variant:hover{border-color:#fff3}.gen-preview__variant--selected{border-color:var(--accent);box-shadow:0 0 20px #ff6b9d4d}.gen-preview__variant img{object-fit:cover;width:100%;height:100%}.gen-preview__placeholder{background:linear-gradient(135deg,#ff6b9d1a,#a855f71a);justify-content:center;align-items:center;width:100%;height:100%;display:flex}.gen-preview__placeholder span{font-family:var(--font-ui);color:var(--text-muted);font-size:.75rem}.gen-preview__variant-label{font-family:var(--font-ui);color:#fff;background:#0009;border-radius:4px;padding:2px 6px;font-size:.6rem;font-weight:700;position:absolute;top:6px;left:6px}.gen-preview__confirm{font-family:var(--font-ui);color:#fff;cursor:pointer;transition:all var(--transition-fast);background:linear-gradient(135deg,#ff6b9d,#a855f7);border:none;border-radius:14px;padding:14px 40px;font-size:.9rem;font-weight:700;box-shadow:0 4px 16px #ff6b9d4d}.gen-preview__confirm:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px #ff6b9d66}.gen-preview__confirm:disabled{opacity:.6;cursor:not-allowed}.creation{align-items:center;gap:var(--space-lg);padding:var(--space-md) var(--space-md) var(--space-xl);scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;flex-direction:column;max-width:1120px;min-height:100%;margin:0 auto;padding-top:.5rem;display:flex;overflow-y:auto}.creation__progress{gap:var(--space-sm);display:flex}.creation__dot{background:var(--panel-border);width:10px;height:10px;transition:background var(--transition-base), box-shadow var(--transition-base);border-radius:50%}.creation__dot--active{background:var(--accent);box-shadow:0 0 8px var(--panel-glow)}.creation__step{align-items:center;gap:var(--space-lg);flex-direction:column;width:100%;display:flex}.creation__title{font-family:var(--font-display);color:#fff;text-align:center;text-shadow:0 2px 6px #000000e6,0 0 20px #0006;font-size:clamp(1.25rem,4vw,1.75rem);font-weight:700}.creation__panel{width:100%;max-width:850px;padding:var(--space-lg);gap:var(--space-md);flex-direction:column;display:flex}.creation__field-hint{font-family:var(--font-ui);color:var(--text-muted);text-align:center;font-size:.75rem}.creation__archetypes{gap:var(--space-md);grid-template-columns:repeat(4,1fr);width:100%;display:grid}@media (width<=700px){.creation__archetypes{grid-template-columns:repeat(2,1fr)}}.creation__summary{align-items:center;gap:var(--space-md)}.creation__summary-portrait{width:72px;height:72px;box-shadow:0 0 20px var(--panel-glow);border-radius:50%;justify-content:center;align-items:center;display:flex}.creation__summary-initial{font-family:var(--font-display);color:#ffffffe6;text-shadow:0 2px 8px #0000004d;font-size:2rem;font-weight:700}.creation__summary-row{flex-direction:column;gap:2px;width:100%;display:flex}.creation__summary-label{font-family:var(--font-ui);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:.6875rem}.creation__summary-value{font-family:var(--font-body);color:var(--text-primary);text-transform:capitalize;font-size:.9375rem}.creation__summary-value--backstory{text-transform:none;color:var(--text-secondary);font-size:.8125rem;line-height:1.5}.creation__error{font-family:var(--font-ui);color:#ff6b6b;text-align:center;font-size:.8125rem}.creation__nav{align-items:center;width:100%;max-width:850px;display:flex}.creation__nav-spacer{flex:1}.location-nav{gap:var(--space-xs);padding:var(--space-sm);scrollbar-width:none;-ms-overflow-style:none;display:flex;overflow-x:auto}.location-nav::-webkit-scrollbar{display:none}.location-nav__item{padding:var(--space-sm) var(--space-md);background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--panel-radius-sm);color:var(--text-secondary);cursor:pointer;transition:background var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-fast);white-space:nowrap;-webkit-backdrop-filter:blur(8px);flex-direction:column;flex-shrink:0;align-items:center;gap:2px;display:flex}.location-nav__item:hover{border-color:var(--accent);background:#ffffff14;transform:scale(1.02)}.location-nav__item--active{border-color:var(--accent);box-shadow:0 0 12px var(--panel-glow);color:var(--text-primary)}.location-nav__thumb{object-fit:cover;border:1px solid var(--panel-border);border-radius:50%;flex-shrink:0;width:28px;height:28px}.location-nav__label{font-family:var(--font-ui);letter-spacing:.03em;font-size:.6875rem;font-weight:500}.location{width:100%;height:100%;position:relative}.location--empty{justify-content:center;align-items:center;gap:var(--space-md);color:var(--text-muted);flex-direction:column;display:flex}.location__error-text{font-family:var(--font-body);color:var(--text-secondary);text-shadow:0 1px 6px #00000080}.location__header{top:var(--space-lg);left:var(--space-md);align-items:flex-start;gap:var(--space-xs);z-index:var(--z-panel);pointer-events:none;flex-direction:column;display:flex;position:absolute}.location__header .btn{pointer-events:auto}.location__name{font-family:var(--font-display);color:var(--text-primary);letter-spacing:.05em;text-shadow:0 2px 12px #00000080;font-size:clamp(1.5rem,4vw,2rem);font-weight:700}.location__mood{color:var(--text-secondary);text-shadow:0 1px 6px #00000080;max-width:500px;font-size:.875rem}.location__scene{z-index:var(--z-content);position:absolute;inset:0}.location__empty-text{color:var(--text-muted);text-shadow:0 1px 6px #00000080;font-style:italic;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.location__nav-wrapper{bottom:var(--space-lg);left:var(--space-md);right:var(--space-md);z-index:var(--z-panel);pointer-events:none;position:absolute}.location__nav-wrapper>*{pointer-events:auto}.chat-message{gap:var(--space-xs);flex-direction:column;max-width:80%;animation:.3s slide-up;display:flex}.chat-message--user{align-self:flex-end}.chat-message--assistant{align-self:flex-start}.chat-message__name{font-family:var(--font-display);color:var(--accent);letter-spacing:.05em;padding-left:var(--space-xs);font-size:.75rem}.chat-message__bubble{padding:var(--space-sm) var(--space-md);border-radius:var(--panel-radius-sm);word-wrap:break-word;font-size:.9375rem;line-height:1.6}.chat-message--user .chat-message__bubble{background:var(--msg-user-bg);border:1px solid var(--msg-user-border);border-radius:var(--panel-radius-sm) var(--panel-radius-sm) 4px var(--panel-radius-sm)}.chat-message--assistant .chat-message__bubble{background:var(--msg-assistant-bg);border:1px solid var(--msg-assistant-border);border-radius:var(--panel-radius-sm) var(--panel-radius-sm) var(--panel-radius-sm) 4px}.typewriter__cursor{color:var(--accent);margin-left:1px;animation:.8s step-end infinite typewriter-cursor}.chat-input{align-items:flex-end;gap:var(--space-sm);padding:var(--space-sm);border-top:1px solid var(--panel-border);flex-shrink:0;display:flex}.chat-input__field{font-family:var(--font-body);color:var(--text-primary);border:1px solid var(--panel-border);border-radius:var(--panel-radius-sm);padding:var(--space-sm) var(--space-md);resize:none;min-height:40px;max-height:120px;transition:border-color var(--transition-base), box-shadow var(--transition-base);background:#ffffff0a;outline:none;flex:1;font-size:.9375rem;line-height:1.5}.chat-input__field::placeholder{color:var(--text-muted)}.chat-input__field:focus{border-color:var(--accent);box-shadow:0 0 8px var(--panel-glow)}.chat-input__field:disabled{opacity:.5}.chat-input__send{background:var(--accent);width:40px;height:40px;color:var(--bg-primary);cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-base);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.chat-input__send:hover:not(:disabled){box-shadow:0 0 16px var(--panel-glow);transform:scale(1.05)}.chat-input__send:active:not(:disabled){transform:scale(.95)}.chat-input__send:disabled{opacity:.3;cursor:not-allowed}.message-limit-bar{align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);border-bottom:1px solid var(--panel-border);color:var(--text-secondary);flex-shrink:0;min-height:28px;font-size:.75rem;display:flex}.message-limit-bar__progress{background:#ffffff0f;border-radius:2px;flex:1;max-width:120px;height:4px;overflow:hidden}.message-limit-bar__fill{background:var(--accent);border-radius:2px;height:100%;transition:width .3s,background .3s}.message-limit-bar__fill--warning{background:#f59e0b}.message-limit-bar__fill--danger{background:#ef4444}.message-limit-bar__text{white-space:nowrap;color:var(--text-muted)}.message-limit-bar__text--warning{color:#f59e0b}.message-limit-bar__text--danger{color:#ef4444}.message-limit-bar__overflow{white-space:nowrap;color:#f59e0b;font-style:italic}.message-limit-bar__link{white-space:nowrap;color:var(--accent);transition:color var(--transition-fast);font-weight:500;text-decoration:none}.message-limit-bar__link:hover{color:var(--accent-hover);text-decoration:underline}.typing-indicator{align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);animation:.3s fadeIn;display:flex}.typing-indicator__dots{gap:3px;display:flex}.typing-indicator__dot{background:var(--accent);border-radius:50%;width:6px;height:6px;animation:1.2s ease-in-out infinite bounce-dot}.typing-indicator__dot:nth-child(2){animation-delay:.15s}.typing-indicator__dot:nth-child(3){animation-delay:.3s}.typing-indicator__text{font-family:var(--font-ui);color:var(--text-muted);font-size:.75rem;font-style:italic}.chat-panel-wrapper{z-index:var(--z-panel);flex-direction:column;max-height:65vh;display:flex;position:fixed;bottom:0;left:0;right:0}.chat-panel{flex-direction:column;max-height:65vh;display:flex;overflow:hidden}.chat-panel__header{padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--panel-border);flex-shrink:0}.chat-panel__name{font-family:var(--font-display);color:var(--accent);letter-spacing:.05em;font-size:.875rem}.chat-panel__messages{padding:var(--space-md);gap:var(--space-md);scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;flex-direction:column;flex:1;min-height:0;display:flex;overflow-y:auto}.conv-sidebar__toggle{z-index:200;color:#e8d5ff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0f0a1ebf;border:1px solid #b482ff59;border-radius:20px;align-items:center;gap:.3rem;padding:.4rem .7rem;font-size:.8rem;transition:background .2s,border-color .2s;display:flex;position:fixed;bottom:calc(65vh + .5rem);left:1rem}.conv-sidebar__toggle:hover{background:#783cc866;border-color:#b482ff99}.conv-sidebar__toggle-icon{font-size:1rem}.conv-sidebar__badge{background:#b482ff66;border-radius:10px;padding:0 .4rem;font-size:.7rem}.conv-sidebar{z-index:300;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#0c081ceb;border-right:1px solid #b482ff33;flex-direction:column;width:260px;transition:left .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:-280px;overflow:hidden}.conv-sidebar--open{left:0}.conv-sidebar__header{border-bottom:1px solid #b482ff26;justify-content:space-between;align-items:center;padding:1rem 1rem .5rem;display:flex}.conv-sidebar__title{color:#d4b3ff;letter-spacing:.04em;font-size:.9rem;font-weight:600}.conv-sidebar__close{color:#a080c0;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:.9rem;transition:color .2s}.conv-sidebar__close:hover{color:#e8d5ff}.conv-sidebar__new{color:#d4b3ff;cursor:pointer;text-align:center;background:#783cc840;border:1px solid #b482ff4d;border-radius:8px;margin:.75rem;padding:.55rem;font-size:.85rem;transition:background .2s}.conv-sidebar__new:hover{background:#783cc873}.conv-sidebar__list{flex:1;padding:.25rem .5rem;overflow-y:auto}.conv-sidebar__empty{color:#7060a0;text-align:center;padding:1rem;font-size:.8rem}.conv-sidebar__item{cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;flex-direction:column;align-items:flex-start;width:100%;margin-bottom:.2rem;padding:.55rem .75rem;transition:background .15s;display:flex;position:relative;overflow:hidden}.conv-sidebar__item:hover{background:#783cc833}.conv-sidebar__item--active{background:#783cc859;border-left:3px solid #b482ffb3}.conv-sidebar__item-title{color:#e8d5ff;white-space:nowrap;text-overflow:ellipsis;max-width:calc(100% - 3.5rem);font-size:.82rem;line-height:1.3;overflow:hidden}.conv-sidebar__actions{opacity:0;gap:.1rem;transition:opacity .15s;display:flex;position:absolute;top:50%;right:.4rem;transform:translateY(-50%)}.conv-sidebar__item:hover .conv-sidebar__actions{opacity:1}.conv-sidebar__action-btn{cursor:pointer;background:#0f0a1eb3;border:none;border-radius:4px;padding:.2rem .3rem;font-size:.75rem;line-height:1;transition:background .15s}.conv-sidebar__action-btn:hover{background:#783cc880}.conv-sidebar__action-btn--delete:hover{background:#b4282880}.conv-sidebar__edit-input{color:#e8d5ff;background:#281446cc;border:1px solid #b482ff80;border-radius:4px;outline:none;width:calc(100% - 3.5rem);padding:.15rem .4rem;font-size:.82rem}.conv-sidebar__item-meta{color:#8060b0;align-items:center;gap:.4rem;margin-top:.15rem;font-size:.72rem;display:flex}.conv-sidebar__dot{background:#9b59b6;border-radius:50%;width:6px;height:6px;box-shadow:0 0 6px #9b59b6cc}.conv-sidebar__backdrop{z-index:299;background:#0006;position:fixed;inset:0}.chat-page{height:100%;padding:var(--space-md);flex-direction:column;display:flex}.chat-page--empty{justify-content:center;align-items:center;gap:var(--space-lg);color:var(--text-muted)}.chat-page__header{z-index:var(--z-content)}.chat-page__character{justify-content:center;align-items:center;gap:var(--space-sm);flex-direction:column;height:40vh;display:flex}.chat-page__character-name{font-family:var(--font-display);color:var(--text-primary);letter-spacing:.05em;text-shadow:0 2px 8px #00000080;font-size:1.125rem}.create-page{min-height:100%;padding:var(--space-md);flex-direction:column;display:flex}.create-page__back{align-self:flex-start}.login-page{z-index:var(--z-content);width:100%;height:100vh;padding:var(--space-md);justify-content:center;align-items:center;display:flex;position:relative}.login-page__container{align-items:center;gap:var(--space-lg);flex-direction:column;width:100%;max-width:420px;display:flex}.login-page__title{font-family:var(--font-display);letter-spacing:.15em;color:#0000;text-align:center;background:linear-gradient(135deg,#ff6b9d 0%,#ffb347 25%,#ff6b9d 50%,#b9f 75%,#ff6b9d 100%) 0 0/200%;-webkit-background-clip:text;background-clip:text;font-size:clamp(1.75rem,5vw,2.5rem);font-weight:700;animation:4s linear infinite shimmer}.login-page__subtitle{font-family:var(--font-display);color:#fff;letter-spacing:.3em;text-transform:uppercase;margin-top:calc(-1 * var(--space-sm));text-align:center;text-shadow:0 2px 8px #000000e6,0 0 20px #00000080;font-size:clamp(.875rem,2.5vw,1.125rem)}.login-page__panel{gap:var(--space-lg);padding:var(--space-xl) var(--space-lg);flex-direction:column;width:100%;display:flex}.login-page__oauth-buttons{gap:var(--space-sm);flex-direction:column;display:flex}.login-page__oauth-btn{justify-content:center;width:100%;height:52px;position:relative}.login-page__oauth-btn--google{color:#8ab4f8;border-color:#4285f480}.login-page__oauth-btn--google:hover:not(:disabled){background:#4285f41a;box-shadow:0 0 16px #4285f433}.login-page__oauth-btn--discord{color:#a8b0f8;border-color:#5865f280}.login-page__oauth-btn--discord:hover:not(:disabled){background:#5865f21a;box-shadow:0 0 16px #5865f233}.login-page__oauth-logo{object-fit:contain;border-radius:50%;flex-shrink:0;width:24px;height:24px}.login-page__oauth-logo--discord{width:38px;height:38px;margin:-7px 0}.login-page__divider{align-items:center;gap:var(--space-md);display:flex}.login-page__divider-line{background:var(--panel-border);flex:1;height:1px}.login-page__divider-text{font-family:var(--font-ui);color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase;font-size:.75rem}.login-page__magic-section{gap:var(--space-sm);flex-direction:column;display:flex}.login-page__magic-btn{width:100%}.login-page__magic-success{align-items:center;gap:var(--space-sm);text-align:center;flex-direction:column;display:flex}.login-page__magic-success p{font-family:var(--font-ui);color:var(--accent);font-size:.9375rem;animation:2.5s ease-in-out infinite pulse-glow}.login-page__legal{font-family:var(--font-ui);color:var(--text-muted);text-align:center;font-size:.7rem}.login-page__legal-link{color:var(--text-secondary);text-underline-offset:2px;transition:color var(--transition-fast);text-decoration:underline}.login-page__legal-link:hover{color:var(--accent)}@media (width<=480px){.login-page__panel{padding:var(--space-lg) var(--space-md)}}.auth-callback{background:radial-gradient(at 50% 40%,#ff6b9d14 0%,#0000 50%),radial-gradient(at 30% 70%,#aa88ff0f 0%,#0000 40%),linear-gradient(#08060f 0%,#0a0a14 50%,#0d0818 100%);justify-content:center;align-items:center;width:100%;height:100vh;display:flex}.auth-callback__content{align-items:center;gap:var(--space-lg);flex-direction:column;display:flex}.auth-callback__spinner{border:2px solid var(--panel-border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px}.auth-callback__text{font-family:var(--font-ui);color:var(--text-secondary);letter-spacing:.1em;font-size:.9375rem;animation:2.5s ease-in-out infinite pulse-glow}.auth-callback__error{font-family:var(--font-ui);color:#f46;text-align:center;max-width:360px;font-size:.9375rem;line-height:1.5}.auth-callback__link{font-family:var(--font-ui);color:var(--accent);letter-spacing:.05em;transition:color var(--transition-base);font-size:.875rem;text-decoration:none}.auth-callback__link:hover{color:var(--accent-hover);text-decoration:underline}.gallery{gap:var(--space-lg);padding:var(--space-md);scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;flex-direction:column;max-width:640px;min-height:100%;margin:0 auto;display:flex;overflow-y:auto}.gallery__header{gap:var(--space-md);background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--panel-blur));border:1px solid var(--panel-border);padding:var(--space-md) var(--space-lg);border-radius:16px;flex-direction:column;display:flex}.gallery__header-top{align-items:center;gap:var(--space-md);display:flex}.gallery__back{color:#fff;cursor:pointer;width:36px;height:36px;transition:background var(--transition-fast);background:#ffffff1a;border:1px solid #ffffff26;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.gallery__back:hover{background:#fff3}.gallery__title{font-family:var(--font-display);color:#fff;text-shadow:0 2px 8px #000000e6,0 0 20px #00000080;font-size:clamp(1.4rem,5vw,1.8rem);font-weight:700;line-height:1.15}.gallery__subtitle{font-family:var(--font-body);color:#ffffffb3;text-shadow:0 2px 8px #000000e6;margin-top:2px;font-size:.8rem}.gallery__limit{align-items:center;gap:var(--space-sm);display:flex}.gallery__limit-bar{background:#ffffff0f;border-radius:2px;flex:1;height:4px;overflow:hidden}.gallery__limit-fill{background:linear-gradient(90deg, var(--accent), #a855f7);border-radius:2px;height:100%;box-shadow:0 0 8px #ff6b9d66}.gallery__limit-text{font-family:var(--font-ui);color:#ffffffb3;white-space:nowrap;text-shadow:0 2px 6px #000c;font-size:.7rem}.gallery__loading{justify-content:center;align-items:center;gap:var(--space-md);padding:var(--space-2xl) 0;flex-direction:column;display:flex}.gallery__loading-spinner{border:2px solid #ffffff0f;border-top-color:var(--accent);border-radius:50%;width:32px;height:32px}.gallery__loading-text{font-family:var(--font-body);color:#ffffffb3;text-shadow:0 2px 6px #000c;font-size:.85rem}.gallery__empty{text-align:center;align-items:center;gap:var(--space-lg);padding:var(--space-2xl) var(--space-xl);background:var(--panel-bg);-webkit-backdrop-filter:blur(var(--panel-blur));border:1px solid var(--panel-border);border-radius:20px;flex-direction:column;display:flex}.gallery__empty-icon{color:#ff6b9d66}.gallery__empty-title{font-family:var(--font-display);color:#fff;text-shadow:0 2px 6px #00000080;font-size:1.4rem}.gallery__empty-text{font-family:var(--font-body);color:#ffffffbf;max-width:320px;font-size:.92rem;line-height:1.6}.gallery__grid{gap:var(--space-md);grid-template-columns:repeat(2,1fr);display:grid}@media (width<=420px){.gallery__grid{grid-template-columns:1fr;max-width:320px;margin:0 auto}}.gallery__card{cursor:pointer;transition:transform var(--transition-fast), border-color var(--transition-base), box-shadow var(--transition-base);background:#0f0c18cc;border:1px solid #ffffff0f;border-radius:16px;position:relative;overflow:hidden}.gallery__card:hover{border-color:#ff6b9d40;transform:translateY(-4px);box-shadow:0 8px 32px #0006,0 0 20px #ff6b9d14}.gallery__card:hover .gallery__card-glow{opacity:1}.gallery__card--generating{border-color:#a855f733}.gallery__card--generating .gallery__card-image:after{content:"";background:linear-gradient(110deg,#0000 30%,#a855f714 50%,#0000 70%) 0 0/200% 100%;animation:1.8s ease-in-out infinite shimmer;position:absolute;inset:0}.gallery__card-image{aspect-ratio:3/4;background:#0000004d;width:100%;position:relative;overflow:hidden}.gallery__card-image img{object-fit:cover;object-position:center 15%;width:100%;height:100%;transition:transform .4s}.gallery__card:hover .gallery__card-image img{transform:scale(1.05)}.gallery__card-fallback{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.gallery__card-fallback span{font-family:var(--font-display);color:#ffffffb3;text-shadow:0 2px 12px #0000004d;font-size:3rem;font-weight:700}.gallery__card-generating{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:2;background:#0a081499;flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex;position:absolute;inset:0}.gallery__card-gen-spinner{border:2px solid #ffffff1a;border-top-color:#a855f7;border-radius:50%;width:24px;height:24px}.gallery__card-generating span{font-family:var(--font-ui);color:#a855f7;letter-spacing:.06em;font-size:.7rem}.gallery__card-archetype{font-family:var(--font-ui);color:#fff;letter-spacing:.04em;z-index:2;border-radius:8px;padding:3px 8px;font-size:.6rem;font-weight:700;position:absolute;bottom:8px;left:8px;box-shadow:0 2px 8px #0006}.gallery__card-info{-webkit-backdrop-filter:blur(8px);background:#0006;border-radius:0 0 14px 14px;flex-direction:column;gap:4px;padding:12px 14px 14px;display:flex}.gallery__card-name{font-family:var(--font-display);color:var(--text-primary);font-size:.95rem;font-weight:700;line-height:1.2}.gallery__card-location{font-family:var(--font-ui);color:var(--text-muted);font-size:.7rem}.gallery__card-traits{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.gallery__card-trait{font-family:var(--font-ui);color:#b0a0d0;text-transform:capitalize;background:#b0a0d01a;border-radius:6px;padding:2px 6px;font-size:.6rem}.gallery__card-glow{opacity:0;width:60%;height:40px;transition:opacity var(--transition-base);pointer-events:none;background:radial-gradient(#ff6b9d26,#0000);position:absolute;bottom:-20px;left:50%;transform:translate(-50%)}.gallery__card--create{background:#ffffff05;border-style:dashed;border-color:#ffffff1a;justify-content:center;align-items:center;min-height:280px;display:flex}.gallery__card--create:hover{background:#ff6b9d0a;border-color:#ff6b9d4d}.gallery__create-content{align-items:center;gap:var(--space-sm);color:var(--text-muted);font-family:var(--font-body);transition:color var(--transition-fast);flex-direction:column;font-size:.85rem;display:flex}.gallery__card--create:hover .gallery__create-content{color:var(--accent)}.gallery__upgrade{padding-bottom:var(--space-lg)}.gallery__upgrade-panel{padding:var(--space-lg)!important}.gallery__upgrade-content{gap:var(--space-md);flex-direction:column;width:100%;display:flex}.gallery__upgrade-title{font-family:var(--font-display);color:var(--text-primary);text-align:center;font-size:1.1rem;font-weight:700}.gallery__upgrade-options{flex-direction:column;gap:10px;display:flex}.gallery__upgrade-pro,.gallery__upgrade-slot{cursor:pointer;transition:all var(--transition-fast);text-align:left;border-radius:14px;align-items:center;gap:12px;width:100%;padding:14px 18px;display:flex}.gallery__upgrade-pro{color:var(--text-primary);background:linear-gradient(135deg,#a855f71f,#ff6b9d1f);border:1px solid #a855f740}.gallery__upgrade-pro:hover{border-color:#a855f766;box-shadow:0 0 16px #a855f726}.gallery__upgrade-pro-icon{font-size:1.3rem}.gallery__upgrade-pro strong{font-family:var(--font-ui);color:#c8a0ff;font-size:.88rem;font-weight:700;display:block}.gallery__upgrade-pro span{font-family:var(--font-ui);color:var(--text-muted);font-size:.75rem}.gallery__upgrade-slot{color:var(--text-primary);background:#ffcc440f;border:1px solid #ffcc4426}.gallery__upgrade-slot:hover:not(:disabled){border-color:#ffcc444d;box-shadow:0 0 12px #ffcc441a}.gallery__upgrade-slot:disabled{opacity:.5;cursor:not-allowed}.gallery__upgrade-slot svg{color:#fc4;flex-shrink:0}.gallery__upgrade-slot strong{font-family:var(--font-ui);color:#fc4;font-size:.88rem;font-weight:700;display:block}.gallery__upgrade-slot span{font-family:var(--font-ui);color:var(--text-muted);font-size:.75rem}.gallery__upgrade-hint{text-align:center;font-family:var(--font-ui);color:var(--text-muted);font-size:.78rem}.gallery__upgrade-hint a{color:var(--accent);font-weight:600;text-decoration:none}.lightbox{z-index:1000;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:var(--space-md);background:#04020cd9;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.lightbox__content{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;background:#0f0c1cf2;border:1px solid #b482ff33;border-radius:20px;width:100%;max-width:400px;max-height:90vh;position:relative;overflow:hidden auto;box-shadow:0 24px 64px #0009,0 0 40px #a855f714}.lightbox__close{z-index:10;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:#00000080;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:12px;right:12px}.lightbox__close:hover{color:#fff;background:#ff3c3c4d}.lightbox__image-area{background:#0006;width:100%;max-height:40vh;position:relative;overflow:hidden}.lightbox__image-area--checkerboard{background:repeating-conic-gradient(#ffffff0a 0% 25%,#00000026 0% 50%) 0 0/20px 20px}.lightbox__image{object-fit:contain;object-position:center;width:100%;height:100%}.lightbox__view-toggle{justify-content:center;gap:2px;padding:12px 16px 0;display:flex}.lightbox__view-btn{font-family:var(--font-ui);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0a;border:1px solid #ffffff0f;border-radius:8px;padding:6px 16px;font-size:.72rem;font-weight:600}.lightbox__view-btn:hover{color:var(--text-secondary);background:#ffffff14}.lightbox__view-btn--active{color:var(--accent);background:#ff6b9d1f;border-color:#ff6b9d40}.lightbox__details{flex-direction:column;gap:8px;padding:16px 20px 8px;display:flex}.lightbox__header-row{justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.lightbox__name{font-family:var(--font-display);color:var(--text-primary);font-size:1.3rem;font-weight:700}.lightbox__archetype{font-family:var(--font-ui);color:#fff;letter-spacing:.04em;white-space:nowrap;border-radius:8px;padding:3px 10px;font-size:.6rem;font-weight:700}.lightbox__location{font-family:var(--font-ui);color:var(--text-muted);align-items:center;gap:4px;font-size:.75rem;display:flex}.lightbox__summary{font-family:var(--font-body);color:var(--text-secondary);font-size:.8rem;line-height:1.5}.lightbox__traits{flex-wrap:wrap;gap:6px;display:flex}.lightbox__trait{font-family:var(--font-ui);color:#c0b0e0;text-transform:capitalize;background:#c0b0e01a;border:1px solid #c0b0e01a;border-radius:8px;padding:3px 8px;font-size:.65rem}.lightbox__actions{flex-wrap:wrap;align-items:center;gap:8px;padding:12px 20px 20px;display:flex}.lightbox__action{font-family:var(--font-ui);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:1px solid #0000;border-radius:10px;align-items:center;gap:6px;padding:8px 14px;font-size:.75rem;font-weight:600;display:flex}.lightbox__action--download{color:#ffb3d0;background:linear-gradient(135deg,#ff6b9d26,#a855f726);border-color:#ff6b9d33}.lightbox__action--download:hover{background:linear-gradient(135deg,#ff6b9d40,#a855f740);border-color:#ff6b9d59;box-shadow:0 0 12px #ff6b9d26}.lightbox__action--chat{color:#a0b0ff;background:#6b7bff1f;border-color:#6b7bff33}.lightbox__action--chat:hover{background:#6b7bff38;border-color:#6b7bff59;box-shadow:0 0 12px #6b7bff26}.lightbox__action--delete{color:#ff8080;background:#ff3c3c14;border-color:#ff3c3c1f;margin-left:auto}.lightbox__action--delete:hover{background:#ff3c3c2e;border-color:#ff3c3c4d}.lightbox__action--delete-confirm{font-family:var(--font-ui);color:#ff6b6b;cursor:pointer;transition:all var(--transition-fast);background:#ff3c3c33;border:1px solid #ff3c3c66;border-radius:10px;justify-content:center;align-items:center;gap:6px;margin-left:auto;padding:8px 16px;font-size:.78rem;font-weight:600;animation:.3s shake;display:flex}.lightbox__action--delete-confirm:hover{background:#ff3c3c59;border-color:#ff3c3c99}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}75%{transform:translate(3px)}}.lightbox__delete-yes{color:#ff6b6b;background:#ff3c3c33;border-color:#ff3c3c4d}.lightbox__delete-yes:hover{background:#ff3c3c59}.lightbox__delete-no{color:var(--text-secondary);background:#ffffff0f;border-color:#ffffff1a}.lightbox__delete-no:hover{background:#ffffff1f}@media (width<=480px){.gallery{padding:var(--space-sm)}.lightbox__content{border-radius:16px;max-width:100%}.lightbox__actions{padding:12px 16px 16px}}.settings{gap:var(--space-lg);padding:var(--space-md);scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;max-width:620px;min-height:100%;padding-bottom:var(--space-2xl);flex-direction:column;margin:0 auto;display:flex;overflow-y:auto}.settings__back{z-index:100;position:fixed;top:.85rem;left:.85rem}.settings__title{font-family:var(--font-display);color:#fff;text-shadow:0 2px 6px #000000e6,0 0 20px #0006;font-size:clamp(1.4rem,5vw,1.8rem);font-weight:700}.settings__section{gap:var(--space-md);flex-direction:column;display:flex;padding:var(--space-lg)!important}.settings__section-title{font-family:var(--font-ui);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;font-size:.7rem;font-weight:700}.settings__divider{background:#ffffff0f;height:1px}.settings__label{font-family:var(--font-ui);color:var(--text-muted);font-size:.7rem}.settings__profile-row{align-items:flex-start;gap:var(--space-md);display:flex}.settings__avatar{border:2px solid #b482ff4d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex;overflow:hidden}.settings__avatar-img{object-fit:cover;width:100%;height:100%}.settings__avatar-initial{font-family:var(--font-display);color:#fff;font-size:1.4rem;font-weight:700}.settings__profile-info{flex-direction:column;flex:1;gap:6px;display:flex}.settings__input-row{gap:var(--space-sm);display:flex}.settings__input{font-family:var(--font-ui);color:var(--text-primary);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;flex:1;padding:8px 12px;font-size:.85rem}.settings__input:focus{border-color:var(--accent);outline:none}.settings__email{font-family:var(--font-ui);color:var(--text-muted);font-size:.72rem}.settings__plan-row{justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.settings__plan-info{flex-direction:column;gap:4px;display:flex}.settings__plan-name{font-family:var(--font-display);color:var(--text-primary);align-items:center;gap:8px;font-size:1rem;font-weight:700;display:flex}.settings__pro-badge{font-family:var(--font-ui);color:#fff;letter-spacing:.08em;background:linear-gradient(135deg,#ff6b9d,#a855f7);border-radius:6px;padding:2px 8px;font-size:.55rem;font-weight:700}.settings__plan-desc{font-family:var(--font-ui);color:var(--text-muted);font-size:.75rem}.settings__coins-row{justify-content:space-between;align-items:center;display:flex}.settings__coins-label{font-family:var(--font-ui);color:var(--text-secondary);font-size:.8rem}.settings__coins-value{font-family:var(--font-ui);color:#fc4;align-items:center;gap:4px;font-size:.9rem;font-weight:700;display:flex}.settings__coins-icon{font-size:.8rem}.settings__audio-row{align-items:center;gap:var(--space-md);display:flex}.settings__audio-label{font-family:var(--font-ui);color:var(--text-secondary);min-width:60px;font-size:.82rem}.settings__audio-toggle{cursor:pointer;width:48px;height:26px;transition:background var(--transition-fast);background:#ffffff1a;border:none;border-radius:13px;align-items:center;padding:2px;display:flex;position:relative}.settings__audio-toggle--on{background:var(--accent)}.settings__audio-toggle-knob{width:22px;height:22px;transition:transform var(--transition-fast);background:#fff;border-radius:50%;box-shadow:0 1px 3px #0000004d}.settings__audio-toggle--on .settings__audio-toggle-knob{transform:translate(22px)}.settings__audio-toggle-text{font-family:var(--font-ui);color:#ffffff80;text-transform:uppercase;font-size:.5rem;font-weight:700;position:absolute;right:8px}.settings__audio-toggle--on .settings__audio-toggle-text{color:#fffc;left:6px;right:auto}.settings__volume-slider{appearance:none;background:#ffffff1a;border-radius:2px;outline:none;flex:1;height:4px}.settings__volume-slider::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);cursor:pointer;border-radius:50%;width:16px;height:16px;box-shadow:0 0 8px #ff6b9d4d}.settings__volume-value{font-family:var(--font-ui);color:var(--text-muted);text-align:right;min-width:32px;font-size:.72rem;font-weight:700}.settings__actions{flex-direction:column;gap:2px;display:flex}.settings__action{text-align:left;width:100%;font-family:var(--font-ui);color:var(--text-secondary);cursor:pointer;transition:color var(--transition-fast);background:0 0;border:none;padding:10px 0;font-size:.82rem;display:block}.settings__action:hover{color:var(--text-primary)}.settings__action--danger{color:#ff6b6b}.settings__action--danger:hover{color:#f44}.settings__delete-confirm{gap:var(--space-sm);flex-direction:column;display:flex}.settings__delete-warn{font-family:var(--font-ui);color:#ff8080;font-size:.78rem;line-height:1.5}.settings__delete-buttons{gap:var(--space-sm);display:flex}.settings__delete-btn{font-family:var(--font-ui);color:#ff6b6b;cursor:pointer;transition:all var(--transition-fast);background:#ff3c3c33;border:1px solid #ff3c3c4d;border-radius:8px;padding:6px 14px;font-size:.75rem;font-weight:700}.settings__delete-btn:hover{background:#ff3c3c59}.settings__language-desc{font-family:var(--font-body);color:var(--text-muted);margin:0 0 12px;font-size:.82rem}.settings__language-options{gap:8px;display:flex}.settings__language-btn{font-family:var(--font-ui);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:10px;flex:1;padding:10px 16px;font-size:.85rem;font-weight:600}.settings__language-btn:hover{background:#ffffff14;border-color:#fff3}.settings__language-btn--active{color:#c8a0ff;background:#a855f71f;border-color:#a855f766;box-shadow:0 0 12px #a855f71a}.settings__help{justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.settings__help-text{font-family:var(--font-body);color:var(--text-muted);font-size:.85rem}.settings__help-email{font-family:var(--font-ui);color:var(--accent);transition:opacity var(--transition-fast);font-size:.85rem;font-weight:600;text-decoration:none}.settings__help-email:hover{opacity:.8}.settings__logout{align-self:center}.shop{min-height:100%;padding:var(--space-md);scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;flex-direction:column;display:flex;overflow-y:auto}.shop__back{align-self:flex-start}.shop__content{gap:var(--space-md);width:90vw;max-width:1100px;padding-bottom:var(--space-2xl);flex-direction:column;margin:0 auto;display:flex}.shop__hero{align-items:center;gap:var(--space-xl);flex-direction:row-reverse;justify-content:center;display:flex}.shop__mascot{filter:drop-shadow(0 4px 24px #ff6b9d4d);width:140px;height:auto;animation:4s ease-in-out infinite shop-mascot-float}@keyframes shop-mascot-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.shop__hero-text{flex-direction:column;gap:6px;display:flex}.shop__title{font-family:var(--font-display);color:#fc4;text-shadow:0 2px 6px #000000e6,0 0 32px #ffcc4440;margin:0;font-size:clamp(1.6rem,5vw,2.4rem);font-weight:700}.shop__subtitle{font-family:var(--font-ui);color:#fff;text-shadow:0 2px 8px #000000e6,0 0 20px #00000080;margin:0;font-size:.95rem}.shop__balance{font-family:var(--font-ui);color:#fff;text-shadow:0 2px 8px #000000e6,0 0 20px #00000080;align-items:center;gap:6px;margin-top:4px;font-size:.9rem;display:flex}.shop__balance-icon{font-size:.85rem}.shop__balance-count{color:#fc4;font-weight:700}.shop__section{gap:var(--space-md);flex-direction:column;display:flex}.shop__section-title{font-family:var(--font-display);color:#fff;text-align:center;text-shadow:0 2px 8px #000000e6,0 0 16px #00000080;margin:0;font-size:1.1rem;font-weight:700}.shop__packs{gap:var(--space-lg);grid-template-columns:repeat(3,1fr);width:100%;display:grid}.shop__pack{padding:var(--space-xl) var(--space-md) var(--space-lg);background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:var(--panel-radius);-webkit-backdrop-filter:blur(var(--panel-blur));backdrop-filter:blur(var(--panel-blur));transition:transform var(--transition-fast), border-color var(--transition-base), box-shadow var(--transition-base);flex-direction:column;align-items:center;gap:8px;display:flex;position:relative}.shop__pack:hover{border-color:#ffcc444d;transform:translateY(-6px);box-shadow:0 12px 40px #00000080,0 0 24px #ffcc441a}.shop__pack--best{background:linear-gradient(135deg, #ffcc440a, #ff99440a), var(--panel-bg);border-color:#ffcc4459;box-shadow:0 0 24px #ffcc441a,inset 0 0 40px #ffcc4408}.shop__pack--best:hover{border-color:#ffcc4480;box-shadow:0 12px 40px #00000080,0 0 40px #ffcc442e}.shop__pack-badge{font-family:var(--font-ui);color:#1a1000;letter-spacing:.08em;white-space:nowrap;background:linear-gradient(135deg,#fc4,#f94);border-radius:10px;padding:3px 14px;font-size:.6rem;font-weight:700;position:absolute;top:-11px;left:50%;transform:translate(-50%);box-shadow:0 2px 12px #ffcc4459}.shop__pack-tagline{font-family:var(--font-ui);color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.65rem;font-weight:600}.shop__pack-coins{font-family:var(--font-display);color:#fc4;text-shadow:0 0 16px #ffcc4440;font-size:2rem;font-weight:700;line-height:1}.shop__pack-label{font-family:var(--font-ui);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.7rem}.shop__pack-price{font-family:var(--font-ui);color:var(--text-primary);margin-top:4px;font-size:1.2rem;font-weight:700}.shop__pack-bonus{font-family:var(--font-ui);color:#7d7;background:#77dd771a;border-radius:8px;padding:3px 10px;font-size:.7rem;font-weight:600}.shop__pack-buy{width:100%;font-family:var(--font-ui);color:#fc4;cursor:pointer;transition:all var(--transition-fast);background:linear-gradient(135deg,#ffcc4426,#ff994426);border:1px solid #ffcc4440;border-radius:12px;margin-top:auto;padding:10px 0;font-size:.82rem;font-weight:700}.shop__pack-buy:hover{background:linear-gradient(135deg,#ffcc4447,#ff994447);border-color:#ffcc4473;transform:translateY(-1px);box-shadow:0 0 16px #ffcc442e}.shop__pack-buy:disabled{opacity:.5;cursor:not-allowed;transform:none}.shop__divider{align-items:center;gap:var(--space-md);display:flex}.shop__divider-line{background:linear-gradient(90deg,#0000,#ffffff1f,#0000);flex:1;height:1px}.shop__divider-text{font-family:var(--font-ui);color:#fff;text-shadow:0 2px 10px #000,0 0 20px #000000b3;white-space:nowrap;font-size:.82rem;font-weight:600}.shop__pro{transition:border-color var(--transition-base), box-shadow var(--transition-base);width:100%;position:relative;box-shadow:0 0 32px #a855f714;padding:var(--space-xl)!important;background:linear-gradient(135deg, #a855f708, #ff6b9d08), var(--panel-bg)!important;border-color:#a855f740!important}.shop__pro:hover{box-shadow:0 0 40px #a855f71f;border-color:#a855f759!important}.shop__pro-header{justify-content:space-between;align-items:center;gap:var(--space-md);margin-bottom:var(--space-lg);display:flex}.shop__pro-title-group{align-items:center;gap:10px;display:flex}.shop__pro-sparkle{font-size:1.4rem}.shop__pro-title{font-family:var(--font-display);color:var(--text-primary);background:linear-gradient(135deg,#e0b0ff,#a855f7);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.4rem;font-weight:700}.shop__pro-price{font-family:var(--font-ui);color:var(--text-secondary);font-size:.9rem;font-weight:700}.shop__pro-price strong{color:var(--text-primary);font-size:1.3rem}.shop__pro-body{align-items:flex-start;gap:var(--space-xl);display:flex}.shop__pro-features{flex-direction:column;flex:1;gap:10px;margin:0;padding:0;list-style:none;display:flex}.shop__pro-feature{font-family:var(--font-body);color:var(--text-secondary);align-items:center;gap:10px;font-size:.88rem;display:flex}.shop__pro-feature-icon{color:#a855f7;flex-shrink:0;font-size:.8rem}.shop__pro-cta{flex-direction:column;justify-content:center;align-items:center;min-width:200px;display:flex}.shop__pro-subscribe{width:100%;font-family:var(--font-ui);color:#fff;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:linear-gradient(135deg,#ff6b9d,#a855f7);border:none;border-radius:14px;padding:14px 32px;font-size:.95rem;font-weight:700;box-shadow:0 4px 20px #a855f74d}.shop__pro-subscribe:hover{transform:translateY(-2px);box-shadow:0 8px 32px #a855f766}.shop__pro-subscribe:disabled{opacity:.5;cursor:not-allowed;transform:none}.shop__pro-active{font-family:var(--font-ui);color:#c8a0ff;background:linear-gradient(135deg,#a855f726,#ff6b9d26);border:1px solid #a855f740;border-radius:14px;align-items:center;gap:8px;padding:12px 20px;font-size:.88rem;font-weight:700;display:flex}.shop__pro-active-icon{font-size:1.1rem}@media (width<=900px){.shop__packs{grid-template-columns:repeat(2,1fr)}.shop__pro-body{flex-direction:column}.shop__pro-cta{width:100%;min-width:0}}@media (width<=600px){.shop__hero{text-align:center;flex-direction:column}.shop__hero-text{align-items:center}.shop__mascot{width:100px}.shop__content{width:100%}.shop__packs{grid-template-columns:1fr}.shop__pro-header{flex-direction:column;align-items:flex-start}}.payment-success{justify-content:center;align-items:center;gap:var(--space-lg);min-height:100%;padding:var(--space-md);text-align:center;flex-direction:column;display:flex}.payment-success__icon{font-size:3rem;animation:.5s ease-out payment-success-pop}@keyframes payment-success-pop{0%{opacity:0;transform:scale(0)}60%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.payment-success__title{font-family:var(--font-display);color:var(--text-primary);text-shadow:0 2px 6px #000000e6;font-size:clamp(1.4rem,5vw,1.8rem);font-weight:700}.payment-success__subtitle{font-family:var(--font-body);color:var(--text-muted);max-width:320px;font-size:.88rem;line-height:1.5}.payment-success__redirect{font-family:var(--font-ui);color:var(--text-muted);font-size:.72rem}.legal{min-height:100%;padding:var(--space-md);flex-direction:column;max-width:860px;margin:0 auto;display:flex}.legal__back{z-index:100;position:fixed;top:.85rem;left:.85rem}.legal__content{scrollbar-width:thin;scrollbar-color:#ffffff1a transparent;border-radius:var(--panel-radius);-webkit-backdrop-filter:blur(16px);padding:var(--space-lg) var(--space-xl);padding-bottom:var(--space-2xl);background:#080512eb;border:1px solid #ffffff0f;flex:1;overflow-y:auto}.legal__title{font-family:var(--font-display);color:#fff;text-shadow:0 2px 8px #00000080;margin-bottom:4px;font-size:clamp(1.4rem,5vw,2rem);font-weight:700}.legal__updated{font-family:var(--font-ui);color:var(--text-muted);margin-bottom:var(--space-lg);font-size:.7rem}.legal__intro{font-family:var(--font-body);color:var(--text-secondary);margin-bottom:var(--space-lg);font-size:.85rem;line-height:1.7}.legal__section{margin-bottom:var(--space-lg)}.legal__section h2{font-family:var(--font-display);color:#fff;text-shadow:0 1px 4px #0006;margin-bottom:var(--space-sm);font-size:1.05rem;font-weight:700}.legal__section h3{font-family:var(--font-ui);color:var(--accent);margin-top:var(--space-md);margin-bottom:var(--space-xs);font-size:.85rem;font-weight:700}.legal__section p{font-family:var(--font-body);color:var(--text-secondary);margin-bottom:var(--space-sm);font-size:.82rem;line-height:1.7}.legal__section ul{margin:0 0 var(--space-sm) 0;flex-direction:column;gap:6px;padding:0;list-style:none;display:flex}.legal__section li{font-family:var(--font-body);color:var(--text-secondary);padding-left:16px;font-size:.82rem;line-height:1.6;position:relative}.legal__section li:before{content:"";background:var(--accent);opacity:.6;border-radius:50%;width:5px;height:5px;position:absolute;top:8px;left:0}.legal__section strong{color:#fff;font-weight:700}@media (width<=600px){.legal{padding:var(--space-sm)}}
