.ipm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.ipm-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:2rem;max-width:400px;width:100%;max-height:90vh;overflow-y:auto;text-align:center;position:relative;animation:ipm-pop .3s cubic-bezier(.34,1.56,.64,1)}@keyframes ipm-pop{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.ipm-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-dim);cursor:pointer;padding:.25rem;border-radius:6px;transition:all .15s}.ipm-close:hover{color:var(--text-primary);background:var(--bg-elevated)}.ipm-portrait{width:120px;height:120px;border-radius:16px;margin:0 auto 1rem;background:var(--bg-elevated);border:3px solid var(--accent-warm);box-shadow:0 0 30px #d4a35333;display:flex;align-items:center;justify-content:center;color:var(--text-dim);overflow:hidden}.ipm-portrait img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.ipm-name{font-size:1.15rem;font-weight:700;color:var(--text-primary);margin-bottom:.15rem}.ipm-pronouns{font-size:.8rem;color:var(--text-dim);margin-bottom:.75rem}.ipm-bio{font-size:.85rem;color:var(--text-muted);line-height:1.5;margin-bottom:1rem;padding:0 .5rem}.ipm-tags-section{margin-bottom:.75rem}.ipm-tags-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:.4rem}.ipm-tags{display:flex;gap:.35rem;justify-content:center;flex-wrap:wrap}.ipm-tag{font-size:.75rem;padding:.2rem .6rem;background:var(--bg-elevated);color:var(--text-muted);border-radius:6px;border:1px solid var(--border-subtle)}.ipm-actions{display:flex;gap:.5rem;justify-content:center;margin-top:1.25rem}.ipm-btn{padding:.55rem 1.1rem;border:none;border-radius:10px;font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .15s}.ipm-btn-later{background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.ipm-btn-later:hover{background:var(--bg-hover);color:var(--text-primary)}.ipm-btn-decline{background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.ipm-btn-decline:hover{background:var(--bg-hover);color:var(--text-primary)}.ipm-btn-accept{background:var(--accent-warm);color:var(--bg-base);box-shadow:0 0 16px #d4a35333}.ipm-btn-accept:hover{background:var(--accent-warm-bright);transform:translateY(-1px)}@media (max-width: 440px){.ipm-modal{padding:1.25rem}.ipm-actions{flex-direction:column}}.ip-panel{position:absolute;top:100%;right:0;margin-top:.35rem;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;min-width:300px;max-width:360px;max-height:400px;overflow-y:auto;z-index:200;box-shadow:0 8px 32px #00000080}.ip-header{padding:.65rem .85rem;font-size:.8rem;font-weight:600;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);text-transform:uppercase;letter-spacing:.04em}.ip-empty{padding:1.5rem .85rem;text-align:center;color:var(--text-dim);font-size:.8rem}.ip-list{padding:.25rem}.ip-item{display:flex;align-items:center;gap:.6rem;padding:.5rem .6rem;border-radius:8px;transition:background .15s}.ip-item:hover{background:var(--bg-elevated)}.ip-item-avatar{flex-shrink:0;width:36px;height:36px;border-radius:8px;overflow:hidden}.ip-item-portrait{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.ip-item-placeholder{width:100%;height:100%;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;color:var(--text-dim)}.ip-item-info{flex:1;min-width:0}.ip-item-name{font-size:.8rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ip-item-meta{font-size:.7rem;color:var(--text-muted);display:flex;gap:.3rem}.ip-item-genres{opacity:.7}.ip-item-actions{display:flex;gap:.3rem;flex-shrink:0}.ip-btn{padding:.3rem .55rem;border-radius:6px;font-family:inherit;font-size:.7rem;font-weight:500;cursor:pointer;transition:all .15s;border:1px solid transparent}.ip-btn-view{background:var(--bg-elevated);color:var(--text-muted);border-color:var(--border)}.ip-btn-view:hover{background:var(--bg-hover);color:var(--text-primary)}.ip-btn-accept{background:var(--accent-warm);border-color:var(--accent-warm);color:var(--bg-base)}.ip-btn-accept:hover{background:var(--accent-warm-bright);border-color:var(--accent-warm-bright)}.ip-btn-decline{background:var(--bg-elevated);color:var(--text-muted);border-color:var(--border)}.ip-btn-decline:hover{background:var(--bg-hover);color:var(--text-primary)}.mm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.mm-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:2rem;max-width:520px;width:100%;max-height:90vh;overflow-y:auto;text-align:center;animation:mm-pop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes mm-pop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.mm-title{font-size:1.5rem;font-weight:700;color:var(--accent-warm);margin-bottom:1.5rem;animation:mm-title-glow 2s ease-in-out infinite}@keyframes mm-title-glow{0%,to{filter:brightness(1)}50%{filter:brightness(1.2)}}.mm-portraits{display:flex;align-items:center;justify-content:center;gap:1.5rem;margin-bottom:1.25rem}.mm-portrait-wrap{display:flex;flex-direction:column;align-items:center;gap:.35rem;animation:mm-portrait-slide .5s ease-out backwards}.mm-portrait-wrap:first-child{animation-delay:.1s}.mm-portrait-wrap:last-child{animation-delay:.2s}@keyframes mm-portrait-slide{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.mm-portrait{width:96px;height:96px;border-radius:16px;background:var(--bg-elevated);border:3px solid var(--accent-warm);box-shadow:0 0 30px #d4a35340;display:flex;align-items:center;justify-content:center;color:var(--text-dim);overflow:hidden}.mm-portrait img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.mm-portrait-name{font-size:.9rem;font-weight:600;color:var(--text-primary)}.mm-portrait-pronouns{font-size:.75rem;color:var(--text-dim)}.mm-portraits-divider{color:var(--accent-warm);opacity:.7}.mm-shared{margin-bottom:1.25rem}.mm-shared-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:.5rem}.mm-shared-tags{display:flex;gap:.4rem;justify-content:center;flex-wrap:wrap}.mm-shared-tag{font-size:.75rem;padding:.2rem .6rem;background:#d4a3531f;color:var(--accent-warm);border-radius:12px;border:1px solid rgba(212,163,83,.2)}.mm-scenarios-section{margin-bottom:1.5rem;text-align:left}.mm-scenarios-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim);margin-bottom:.75rem;text-align:center}.mm-scenarios-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.mm-scenario{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;padding:.75rem;cursor:pointer;transition:all .15s;text-align:left;font-family:inherit;color:var(--text-primary)}.mm-scenario:hover:not(:disabled){border-color:var(--accent-primary-dim);background:var(--bg-hover)}.mm-scenario-selected{border-color:var(--accent-warm);background:#d4a35314}.mm-scenario-selected:hover{border-color:var(--accent-warm)!important}.mm-scenario-disabled{opacity:.4;cursor:not-allowed}.mm-scenario-name{font-size:.85rem;font-weight:600;margin-bottom:.2rem}.mm-scenario-tagline{font-size:.7rem;color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.mm-scenario-soon{display:inline-block;font-size:.65rem;color:var(--text-dim);margin-top:.25rem}.mm-actions{display:flex;gap:.75rem;justify-content:center}.mm-btn{padding:.65rem 1.5rem;border:none;border-radius:10px;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s}.mm-btn-later{background:var(--bg-elevated);color:var(--text-muted);border:1px solid var(--border)}.mm-btn-later:hover{background:var(--bg-hover);color:var(--text-primary)}.mm-btn-play{background:var(--accent-warm);color:#0a0b0e;box-shadow:0 0 24px #d4a35340}.mm-btn-play:hover:not(:disabled){background:var(--accent-warm-bright);transform:translateY(-1px)}.mm-btn-play:disabled{opacity:.5;cursor:not-allowed}.mm-confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1001;overflow:hidden}.mm-confetti-piece{position:absolute;top:-20px;width:10px;height:10px;animation:mm-confetti-fall 3s ease-out forwards;opacity:0}@keyframes mm-confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.mm-confetti-piece:nth-child(1){left:5%;background:var(--accent-warm);animation-delay:0s;border-radius:50%;width:8px;height:8px}.mm-confetti-piece:nth-child(2){left:12%;background:var(--accent-primary);animation-delay:.1s;border-radius:2px;width:10px;height:10px}.mm-confetti-piece:nth-child(3){left:20%;background:var(--accent-warm-bright);animation-delay:.05s;border-radius:50%;width:7px;height:7px}.mm-confetti-piece:nth-child(4){left:28%;background:var(--accent-primary-bright);animation-delay:.2s;border-radius:2px;width:9px;height:9px}.mm-confetti-piece:nth-child(5){left:35%;background:var(--text-primary);animation-delay:.08s;border-radius:50%;width:6px;height:6px}.mm-confetti-piece:nth-child(6){left:42%;background:var(--accent-warm);animation-delay:.15s;border-radius:2px;width:11px;height:11px}.mm-confetti-piece:nth-child(7){left:48%;background:var(--accent-primary-bright);animation-delay:.25s;border-radius:50%;width:8px;height:8px}.mm-confetti-piece:nth-child(8){left:55%;background:var(--accent-warm-bright);animation-delay:.12s;border-radius:2px;width:10px;height:10px}.mm-confetti-piece:nth-child(9){left:62%;background:var(--accent-primary);animation-delay:.3s;border-radius:50%;width:7px;height:7px}.mm-confetti-piece:nth-child(10){left:68%;background:var(--text-primary);animation-delay:.18s;border-radius:2px;width:9px;height:9px}.mm-confetti-piece:nth-child(11){left:75%;background:var(--accent-warm);animation-delay:.22s;border-radius:50%;width:10px;height:10px}.mm-confetti-piece:nth-child(12){left:82%;background:var(--accent-warm-bright);animation-delay:.02s;border-radius:2px;width:8px;height:8px}.mm-confetti-piece:nth-child(13){left:88%;background:var(--accent-primary);animation-delay:.28s;border-radius:50%;width:6px;height:6px}.mm-confetti-piece:nth-child(14){left:93%;background:var(--accent-primary-bright);animation-delay:.14s;border-radius:2px;width:11px;height:11px}.mm-confetti-piece:nth-child(15){left:8%;background:var(--accent-warm-bright);animation-delay:.35s;border-radius:50%;width:9px;height:9px}.mm-confetti-piece:nth-child(16){left:17%;background:var(--text-primary);animation-delay:.4s;border-radius:2px;width:7px;height:7px}.mm-confetti-piece:nth-child(17){left:38%;background:var(--accent-warm);animation-delay:.32s;border-radius:50%;width:10px;height:10px}.mm-confetti-piece:nth-child(18){left:52%;background:var(--accent-primary-bright);animation-delay:.38s;border-radius:2px;width:8px;height:8px}.mm-confetti-piece:nth-child(19){left:72%;background:var(--accent-warm-bright);animation-delay:.42s;border-radius:50%;width:7px;height:7px}.mm-confetti-piece:nth-child(20){left:95%;background:var(--accent-primary);animation-delay:.45s;border-radius:2px;width:9px;height:9px}@media (max-width: 500px){.mm-scenarios-grid{grid-template-columns:1fr}.mm-modal{padding:1.25rem}}.app-layout{min-height:100vh;background:var(--bg-base);color:var(--text-primary)}.app-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background:#111318f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-subtle);position:sticky;top:0;z-index:100}.logo{font-size:1.25rem;font-weight:800;letter-spacing:-.02em;display:flex;align-items:baseline;gap:.1rem;text-decoration:none}.logo-story{color:var(--text-primary);font-weight:600}.logo-bond{color:var(--accent-warm);font-weight:800}.logo-dot{color:var(--accent-primary-bright);font-size:1.5rem;line-height:1;margin-left:.1rem}.alpha-badge{font-size:.6rem;text-transform:uppercase;letter-spacing:.05em;padding:2px 6px;border:1px solid var(--accent-warm);color:var(--accent-warm);border-radius:4px;margin-left:8px;align-self:center;font-weight:600}.header-nav{display:flex;gap:1.5rem;margin-left:2rem}.header-nav-link{color:var(--text-muted);text-decoration:none;font-size:.875rem;font-weight:500;padding:.35rem .5rem;border-radius:6px;transition:color .15s,background .15s}.header-nav-link:hover{color:var(--text-primary);background:var(--bg-elevated)}.header-actions{display:flex;gap:.5rem;align-items:center;margin-left:auto}.header-btn{padding:.5rem .85rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);font-family:inherit;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:.4rem}.header-btn:hover{background:var(--bg-hover);border-color:var(--accent-primary);color:var(--text-primary)}.header-btn .badge{background:var(--accent-warm);color:var(--bg-base);font-size:.65rem;font-weight:700;padding:.1rem .35rem;border-radius:4px}.invites-btn-wrapper,.profile-btn-wrapper{position:relative}.profile-btn{display:flex;align-items:center;gap:.45rem;padding:.5rem .75rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}.profile-btn:hover{border-color:var(--accent-warm)}.profile-status-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-success);box-shadow:0 0 6px var(--accent-success);flex-shrink:0}.profile-dropdown{display:none;position:absolute;top:100%;right:0;margin-top:.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:.25rem;min-width:140px;z-index:200}.profile-dropdown-open{display:block}.dropdown-status{display:flex;align-items:center;gap:.4rem;padding:.5rem .75rem;font-size:.8rem;color:var(--text-dim)}.dropdown-online-dot{width:6px;height:6px;border-radius:50%;background:var(--accent-success)}.dropdown-item{display:block;width:100%;padding:.5rem .75rem;background:none;border:none;border-radius:6px;color:var(--text-muted);font-family:inherit;font-size:.8rem;cursor:pointer;text-align:left;transition:all .15s}.dropdown-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.header-nav-active{color:var(--text-primary);font-weight:600;position:relative}.header-nav-active:after{content:"";position:absolute;bottom:0;left:.5rem;right:.5rem;height:2px;background:var(--accent-warm);border-radius:1px}.join-btn-wrapper{position:relative}.header-btn-join{background:var(--bg-elevated);border-color:var(--accent-warm-dim);color:var(--accent-warm)}.header-btn-join:hover{background:var(--bg-hover);border-color:var(--accent-warm)}.join-dropdown{position:absolute;top:100%;right:0;margin-top:.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:.75rem;min-width:240px;z-index:200}.join-dropdown-label{font-size:.75rem;color:var(--text-dim);margin-bottom:.5rem}.join-dropdown-form{display:flex;gap:.35rem}.join-dropdown-input{flex:1;padding:.4rem .6rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-family:inherit;font-size:.8rem}.join-dropdown-input:focus{outline:none;border-color:var(--accent-primary)}.join-dropdown-input::-moz-placeholder{color:var(--text-dim)}.join-dropdown-input::placeholder{color:var(--text-dim)}.join-dropdown-btn{padding:.4rem .75rem;background:var(--accent-warm);border:none;border-radius:6px;color:var(--bg-base);font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.join-dropdown-btn:hover{background:var(--accent-warm-bright)}.header-btn-signin{background:var(--action-blue);color:#fff;font-weight:600;padding:.45rem 1rem;border-radius:8px}.header-btn-signin:hover{background:#4670a5}.app-main{min-height:calc(100vh - var(--header-height))}.am-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.am-modal{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:16px;padding:2rem;width:100%;max-width:380px;position:relative}.am-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem .5rem;line-height:1}.am-close:hover{color:var(--text-primary)}.am-title{font-size:1.25rem;font-weight:600;margin:0 0 .25rem}.am-subtitle{font-size:.85rem;color:var(--text-muted);margin:0 0 1.25rem}.am-tabs{display:flex;gap:.25rem;background:var(--bg-elevated);border-radius:8px;padding:.2rem;margin-bottom:1.25rem}.am-tab{flex:1;padding:.5rem;font-family:inherit;font-size:.85rem;font-weight:500;border:none;border-radius:6px;background:transparent;color:var(--text-muted);cursor:pointer;transition:all .15s}.am-tab:hover{color:var(--text-primary)}.am-tab-active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 3px #0000004d}.am-form{display:flex;flex-direction:column;gap:.75rem}.am-input{padding:.65rem .75rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:.9rem;outline:none;transition:border-color .15s}.am-input:focus{border-color:var(--accent-primary)}.am-input::-moz-placeholder{color:var(--text-dim)}.am-input::placeholder{color:var(--text-dim)}.am-error{font-size:.8rem;color:var(--accent-warm);padding:.4rem 0}.am-submit{padding:.65rem;background:var(--action-blue);border:none;border-radius:8px;color:#fff;font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s;margin-top:.25rem}.am-submit:hover:not(:disabled){background:#4670a5}.am-submit:disabled{opacity:.6;cursor:not-allowed}.am-body{font-size:.85rem;color:var(--text-muted);margin:0 0 1.25rem;line-height:1.5}.am-discord-btn{display:block;width:100%;padding:.65rem;background:#5865f2;border:none;border-radius:8px;color:#fff;font-family:inherit;font-size:.9rem;font-weight:600;text-align:center;text-decoration:none;cursor:pointer;transition:background .15s;margin-bottom:.5rem}.am-discord-btn:hover{background:#4752c4}.am-link-btn{display:block;width:100%;padding:.5rem;background:none;border:none;color:var(--text-dim);font-family:inherit;font-size:.8rem;cursor:pointer;transition:color .15s}.am-link-btn:hover{color:var(--text-primary)}.am-note{font-size:.75rem;color:var(--text-dim);text-align:center;margin-top:.75rem}.sc-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;display:flex;flex-direction:column}.sc-card:hover{border-color:var(--border);transform:translateY(-2px);box-shadow:0 8px 32px #0006}.sc-image{width:100%;aspect-ratio:4/3;position:relative;overflow:hidden;background:var(--bg-elevated)}.sc-badge{position:absolute;top:.5rem;left:.5rem;padding:.25rem .55rem;font-size:.75rem;font-weight:600;border-radius:5px;color:#fff}.sc-players{position:absolute;bottom:.5rem;right:.5rem;padding:.25rem .5rem;font-size:.75rem;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:4px;color:var(--text-primary)}.sc-info{padding:1rem;flex:1;display:flex;flex-direction:column}.sc-title{font-size:1rem;font-weight:600;margin-bottom:.35rem}.sc-pitch{font-size:.8rem;color:var(--text-muted);line-height:1.5;margin-bottom:.75rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sc-actions{display:flex;gap:.5rem;margin-top:auto;padding-top:.5rem}.sc-btn{flex:1;padding:.45rem .5rem;border-radius:6px;font-family:inherit;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;gap:.35rem}.sc-btn-gold{background:var(--accent-warm);border:1px solid var(--accent-warm);color:var(--bg-base);box-shadow:0 0 12px #d4a3534d}.sc-btn-gold:hover{background:var(--accent-warm-bright);border-color:var(--accent-warm-bright)}.sc-btn-blue{background:var(--action-blue);border:1px solid var(--action-blue);color:#fff;box-shadow:0 0 12px #5580b84d}.sc-btn-blue:hover{background:#4670a5;box-shadow:0 0 16px #5580b866}.sc-card-coming-soon{cursor:default}.sc-card-coming-soon .sc-image{filter:grayscale(60%);opacity:.6}.sc-card-coming-soon:hover{transform:none;box-shadow:none;border-color:var(--border-subtle)}.sc-coming-soon-badge{flex:1;padding:.45rem .5rem;border-radius:6px;font-size:.75rem;font-weight:600;text-align:center;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-dim)}.cc-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s;display:flex;flex-direction:column}.cc-card:hover{border-color:var(--border);transform:translateY(-2px);box-shadow:0 8px 32px #0006}.cc-image{width:100%;aspect-ratio:3/4;position:relative;overflow:hidden}.cc-image-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--bg-elevated) 0%,var(--bg-hover) 100%);display:flex;align-items:center;justify-content:center;color:var(--text-dim)}.cc-image-portrait{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.cc-badge{position:absolute;top:.5rem;left:.5rem;padding:.25rem .5rem;font-size:.75rem;font-weight:600;border-radius:5px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.cc-badge-ai{background:#5580b8e6;color:#fff}.cc-badge-player{background:#d4a353e6;color:var(--bg-base)}.cc-online-dot{position:absolute;top:.5rem;right:.5rem;width:10px;height:10px;background:var(--accent-warm);border-radius:50%;border:2px solid var(--bg-card);box-shadow:0 0 8px var(--accent-warm)}.cc-online-dot.offline{background:var(--text-dim);box-shadow:none}.cc-info{padding:.75rem;flex:1;display:flex;flex-direction:column}.cc-name{font-size:.95rem;font-weight:600;margin-bottom:.1rem}.cc-meta{font-size:.75rem;color:var(--text-muted);margin-bottom:.4rem}.cc-tags{display:flex;flex-wrap:wrap;gap:.25rem;margin-bottom:.5rem}.cc-tag{padding:.2rem .45rem;background:var(--bg-elevated);border-radius:4px;font-size:.75rem;color:var(--text-muted)}.cc-actions{display:flex;gap:.35rem;margin-top:auto;padding-top:.5rem}.cc-btn{flex:1;padding:.45rem .5rem;border-radius:6px;font-family:inherit;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;justify-content:center;gap:.35rem}.cc-btn-default{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted)}.cc-btn-default:hover{background:var(--bg-hover);color:var(--text-primary)}.cc-action-blue{background:var(--action-blue);border:1px solid var(--action-blue);color:#fff;box-shadow:0 0 12px #5580b84d}.cc-action-blue:hover{background:#4670a5}.cc-action-gold{background:var(--accent-warm);border:1px solid var(--accent-warm);color:var(--bg-base);box-shadow:0 0 12px #d4a3534d}.cc-action-gold:hover{background:var(--accent-warm-dim)}.cc-action-sent{opacity:.6;cursor:default;box-shadow:none}.cc-action-sent:hover{background:var(--accent-warm)}.cc-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--space-lg)}.cc-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.cc-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg) var(--space-xl);border-bottom:1px solid var(--border-subtle)}.cc-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.cc-close{background:none;border:none;color:var(--text-dim);font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.cc-close:hover{color:var(--text-muted)}.cc-body{padding:var(--space-xl);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-sm)}.cc-label{font-size:var(--font-sm);color:var(--text-muted);margin-top:var(--space-sm)}.cc-input{width:100%;padding:10px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:var(--font-base);outline:none;box-sizing:border-box}.cc-input:focus{border-color:var(--accent-primary)}.cc-input::-moz-placeholder{color:var(--text-dim)}.cc-input::placeholder{color:var(--text-dim)}.cc-input-custom{margin-top:var(--space-xs)}.cc-pronoun-row{display:flex;gap:var(--space-sm);flex-wrap:wrap}.cc-pronoun-btn{padding:8px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);font-size:var(--font-sm);cursor:pointer;transition:all .15s}.cc-pronoun-btn:hover{border-color:var(--accent-primary-dim);color:var(--text-primary)}.cc-pronoun-active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-base);font-weight:500}.cc-pronoun-active:hover{background:var(--accent-primary-bright);border-color:var(--accent-primary-bright);color:var(--bg-base)}.cc-filter-row{display:flex;gap:var(--space-lg);flex-wrap:wrap}.cc-filter-group{display:flex;gap:2px;background:var(--bg-elevated);border-radius:6px;overflow:hidden}.cc-filter-btn{padding:5px 10px;background:transparent;border:none;color:var(--text-dim);font-size:var(--font-xs);cursor:pointer;transition:all .15s}.cc-filter-btn:hover{color:var(--text-muted);background:var(--bg-hover)}.cc-filter-active{background:var(--bg-hover);color:var(--accent-primary-bright)}.cc-portrait-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);margin-top:var(--space-xs)}.cc-portrait-btn{position:relative;aspect-ratio:1;border:2px solid var(--border);border-radius:10px;overflow:hidden;cursor:pointer;padding:0;background:var(--bg-elevated);transition:border-color .15s,transform .1s}.cc-portrait-btn:hover{border-color:var(--accent-primary-dim);transform:scale(1.03)}.cc-portrait-selected{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-primary-dim)}.cc-portrait-img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.cc-no-results{grid-column:1 / -1;text-align:center;color:var(--text-dim);font-size:var(--font-sm);padding:var(--space-xl) 0}.cc-divider{height:1px;background:var(--border-subtle);margin:var(--space-md) 0}.cc-textarea{width:100%;padding:10px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:var(--font-base);font-family:inherit;outline:none;box-sizing:border-box;resize:vertical;min-height:60px}.cc-textarea:focus{border-color:var(--accent-primary)}.cc-textarea::-moz-placeholder{color:var(--text-dim)}.cc-textarea::placeholder{color:var(--text-dim)}.cc-char-count{float:right;font-size:var(--font-xs);color:var(--text-dim);font-weight:400}.cc-chip-row{display:flex;gap:var(--space-sm);flex-wrap:wrap}.cc-chip{padding:6px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:20px;color:var(--text-muted);font-size:var(--font-sm);cursor:pointer;transition:all .15s}.cc-chip:hover{border-color:var(--accent-primary-dim);color:var(--text-primary)}.cc-chip-active{background:var(--accent-primary);border-color:var(--accent-primary);color:var(--bg-base);font-weight:500}.cc-chip-active:hover{background:var(--accent-primary-bright);border-color:var(--accent-primary-bright);color:var(--bg-base)}.cc-select{width:100%;padding:10px 14px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:var(--font-base);outline:none;box-sizing:border-box;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238892a8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.cc-select:focus{border-color:var(--accent-primary)}.cc-select option{background:var(--bg-card);color:var(--text-primary)}.cc-error{padding:10px;background:#dc50501a;border:1px solid rgba(220,80,80,.3);border-radius:8px;color:#dc5050;font-size:var(--font-sm)}.cc-actions{display:flex;gap:var(--space-sm);justify-content:flex-end;margin-top:var(--space-md)}.cc-btn-primary{padding:10px 24px;background:var(--accent-primary);border:none;border-radius:8px;color:var(--bg-base);font-weight:600;font-size:var(--font-md);cursor:pointer;transition:background .15s}.cc-btn-primary:hover:not(:disabled){background:var(--accent-primary-bright)}.cc-btn-primary:disabled{opacity:.5;cursor:default}.cc-btn-secondary{padding:10px 24px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);font-size:var(--font-md);cursor:pointer;transition:all .15s}.cc-btn-secondary:hover:not(:disabled){border-color:var(--accent-primary-dim);color:var(--text-primary)}.home{max-width:var(--max-content-width);margin:0 auto;padding:2rem 1.5rem}.home-welcome{text-align:center;padding:2.5rem 1rem 2rem;margin-bottom:1rem}.home-greeting{font-family:Playfair Display,Georgia,serif;font-size:1.75rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem}.home-name{color:var(--accent-warm)}.home-subtitle{font-size:13px;color:var(--text-muted);margin-top:.5rem}.home-cta{margin-top:1.25rem;padding:.65rem 1.5rem;background:var(--accent-warm);border:none;border-radius:8px;color:var(--bg-base);font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s;box-shadow:0 0 16px #d4a3534d}.home-cta:hover{background:var(--accent-warm-bright)}.home-gentle-prompt{text-align:center;padding:1.5rem 1rem;margin-bottom:1rem;color:var(--text-muted);font-size:.9rem}.home-section{margin-bottom:2rem}.home-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.home-section-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim)}.home-section-link{font-size:.75rem;color:var(--accent-primary);text-decoration:none;cursor:pointer;transition:color .15s}.home-section-link:hover{color:var(--accent-primary-bright)}.home-scroll-row{display:flex;gap:1rem;overflow-x:auto;padding-bottom:.5rem;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.home-scroll-row::-webkit-scrollbar{height:6px}.home-scroll-row::-webkit-scrollbar-track{background:transparent}.home-scroll-row::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.home-card-wrap{flex:0 0 auto}.home-card-landscape{width:300px}.home-card-portrait{width:185px}.home-sess-card{flex:0 0 280px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s}.home-sess-card:hover{border-color:var(--accent-primary);transform:translateY(-2px)}.home-sess-image{width:100%;aspect-ratio:4/3;background:var(--bg-elevated);position:relative}.home-sess-menu-btn{position:absolute;top:.5rem;right:.5rem;width:28px;height:28px;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:none;border-radius:6px;color:var(--text-primary);font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s}.home-sess-card:hover .home-sess-menu-btn{opacity:1}.home-sess-menu{position:absolute;top:2.25rem;right:.5rem;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;padding:.25rem;z-index:10;min-width:120px}.home-sess-menu-item{display:block;width:100%;padding:.45rem .6rem;background:none;border:none;border-radius:4px;color:var(--text-muted);font-family:inherit;font-size:.75rem;text-align:left;cursor:pointer;transition:all .15s}.home-sess-menu-item:hover{background:var(--bg-elevated);color:#e05555}.home-sess-info{padding:.75rem}.home-sess-title{font-size:.95rem;font-weight:600;margin-bottom:.2rem}.home-sess-meta{font-size:.75rem;color:var(--text-muted);margin-bottom:.35rem}.home-sess-partner{display:flex;align-items:center;gap:.35rem;font-size:.75rem;color:var(--text-dim);margin-bottom:.65rem}.home-sess-partner.online{color:var(--accent-warm)}.home-sess-dot{width:6px;height:6px;background:var(--accent-warm);border-radius:50%}.home-sess-btn{width:100%;padding:.5rem;background:var(--accent-warm);border:none;border-radius:6px;color:var(--bg-base);font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s;box-shadow:0 0 12px #d4a35333}.home-sess-btn:hover{background:var(--accent-warm-bright)}.home-invite-card{flex:0 0 280px;display:flex;flex-direction:column;padding:1rem;background:var(--bg-card);border:1px solid var(--accent-primary-dim);border-radius:12px;transition:border-color .2s,box-shadow .2s;position:relative}.home-invite-card:hover{border-color:var(--accent-primary);box-shadow:0 4px 20px #6b7fa826}.home-invite-badge{font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--accent-primary-bright);background:var(--accent-primary-dim);padding:2px 6px;border-radius:3px;display:inline-block;margin-bottom:.75rem;align-self:flex-start}.home-invite-portraits{display:flex;align-items:flex-end;margin-bottom:.75rem;position:relative;height:56px}.home-invite-from-portrait{width:52px;height:52px;border-radius:50%;background:var(--bg-elevated);border:2px solid var(--accent-primary-dim);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--text-dim);overflow:hidden;z-index:1}.home-invite-from-portrait img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.home-invite-to-portrait{width:32px;height:32px;border-radius:50%;background:var(--bg-elevated);border:2px solid var(--accent-warm-dim);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--text-dim);overflow:hidden;margin-left:-10px}.home-invite-to-portrait img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.home-invite-body{flex:1;min-width:0;margin-bottom:.75rem}.home-invite-name{font-size:.95rem;font-weight:600;color:var(--text-primary)}.home-invite-pronouns{font-size:var(--font-xs);color:var(--text-dim);margin-bottom:.25rem}.home-invite-target{font-size:.75rem;color:var(--text-muted);margin-top:.15rem}.home-invite-target strong{color:var(--accent-warm);font-weight:600}.home-invite-tags{display:flex;gap:.25rem;margin-top:.4rem;flex-wrap:wrap}.home-invite-tag{padding:1px 6px;background:var(--bg-elevated);border-radius:3px;font-size:.65rem;color:var(--text-muted)}.home-invite-actions{display:flex;gap:.5rem}.home-invite-accept{flex:1;padding:.5rem .75rem;background:var(--accent-primary);border:none;border-radius:6px;color:#fff;font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.home-invite-accept:hover{background:var(--accent-primary-bright)}.home-invite-pass{padding:.5rem .75rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-family:inherit;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.home-invite-pass:hover{border-color:var(--text-dim);color:var(--text-primary)}.home-match-card{flex:0 0 260px;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;transition:border-color .15s}.home-match-card:hover{border-color:var(--accent-warm-dim)}.home-match-card .home-invite-portrait{width:44px;height:44px;border-radius:50%;background:var(--bg-elevated);border:2px solid var(--accent-warm-dim);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--text-dim);overflow:hidden}.home-match-card .home-invite-portrait img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.home-match-card .home-invite-info{flex:1;min-width:0}.home-match-card .home-invite-name{font-size:var(--font-md);font-weight:500;color:var(--text-primary)}.home-match-card .home-invite-pronouns{font-size:var(--font-xs);color:var(--text-dim)}.home-match-play{padding:.35rem .65rem;background:var(--accent-warm);border:none;border-radius:6px;color:var(--bg-base);font-family:inherit;font-size:.75rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s;flex-shrink:0}.home-match-play:hover{background:var(--accent-warm-bright)}.home-create-char{cursor:pointer}.home-create-char-inner{background:var(--bg-card);border:2px dashed var(--border);border-radius:12px;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 1rem;transition:border-color .15s}.home-create-char:hover .home-create-char-inner{border-color:var(--accent-primary-dim)}.home-create-char-portrait{width:64px;height:64px;border-radius:50%;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;color:var(--text-dim);margin-bottom:.75rem}.home-create-char-label{font-size:var(--font-md);font-weight:500;color:var(--accent-primary)}.home-dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:500}.home-dialog{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;max-width:360px;width:90%}.home-dialog-text{font-size:.9rem;color:var(--text-primary);margin-bottom:1.25rem;text-align:center}.home-dialog-actions{display:flex;gap:.5rem;justify-content:center}.home-dialog-cancel{padding:.5rem 1rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:6px;color:var(--text-muted);font-family:inherit;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .15s}.home-dialog-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.home-dialog-confirm{padding:.5rem 1rem;background:#c0392b;border:none;border-radius:6px;color:#fff;font-family:inherit;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s}.home-dialog-confirm:hover{background:#e74c3c}.worlds-layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:calc(100vh - var(--header-height))}.worlds-layout.worlds-sidebar-hidden{grid-template-columns:0 1fr}.worlds-sidebar{background:var(--bg-card);border-right:1px solid var(--border-subtle);padding:.75rem;overflow-y:auto;position:relative;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.worlds-sidebar.collapsed{padding:0;width:0;overflow:visible;border:none}.worlds-sidebar::-webkit-scrollbar{width:4px}.worlds-sidebar::-webkit-scrollbar-track{background:transparent}.worlds-sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.worlds-sidebar-collapse{position:absolute;top:.75rem;right:-1px;width:20px;height:32px;background:var(--bg-card);border:1px solid var(--border-subtle);border-right:none;border-radius:4px 0 0 4px;color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:color .15s,background .15s}.worlds-sidebar-collapse:hover{color:var(--text-muted);background:var(--bg-elevated)}.worlds-sidebar.collapsed .worlds-sidebar-collapse{right:-21px;border-right:1px solid var(--border-subtle);border-left:none;border-radius:0 4px 4px 0}.worlds-sidebar.collapsed .worlds-sidebar-collapse svg{transform:rotate(180deg)}.worlds-sidebar-top{display:flex;justify-content:flex-end;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-subtle)}.worlds-collapse-all{background:none;border:none;color:var(--text-dim);font-family:inherit;font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:color .15s;padding:.2rem .25rem}.worlds-collapse-all:hover{color:var(--text-muted)}.worlds-filter-group{margin-bottom:.75rem}.worlds-filter-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.4rem .25rem;background:none;border:none;font-family:inherit;font-size:.7rem;font-weight:600;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;cursor:pointer;transition:color .15s}.worlds-filter-header:hover{color:var(--text-primary)}.worlds-filter-arrow{font-size:.65rem;transition:transform .15s}.worlds-filter-arrow.collapsed{transform:rotate(-90deg)}.worlds-filter-list{display:flex;flex-direction:column;gap:.15rem;padding-left:.15rem}.worlds-filter-item{display:flex;align-items:center;gap:.4rem;padding:.3rem .25rem;border-radius:4px;cursor:pointer;transition:background .1s}.worlds-filter-item:hover{background:var(--bg-elevated)}.worlds-filter-stubbed{opacity:.45;cursor:default}.worlds-filter-stubbed:hover{background:transparent}.worlds-filter-checkbox{width:14px;height:14px;accent-color:var(--accent-primary);flex-shrink:0}.worlds-filter-label{font-size:.75rem;color:var(--text-muted)}.worlds-soon-badge{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:1px 4px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:3px;color:var(--text-dim);margin-left:auto}.worlds-content{padding:1.25rem;overflow-y:auto}.worlds-content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.worlds-count{font-size:.75rem;color:var(--text-muted)}.worlds-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.worlds-empty{text-align:center;padding:3rem 1rem;color:var(--text-dim);font-size:.9rem}@media (max-width: 768px){.worlds-layout{grid-template-columns:1fr}.worlds-sidebar{display:none}}.chars-layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:calc(100vh - var(--header-height))}.chars-layout.chars-sidebar-hidden{grid-template-columns:0 1fr}.chars-sidebar{background:var(--bg-card);border-right:1px solid var(--border-subtle);padding:.75rem;overflow-y:auto;position:relative;scrollbar-width:thin;scrollbar-color:var(--border) transparent}.chars-sidebar.collapsed{padding:0;width:0;overflow:visible;border:none}.chars-sidebar::-webkit-scrollbar{width:4px}.chars-sidebar::-webkit-scrollbar-track{background:transparent}.chars-sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.chars-sidebar-collapse{position:absolute;top:.75rem;right:-1px;width:20px;height:32px;background:var(--bg-card);border:1px solid var(--border-subtle);border-right:none;border-radius:4px 0 0 4px;color:var(--text-dim);cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:color .15s,background .15s}.chars-sidebar-collapse:hover{color:var(--text-muted);background:var(--bg-elevated)}.chars-sidebar.collapsed .chars-sidebar-collapse{right:-21px;border-right:1px solid var(--border-subtle);border-left:none;border-radius:0 4px 4px 0}.chars-sidebar.collapsed .chars-sidebar-collapse svg{transform:rotate(180deg)}.chars-sidebar-top{display:flex;justify-content:flex-end;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid var(--border-subtle)}.chars-collapse-all{background:none;border:none;color:var(--text-dim);font-family:inherit;font-size:.65rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;transition:color .15s;padding:.2rem .25rem}.chars-collapse-all:hover{color:var(--text-muted)}.chars-filter-group{margin-bottom:.75rem}.chars-filter-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.4rem .25rem;background:none;border:none;font-family:inherit;font-size:.7rem;font-weight:600;letter-spacing:.08em;color:var(--text-muted);text-transform:uppercase;cursor:pointer;transition:color .15s}.chars-filter-header:hover{color:var(--text-primary)}.chars-filter-arrow{font-size:.65rem;transition:transform .15s}.chars-filter-arrow.collapsed{transform:rotate(-90deg)}.chars-filter-list{display:flex;flex-direction:column;gap:.15rem;padding-left:.15rem}.chars-filter-item{display:flex;align-items:center;gap:.4rem;padding:.3rem .25rem;border-radius:4px;cursor:pointer;transition:background .1s}.chars-filter-item:hover{background:var(--bg-elevated)}.chars-filter-stubbed{opacity:.45;cursor:default}.chars-filter-stubbed:hover{background:transparent}.chars-filter-checkbox{width:14px;height:14px;accent-color:var(--accent-primary);flex-shrink:0}.chars-filter-label{font-size:.75rem;color:var(--text-muted)}.chars-soon-badge{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:1px 4px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:3px;color:var(--text-dim);margin-left:auto}.chars-content{padding:1.25rem;overflow-y:auto}.chars-content-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.chars-count{font-size:.75rem;color:var(--text-muted)}.chars-row-section{margin-bottom:1.75rem}.chars-row-header{margin-bottom:.6rem}.chars-row-title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim)}.chars-your-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.chars-own-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;overflow:hidden;transition:all .2s;display:flex;flex-direction:column}.chars-own-card:hover{border-color:var(--accent-primary-dim)}.chars-own-active{border-color:var(--accent-warm-dim)}.chars-own-portrait{width:100%;aspect-ratio:3/4;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;color:var(--text-dim);overflow:hidden}.chars-own-portrait-empty{border-bottom:1px dashed var(--border)}.chars-own-info{padding:.5rem .6rem;text-align:center}.chars-own-name{font-size:var(--font-md);font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chars-own-pronouns{font-size:var(--font-xs);color:var(--text-dim);margin-bottom:.25rem}.chars-own-badge{display:inline-block;font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:1px 5px;border:1px solid var(--accent-warm);color:var(--accent-warm);border-radius:3px;margin-bottom:.25rem}.chars-own-actions{margin-top:.35rem}.chars-own-edit,.chars-own-select{padding:.3rem .6rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:5px;color:var(--text-muted);font-family:inherit;font-size:.7rem;font-weight:500;cursor:pointer;transition:all .15s}.chars-own-edit:hover,.chars-own-select:hover{background:var(--bg-hover);color:var(--text-primary)}.chars-own-create{border-style:dashed;cursor:pointer}.chars-own-create:hover{border-color:var(--accent-primary)}.chars-own-create-label{color:var(--accent-primary)}.chars-own-upgrade{display:flex;align-items:center;justify-content:center;opacity:.6}.chars-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.chars-empty{text-align:center;padding:3rem 1rem;color:var(--text-dim);font-size:.9rem}@media (max-width: 768px){.chars-layout{grid-template-columns:1fr}.chars-sidebar{display:none}}.sl-loading{display:flex;align-items:center;justify-content:center;min-height:50vh;color:var(--text-muted)}.sl-overlay{display:flex;align-items:center;justify-content:center;padding:2rem;min-height:calc(100vh - var(--header-height))}.sl-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:600px}.sl-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-subtle)}.sl-title{font-size:1.1rem;font-weight:600}.sl-close{width:32px;height:32px;border-radius:8px;background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-muted);font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.sl-close:hover{border-color:var(--accent-primary);color:var(--text-primary)}.sl-body{padding:1.5rem}.sl-preview{display:grid;grid-template-columns:160px 1fr;gap:1.25rem;margin-bottom:1.25rem}.sl-preview-image{aspect-ratio:16/10;border-radius:10px;overflow:hidden;background:var(--bg-elevated)}.sl-preview-info h2{font-size:1.1rem;font-weight:600;margin-bottom:.25rem}.sl-preview-info p{font-size:.8rem;color:var(--text-muted);line-height:1.4;margin-bottom:.5rem}.sl-preview-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.5rem}.sl-preview-tag{padding:.2rem .45rem;background:#252a38;border-radius:4px;font-size:.7rem;color:var(--text-muted)}.sl-preview-meta{display:flex;gap:1rem;font-size:.75rem;color:var(--text-muted)}.sl-divider{height:1px;background:var(--border-subtle);margin:1.25rem 0}.sl-section-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim);margin-bottom:.6rem}.sl-session-types{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;margin-bottom:1.25rem}.sl-type{padding:.6rem .5rem;background:var(--bg-elevated);border:2px solid var(--border);border-radius:8px;text-align:center;cursor:pointer;transition:all .15s;font-family:inherit;color:var(--text-primary)}.sl-type:hover{border-color:var(--accent-primary);background:#6b7fa814}.sl-type-selected{border-color:var(--accent-primary);background:#6b7fa81f}.sl-type-icon{margin:0 auto .25rem}.sl-type-icon-solo{color:#9a7acd}.sl-type-icon-private{color:var(--accent-warm)}.sl-type-icon-public{color:#5a9acf}.sl-type-label{font-size:.8rem;font-weight:600;margin-bottom:.1rem}.sl-type-desc{font-size:.65rem;color:var(--text-dim)}.sl-party{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.25rem}.sl-party-slot{padding:.75rem;background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;display:flex;align-items:center;gap:.75rem}.sl-party-you{border-color:var(--accent-warm-dim);background:#d4a35314}.sl-party-avatar{width:44px;height:44px;border-radius:8px;background:var(--bg-hover);flex-shrink:0}.sl-party-name{font-size:.85rem;font-weight:600;margin-bottom:.1rem}.sl-party-name-you{color:var(--accent-warm)}.sl-party-status{font-size:.7rem;color:var(--text-dim)}.sl-party-empty{flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}.sl-party-empty:hover{border-color:var(--accent-primary);background:#6b7fa80f}.sl-party-add-icon{width:44px;height:44px;border-radius:50%;background:var(--bg-hover);border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-dim)}.sl-party-add-label{font-size:.75rem;color:var(--text-dim);margin-top:.5rem}.sl-party-no-ai{border-style:dashed;border-color:var(--border);opacity:.6;cursor:default}.sl-party-no-ai:hover{border-color:var(--border);background:var(--bg-elevated)}.sl-party-companion{border-color:var(--accent-primary);background:#6b7fa814}.sl-party-avatar-companion{background:var(--bg-hover);border-radius:8px}.sl-party-name-companion{color:var(--accent-primary-bright)}.sl-type-disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.sl-type-soon{font-size:.6rem;color:var(--text-dim);margin-top:.15rem;font-style:italic}.sl-ai-toggle{display:flex;align-items:center;gap:.5rem;margin-bottom:1.25rem;cursor:pointer;font-size:.8rem;color:var(--text-secondary)}.sl-ai-toggle input[type=checkbox]{accent-color:var(--accent-primary);width:16px;height:16px;cursor:pointer}.sl-ai-toggle-label{font-weight:500}.sl-ai-toggle-name{color:var(--text-dim);font-size:.75rem}.sl-error{color:#cf6f6f;font-size:.8rem;margin-bottom:1rem;padding:.5rem .75rem;background:#cf6f6f1a;border-radius:6px}.sl-start-btn{width:100%;padding:.85rem 1rem;border-radius:8px;background:var(--accent-warm);border:1px solid var(--accent-warm);color:var(--bg-base);font-family:inherit;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s;box-shadow:0 0 16px #d4a35340}.sl-start-btn:hover{background:var(--accent-warm-bright);border-color:var(--accent-warm-bright)}.sl-start-disabled{opacity:.6;cursor:not-allowed}.sl-start-disabled:hover{background:var(--accent-warm);border-color:var(--accent-warm)}.sl-party-clickable{cursor:pointer;transition:border-color .15s;position:relative}.sl-party-clickable:hover{border-color:var(--accent-primary-dim)}.sl-party-edit-hint{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--text-dim);opacity:0;transition:opacity .15s}.sl-party-clickable:hover .sl-party-edit-hint{opacity:1}@media (max-width: 600px){.sl-preview{grid-template-columns:1fr}}.psm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.psm-modal{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:2rem;max-width:400px;width:100%;text-align:center;animation:psm-pop .4s cubic-bezier(.34,1.56,.64,1)}@keyframes psm-pop{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.psm-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem}.psm-portrait{width:96px;height:96px;border-radius:16px;background:var(--bg-elevated);border:3px solid var(--accent-warm);box-shadow:0 0 30px #d4a35340;display:flex;align-items:center;justify-content:center;color:var(--text-dim);overflow:hidden;margin:0 auto .5rem}.psm-portrait img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.psm-partner-name{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem}.psm-partner-name:has(+.psm-partner-pronouns){margin-bottom:.25rem}.psm-partner-pronouns{font-size:.75rem;color:var(--text-dim);margin-bottom:1.5rem}.psm-buttons{display:flex;gap:1rem;justify-content:center;margin-bottom:1rem}.psm-btn{width:72px;height:72px;border-radius:16px;border:2px solid var(--border);background:var(--bg-elevated);cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;color:var(--text-muted);font-family:inherit;font-size:.7rem}.psm-btn svg{width:28px;height:28px;transition:all .2s}.psm-btn:hover{border-color:var(--accent-primary-dim);background:var(--bg-hover);color:var(--text-primary)}.psm-btn-heart:hover{border-color:#c06070;color:#e07080}.psm-btn-heart:hover svg{fill:#e07080;stroke:#e07080}.psm-btn-star:hover{border-color:var(--accent-warm-dim);color:var(--accent-warm)}.psm-btn-star:hover svg{fill:var(--accent-warm);stroke:var(--accent-warm)}.psm-btn-skip:hover{border-color:var(--text-dim)}.psm-btn-label{font-size:.65rem;text-transform:uppercase;letter-spacing:.05em}.psm-waiting{color:var(--text-muted);font-size:.9rem;padding:1rem 0;animation:psm-waiting-pulse 2s ease-in-out infinite}@keyframes psm-waiting-pulse{0%,to{opacity:.6}50%{opacity:1}}.psm-waiting-dots:after{content:"";animation:psm-dots 1.5s infinite}@keyframes psm-dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}.psm-result{padding:1rem 0}.psm-result-icon{font-size:2rem;margin-bottom:.75rem}.psm-result-mutual{position:relative;overflow:hidden}.psm-result-mutual .psm-result-icon{animation:psm-heart-bounce .6s cubic-bezier(.34,1.56,.64,1),psm-heart-glow 2s ease-in-out .6s infinite}@keyframes psm-heart-bounce{0%{transform:scale(.3);opacity:0}60%{transform:scale(1.3);opacity:1}to{transform:scale(1);opacity:1}}@keyframes psm-heart-glow{0%,to{filter:brightness(1) drop-shadow(0 0 0 transparent)}50%{filter:brightness(1.2) drop-shadow(0 0 12px rgba(224,112,128,.5))}}.psm-result-mutual:before,.psm-result-mutual:after{content:"";position:absolute;width:8px;height:8px;border-radius:50%;animation:psm-confetti-l 2.5s ease-out forwards;pointer-events:none}.psm-result-mutual:before{background:var(--accent-warm);left:30%;top:20%}.psm-result-mutual:after{background:var(--accent-primary-bright);right:30%;top:20%;animation-name:psm-confetti-r;animation-delay:.15s}@keyframes psm-confetti-l{0%{transform:translate(0) scale(0);opacity:0}20%{transform:translate(-20px,-10px) scale(1);opacity:1}to{transform:translate(-40px,80px) rotate(360deg) scale(0);opacity:0}}@keyframes psm-confetti-r{0%{transform:translate(0) scale(0);opacity:0}20%{transform:translate(20px,-10px) scale(1);opacity:1}to{transform:translate(40px,80px) rotate(-360deg) scale(0);opacity:0}}.psm-result-mutual .psm-result-text{color:#e07080;font-weight:600}.psm-result-friends .psm-result-icon{animation:psm-star-glow 2s ease-in-out infinite}@keyframes psm-star-glow{0%,to{filter:brightness(1)}50%{filter:brightness(1.2) drop-shadow(0 0 8px rgba(212,163,83,.4))}}.psm-result-friends .psm-result-text{color:var(--accent-warm)}.psm-result-text{font-size:1rem;color:var(--text-primary);margin-bottom:.5rem;font-weight:500}.psm-result-sub{font-size:.8rem;color:var(--text-muted);margin-bottom:1.25rem}.psm-done-btn{padding:.65rem 2rem;border:none;border-radius:10px;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;background:var(--accent-warm);color:#0a0b0e;transition:all .15s;box-shadow:0 0 24px #d4a35340}.psm-done-btn:hover{background:var(--accent-warm-bright);transform:translateY(-1px)}@media (max-width: 400px){.psm-modal{padding:1.25rem}.psm-btn{width:64px;height:64px}}:root{--bg-base: #0a0b0e;--bg-card: #111318;--bg-elevated: #191c22;--bg-hover: #21252e;--accent-primary: #6b7fa8;--accent-primary-bright: #8da0cc;--accent-primary-dim: #566a8f;--accent-warm: #d4a353;--accent-warm-bright: #e8b968;--accent-warm-dim: #b8893f;--accent-success: #5bb98c;--action-blue: #5580b8;--text-primary: #eaeef4;--text-muted: #8892a8;--text-dim: #515970;--border: #2a3040;--border-subtle: #1e222c;--genre-survival: #4a8c5c;--genre-romance: #b86a7a;--genre-horror: #7a6b9a;--genre-scifi: #4a8a9a;--genre-fantasy: #8a6a9a;--genre-combat: #b87a4a;--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem;--font-xs: .75rem;--font-sm: .8125rem;--font-md: .875rem;--font-base: 1rem;--font-lg: 1.0625rem;--sidebar-width: 200px;--header-height: 56px;--touch-target: 40px;--max-content-width: 1200px}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--font-mono);font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.pointer-events-none{pointer-events:none}.visible{visibility:visible}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{top:0;right:0;bottom:0;left:0}.left-1\/2{left:50%}.right-0{right:0}.right-2{right:.5rem}.top-0{top:0}.top-16{top:4rem}.top-2{top:.5rem}.top-full{top:100%}.z-50{z-index:50}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.mx-lg-std{margin-left:var(--space-lg);margin-right:var(--space-lg)}.my-md-std{margin-top:var(--space-md);margin-bottom:var(--space-md)}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-4{margin-bottom:1rem}.mb-8{margin-bottom:2rem}.mb-lg-std{margin-bottom:var(--space-lg)}.mb-md-std{margin-bottom:var(--space-md)}.mb-sm-std{margin-bottom:var(--space-sm)}.mb-xs-std{margin-bottom:var(--space-xs)}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}.mr-sm-std{margin-right:var(--space-sm)}.mt-1{margin-top:.25rem}.mt-3{margin-top:.75rem}.mt-lg-std{margin-top:var(--space-lg)}.mt-md-std{margin-top:var(--space-md)}.mt-sm-std{margin-top:var(--space-sm)}.block{display:block}.inline{display:inline}.flex{display:flex}.grid{display:grid}.aspect-square{aspect-ratio:1 / 1}.aspect-video{aspect-ratio:16 / 9}.h-2{height:.5rem}.h-3{height:.75rem}.h-4{height:1rem}.h-40{height:10rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-\[10px\]{height:10px}.h-\[18px\]{height:18px}.h-full{height:100%}.h-header{height:var(--header-height)}.h-screen{height:100vh}.h-touch{height:var(--touch-target)}.max-h-\[80vh\]{max-height:80vh}.min-h-\[44px\]{min-height:44px}.min-h-screen{min-height:100vh}.min-h-touch{min-height:var(--touch-target)}.w-12{width:3rem}.w-16{width:4rem}.w-2{width:.5rem}.w-3{width:.75rem}.w-4{width:1rem}.w-56{width:14rem}.w-6{width:1.5rem}.w-8{width:2rem}.w-\[10px\]{width:10px}.w-\[18px\]{width:18px}.w-\[320px\]{width:320px}.w-full{width:100%}.w-screen{width:100vw}.w-touch{width:var(--touch-target)}.min-w-0{min-width:0px}.min-w-\[60px\]{min-width:60px}.max-w-2xl{max-width:42rem}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-x-1\/2{--tw-translate-x: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.cursor-pointer{cursor:pointer}.list-inside{list-style-position:inside}.list-decimal{list-style-type:decimal}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-md-std{gap:var(--space-md)}.gap-sm-std{gap:var(--space-sm)}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-md-std>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(var(--space-md) * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(var(--space-md) * var(--tw-space-y-reverse))}.space-y-sm-std>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(var(--space-sm) * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(var(--space-sm) * var(--tw-space-y-reverse))}.space-y-xs-std>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(var(--space-xs) * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(var(--space-xs) * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-pre-wrap{white-space:pre-wrap}.rounded{border-radius:.25rem}.rounded-\[10px\]{border-radius:10px}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-l{border-left-width:1px}.border-l-\[3px\]{border-left-width:3px}.border-r{border-right-width:1px}.border-t{border-top-width:1px}.border-accent-primary{border-color:var(--accent-primary)}.border-accent-primary-dim{border-color:var(--accent-primary-dim)}.border-bg-elevated{border-color:var(--bg-elevated)}.border-border{border-color:var(--border)}.border-border-subtle{border-color:var(--border-subtle)}.border-char1{border-color:var(--char1)}.border-npc-bright{border-color:var(--color-npc)}.border-text-dim{border-color:var(--text-dim)}.bg-\[rgba\(168\,160\,176\,0\.05\)\]{background-color:#a8a0b00d}.bg-accent-primary{background-color:var(--accent-primary)}.bg-accent-secondary{background-color:var(--accent-secondary)}.bg-bg-base{background-color:var(--bg-base)}.bg-bg-card{background-color:var(--bg-card)}.bg-bg-elevated{background-color:var(--bg-elevated)}.bg-bg-hover{background-color:var(--bg-hover)}.bg-black\/50{background-color:#00000080}.bg-black\/60{background-color:#0009}.bg-danger{background-color:var(--danger)}.bg-success{background-color:var(--success)}.bg-text-dim{background-color:var(--text-dim)}.bg-transparent{background-color:transparent}.bg-warning{background-color:var(--warning)}.bg-gradient-to-b{background-image:linear-gradient(to bottom,var(--tw-gradient-stops))}.from-bg-card{--tw-gradient-from: var(--bg-card) var(--tw-gradient-from-position);--tw-gradient-to: rgb(255 255 255 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.to-bg-base{--tw-gradient-to: var(--bg-base) var(--tw-gradient-to-position)}.to-transparent{--tw-gradient-to: transparent var(--tw-gradient-to-position)}.fill-none{fill:none}.stroke-current{stroke:currentColor}.stroke-2{stroke-width:2}.object-cover{-o-object-fit:cover;object-fit:cover}.object-\[50\%_15\%\]{-o-object-position:50% 15%;object-position:50% 15%}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-8{padding:2rem}.p-lg-std{padding:var(--space-lg)}.p-md-std{padding:var(--space-md)}.p-xl-std{padding:var(--space-xl)}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-4{padding-left:1rem;padding-right:1rem}.px-\[0\.625rem\]{padding-left:.625rem;padding-right:.625rem}.px-lg-std{padding-left:var(--space-lg);padding-right:var(--space-lg)}.px-md-std{padding-left:var(--space-md);padding-right:var(--space-md)}.px-xl-std{padding-left:var(--space-xl);padding-right:var(--space-xl)}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-md-std{padding-top:var(--space-md);padding-bottom:var(--space-md)}.py-sm-std{padding-top:var(--space-sm);padding-bottom:var(--space-sm)}.py-xl-std{padding-top:var(--space-xl);padding-bottom:var(--space-xl)}.pb-lg-std{padding-bottom:var(--space-lg)}.pl-md-std{padding-left:var(--space-md)}.text-left{text-align:left}.text-center{text-align:center}.font-display{font-family:var(--font-display)}.font-mono{font-family:var(--font-mono)}.font-ui{font-family:var(--font-ui)}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-\[0\.9375rem\]{font-size:.9375rem}.text-\[10px\]{font-size:10px}.text-base-std{font-size:var(--font-base);line-height:1.75}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-lg-std{font-size:var(--font-lg);line-height:1.75}.text-md-std{font-size:var(--font-md);line-height:1.5}.text-sm{font-size:.875rem;line-height:1.25rem}.text-sm-std{font-size:var(--font-sm);line-height:1.5}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.text-xs-std{font-size:var(--font-xs);line-height:1.5}.font-\[450\]{font-weight:450}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-\[1\.75\]{line-height:1.75}.leading-\[1\.7\]{line-height:1.7}.tracking-\[0\.05em\]{letter-spacing:.05em}.tracking-\[0\.1em\]{letter-spacing:.1em}.tracking-wide{letter-spacing:.025em}.text-accent-primary{color:var(--accent-primary)}.text-accent-secondary{color:var(--accent-secondary)}.text-bg-base{color:var(--bg-base)}.text-char1{color:var(--char1)}.text-char2{color:var(--char2)}.text-danger{color:var(--danger)}.text-item{color:var(--item)}.text-npc-bright{color:var(--color-npc)}.text-npc-dim{color:var(--color-npc-dim)}.text-room{color:var(--room)}.text-success{color:var(--success)}.text-text-dim{color:var(--text-dim)}.text-text-muted{color:var(--text-muted)}.text-text-primary{color:var(--text-primary)}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.opacity-0{opacity:0}.opacity-100{opacity:1}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-xl{--tw-shadow: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--tw-shadow-colored: 0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-\[grid-template-columns\]{transition-property:grid-template-columns;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}:root{--space-xs: .25rem;--space-sm: .5rem;--space-md: .75rem;--space-lg: 1rem;--space-xl: 1.5rem;--font-xs: .75rem;--font-sm: .8125rem;--font-md: .875rem;--font-base: 1rem;--font-lg: 1.0625rem;--sidebar-left: 220px;--sidebar-right: 300px;--header-height: 56px;--touch-target: 40px;--bg-base: #0f1419;--bg-card: #1a1f2e;--bg-elevated: #1e232e;--bg-hover: #252a38;--text-primary: #e2e8f0;--text-muted: #9ca3af;--text-dim: #6b7280;--border: #2a2f3a;--border-subtle: #1a1e28;--color-storm: #5888C8;--color-storm-dim: #7098C0;--color-teal: #50C0A8;--color-teal-dim: #68B0A0;--color-evergreen: #509878;--color-evergreen-dim: #609880;--color-sage: #80C8A0;--color-sage-dim: #78B898;--color-khaki: #98A860;--color-khaki-dim: #909868;--color-violet: #9080D8;--color-violet-dim: #8880C0;--color-orchid: #B870B8;--color-orchid-dim: #A878B0;--color-rose: #E0A8B8;--color-rose-dim: #C8A0A8;--color-burgundy: #C87080;--color-burgundy-dim: #B07880;--color-ember: #D87048;--color-ember-dim: #C07858;--color-rust: #C8A078;--color-rust-dim: #B09070;--color-npc: #7EB8E0;--color-npc-dim: #6899B8;--system-grey: #6b7280;--ooc-tag: #9098a0;--admin-color: #e0a040;--admin-bg: rgba(224, 160, 64, .12);--accent-primary: #d4af37;--accent-primary-bright: #f4c542;--accent-primary-dim: #b8884a;--accent-secondary: #8aa8c8;--accent-secondary-dim: #6888a8;--char1: var(--color-teal);--char1-dim: var(--color-teal-dim);--char2: var(--color-storm);--char2-dim: var(--color-storm-dim);--room: var(--accent-primary);--feature: var(--accent-primary);--item: var(--accent-primary);--npc: var(--color-npc);--narration: var(--accent-secondary);--card-char1: rgba(80, 192, 168, .08);--card-char2: rgba(88, 136, 200, .08);--card-system: rgba(107, 114, 128, .06);--success: #72dba0;--warning: #d4af37;--danger: #cf6f6f;--info: #8aa8c8;--font-display: "Barlow", system-ui, sans-serif;--font-ui: "Barlow Condensed", "Barlow", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace}html{font-family:var(--font-display);font-size:16px;background-color:var(--bg-base);color:var(--text-primary)}body{margin:0;min-height:100vh}#root{min-height:100vh}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}*{scrollbar-width:thin;scrollbar-color:var(--border) var(--bg-base)}[data-scenario=greenwood-inn]{--bg-base: #111010;--bg-card: #1a1816;--bg-elevated: #211f1c;--bg-hover: #2a2724;--text-primary: #e8e2da;--text-muted: #9c9590;--text-dim: #5c5854;--border: #2a2724;--border-subtle: #1e1c1a;--color-storm: #5888C8;--color-storm-dim: #7098C0;--color-teal: #50C0A8;--color-teal-dim: #68B0A0;--color-evergreen: #6c9d6c;--color-evergreen-dim: #6c9c6c;--color-sage: #8cbc8c;--color-sage-dim: #78B898;--color-khaki: #98A860;--color-khaki-dim: #909868;--color-violet: #9080D8;--color-violet-dim: #8880C0;--color-orchid: #B870B8;--color-orchid-dim: #A878B0;--color-rose: #E0A8B8;--color-rose-dim: #C8A0A8;--color-burgundy: #C87080;--color-burgundy-dim: #B07880;--color-ember: #D87048;--color-ember-dim: #C07858;--color-rust: #C8A078;--color-rust-dim: #B09070;--color-npc: #c8a060;--color-npc-dim: #9a7c4c;--system-grey: #5c5854;--ooc-tag: #7c7872;--admin-color: #c8a040;--admin-bg: rgba(200, 160, 64, .1);--accent-primary: #c8a040;--accent-primary-bright: #dab448;--accent-primary-dim: #a08030;--accent-secondary: #6c9d6c;--accent-secondary-dim: #5c8c5c;--char1: #dab448;--char1-dim: #a08030;--char2: #8cbc8c;--char2-dim: #6c9c6c;--card-char1: rgba(218, 180, 72, .06);--card-char2: rgba(140, 188, 140, .06);--card-system: rgba(92, 88, 84, .06);--success: #5c9c6c;--warning: #c8a040;--danger: #b05050;--info: #7c7872;--room: #c8a040;--feature: #c8a040;--item: #c8a040;--exit-dir: #6c9d6c;--font-display: "Merriweather", "Georgia", serif;--font-ui: "Inter", system-ui, sans-serif}.placeholder\:italic::-moz-placeholder{font-style:italic}.placeholder\:italic::placeholder{font-style:italic}.placeholder\:text-text-dim::-moz-placeholder{color:var(--text-dim)}.placeholder\:text-text-dim::placeholder{color:var(--text-dim)}.hover\:border-accent-primary:hover{border-color:var(--accent-primary)}.hover\:border-border:hover{border-color:var(--border)}.hover\:bg-accent-primary-bright:hover{background-color:var(--accent-primary-bright)}.hover\:bg-bg-elevated:hover{background-color:var(--bg-elevated)}.hover\:bg-bg-hover:hover{background-color:var(--bg-hover)}.hover\:text-accent-primary:hover{color:var(--accent-primary)}.hover\:text-text-primary:hover{color:var(--text-primary)}.focus\:border-accent-primary:focus{border-color:var(--accent-primary)}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}
