.char-modal-backdrop{position:fixed;inset:0;background:transparent;display:flex;align-items:center;justify-content:center;z-index:10001;opacity:0;transition:opacity .28s ease;padding:16px;box-sizing:border-box}.char-modal-backdrop.visible{opacity:1}.char-modal-backdrop.closing{opacity:0;pointer-events:none}@media (max-width:768px){.char-modal-backdrop{align-items:flex-end;justify-content:flex-end;padding:0}}.char-modal-card{position:relative;width:100%;max-width:680px;border-radius:20px;background:transparent;backdrop-filter:blur(100px);-webkit-backdrop-filter:blur(100px);display:flex;flex-direction:column;overflow:hidden;max-height:calc(100vh - 40px);transform:scale(.94) translateY(12px);transition:transform .28s cubic-bezier(.22,1,.36,1)}@media (min-width:769px){.char-modal-card{max-width:1000px;width:90vw;height:85vh;height:85dvh;max-height:85vh;max-height:85dvh;border-radius:16px}}.char-modal-backdrop.visible .char-modal-card{transform:scale(1) translateY(0)}.char-modal-backdrop.closing .char-modal-card{transform:scale(.96) translateY(8px)}@media (max-width:768px){.char-modal-card{max-width:100%;width:100%;border-radius:20px 20px 0 0;height:92vh;max-height:92vh;min-height:70vh;transform:translateY(20px)}.char-modal-backdrop.visible .char-modal-card{transform:translateY(0)}}.char-modal-header{display:flex;flex-direction:column;align-items:center;gap:8px;position:relative;flex-shrink:0;padding:20px 20px 12px}@media (min-width:769px){.char-modal-header.char-modal-header--back-nav{flex-direction:row;align-items:center;justify-content:flex-start;gap:12px}.char-modal-header.char-modal-header--back-nav .char-modal-inspect-back-btn{flex-shrink:0;position:relative;z-index:1}.char-modal-header.char-modal-header--back-nav .char-modal-title{position:absolute;left:50%;transform:translateX(-50%);margin:0;max-width:calc(100% - 200px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;pointer-events:none}}.char-modal-title-row{position:relative;display:flex;align-items:center;justify-content:center;width:100%}.char-modal-title{color:#fff;font-size:20px;font-family:Outfit-Bold;font-weight:600;margin:0;text-align:center}.char-modal-create-row{width:100%}.char-modal-close-btn,.char-modal-create-row{display:flex;justify-content:center;flex-shrink:0}.char-modal-close-btn{position:absolute;top:14px;right:14px;width:40px;height:40px;border-radius:0;background:transparent;border:none;color:hsla(0,0%,100%,.5);font-size:22px;cursor:pointer;align-items:center;line-height:1;transition:background .15s ease;z-index:2}.char-modal-create-row .char-modal-create-btn{margin-right:0;width:90%;max-width:400px;padding:8px 14px;font-size:14px;font-weight:500;gap:6px;background:transparent;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid hsla(0,0%,100%,.1);color:#fff;font-family:Outfit-Bold;transition:all .2s ease}.char-modal-create-row .char-modal-create-btn:hover{background:hsla(0,0%,100%,.12);border-color:hsla(0,0%,100%,.18);transform:translateY(-2px)}.char-modal-close-btn:hover{background:none;color:hsla(0,0%,100%,.85)}.char-modal-create-btn{display:flex;align-items:center;justify-content:center;border-radius:10px;cursor:pointer;white-space:nowrap}.char-modal-create-btn:hover{background:hsla(0,0%,100%,.14)}@media (max-width:768px){.char-modal-header{padding:18px 16px 10px}.char-modal-title{font-size:18px}.char-modal-close-btn{top:12px;right:12px}.char-modal-create-row .char-modal-create-btn{padding:8px 14px;font-size:13px}}.char-modal-search-wrap{flex:0 0 auto;display:flex;justify-content:center;margin-bottom:4px}.char-modal-search-inner{position:relative;width:90%;max-width:600px}.char-modal-search-wrap .char-modal-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:hsla(0,0%,100%,.5);pointer-events:none;z-index:1;font-size:14px}.char-modal-search-input{width:100%;padding:10px 16px 10px 44px;border:none;border-bottom:1px solid hsla(0,0%,100%,.2);font-size:14px;background:transparent;outline:none;color:#fff;font-family:Outfit,sans-serif;box-sizing:border-box;transition:border-color .2s ease}.char-modal-search-input::placeholder{color:hsla(0,0%,100%,.5)}.char-modal-search-input:focus{border-bottom-color:hsla(0,0%,100%,.4)}@media (max-width:768px){.char-modal-search-wrap{padding:0 16px 8px}}.char-modal-filter-tabs{display:flex;align-items:center;justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;gap:8px;padding:0 20px 10px;flex-shrink:0;scrollbar-width:none}.char-modal-filter-tabs::-webkit-scrollbar{display:none}.char-modal-filter-tab{background:hsla(0,0%,100%,.06);border:1px solid hsla(0,0%,100%,.1);border-radius:20px;padding:7px 14px;color:hsla(0,0%,100%,.6);font-size:13px;font-weight:500;font-family:Outfit-Bold;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.char-modal-filter-tab:hover{background:hsla(0,0%,100%,.08);border-color:hsla(0,0%,100%,.2);color:hsla(0,0%,100%,.9)}.char-modal-filter-tab.active{background:hsla(0,0%,100%,.16);border-color:hsla(0,0%,100%,.25);color:#fff}.char-modal-filter-tab:hover:not(.active){background:hsla(0,0%,100%,.1)}@media (max-width:768px){.char-modal-filter-tabs{padding:0 16px 8px}}.char-modal-grid-wrap{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:0 16px 8px}.char-modal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:10px;gap:10px}.char-modal-section-label{grid-column:1/-1;padding:0 4px 6px;color:hsla(0,0%,100%,.35);font-size:11px;font-family:Outfit-Bold;font-weight:600;letter-spacing:.5px;text-transform:uppercase;margin-top:4px}.char-modal-card-item{display:flex;flex-direction:column;align-items:center;background:hsla(0,0%,100%,.04);border:none;border-radius:12px;padding:10px 8px;cursor:pointer;transition:background .2s,transform .2s;gap:6px;position:relative;overflow:hidden;text-align:center;min-width:0}.char-modal-card-item:hover{background:hsla(0,0%,100%,.1);transform:translateY(-2px)}.char-modal-card-item.is-yours{background:hsla(0,0%,100%,.06)}.char-modal-card-item .character-avatar-card.character-avatar-card--icon-only{width:72px;height:72px;border-radius:50%;object-fit:cover;display:block;margin:0 auto 8px;background-color:hsla(0,0%,100%,.1);flex-shrink:0}@media (max-width:768px){.char-modal-card-item .character-avatar-card.character-avatar-card--icon-only{width:56px;height:56px}}.char-modal-card-name{color:#fff;font-size:14px;font-family:NewSpirit-SemiBold;font-weight:600;word-break:break-word;line-height:1.2;margin:0 0 4px;width:100%}.char-modal-card-creator{color:hsla(0,0%,100%,.6);font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;width:100%}.char-modal-card-creator.yours{color:#8b5cf6}.char-modal-card-badge{position:absolute;top:8px;left:8px;padding:4px 6px;border-radius:6px;background:rgba(239,68,68,.9);display:flex;align-items:center;justify-content:center;font-size:10px;color:#fff}@media (max-width:768px){.char-modal-grid-wrap{padding:0 12px 12px}.char-modal-grid{grid-template-columns:repeat(2,1fr);gap:8px}}.char-modal-state-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;gap:10px}.char-modal-state-text{color:hsla(0,0%,100%,.45);font-size:14px;text-align:center;max-width:240px}.char-modal-state-icon{font-size:28px;color:hsla(0,0%,100%,.25)}.char-modal-empty-create-btn{margin-top:6px;padding:9px 18px;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.18);border-radius:10px;color:#fff;font-size:13px;font-family:Outfit SemiBold,Outfit,sans-serif;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background .15s ease}.char-modal-empty-create-btn:hover{background:hsla(0,0%,100%,.16)}.char-modal-pagination{display:flex;align-items:center;justify-content:center;padding:12px 20px;gap:10px}.char-modal-page-btn{background:hsla(0,0%,100%,.08);border:none;border-radius:10px;padding:8px 14px;color:#fff;font-size:14px;cursor:pointer;transition:background .15s ease;font-family:Outfit,sans-serif}.char-modal-page-btn:hover:not(:disabled){background:hsla(0,0%,100%,.16)}.char-modal-page-btn:disabled{opacity:.5;cursor:not-allowed}.char-modal-page-info{text-align:center;color:hsla(0,0%,100%,.5);font-size:13px;font-family:Outfit,sans-serif}@media (max-width:768px){.char-modal-pagination{padding:12px 16px}}.char-modal-inspect-overlay{position:absolute;inset:0;background:rgba(14,14,20,.4);backdrop-filter:blur(100px);-webkit-backdrop-filter:blur(100px);display:flex;flex-direction:column;z-index:1;animation:charInspectIn .2s ease both}@keyframes charInspectIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.char-modal-inspect-header{display:flex;align-items:center;gap:8px;padding:16px 20px;min-height:64px;flex-shrink:0;border-bottom:1px solid hsla(0,0%,100%,.1)}.char-modal-inspect-back-btn{background:none;border:none;color:hsla(0,0%,100%,.5);font-size:14px;cursor:pointer;padding:4px 0;display:flex;align-items:center;gap:4px;font-family:Outfit,sans-serif;transition:color .15s ease}.char-modal-inspect-back-btn:hover{color:hsla(0,0%,100%,.85)}.char-modal-inspect-name{color:#fff;font-size:22px;font-family:Outfit,sans-serif;font-weight:600;flex:1 1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0;text-align:center}.char-modal-inspect-body{flex:1 1;overflow-y:auto;display:flex;flex-direction:column}.char-modal-inspect-content{display:flex;gap:24px;padding:24px;flex:1 1;min-height:0}.char-modal-inspect-image-col{flex:0 0 200px;display:flex;flex-direction:column;align-items:flex-start}.char-modal-inspect-headshot{width:200px;height:300px;border-radius:12px;object-fit:cover;object-position:top;flex-shrink:0}.char-modal-inspect-headshot-placeholder{width:200px;height:300px;border-radius:12px;background:hsla(0,0%,100%,.08);display:flex;align-items:center;justify-content:center;font-size:64px;color:hsla(0,0%,100%,.3);flex-shrink:0}.char-modal-inspect-creator{color:hsla(0,0%,100%,.6);font-size:13px;margin-top:8px;font-family:Outfit,sans-serif}.char-modal-inspect-info-col{flex:1 1;display:flex;flex-direction:column;gap:16px;min-width:0;overflow-y:auto}.char-modal-inspect-section{background:hsla(0,0%,100%,.05);border-radius:8px;padding:16px}.char-modal-inspect-tags{display:flex;flex-wrap:wrap;gap:6px}.char-modal-inspect-tag{display:inline-flex;align-items:center;gap:4px;background:hsla(0,0%,100%,.1);border:1px solid hsla(0,0%,100%,.1);border-radius:16px;padding:5px 12px;color:hsla(0,0%,100%,.9);font-size:12px}.char-modal-inspect-tag.fandom{color:#fff}.char-modal-inspect-section-title{color:#fff;font-size:15px;font-family:Outfit,sans-serif;font-weight:600;margin:0 0 8px}.char-modal-inspect-section-content{color:hsla(0,0%,100%,.85);font-size:14px;line-height:20px;margin:0;white-space:pre-wrap}.char-modal-inspect-footer{padding:20px;border-top:1px solid hsla(0,0%,100%,.1);flex-shrink:0;display:flex;justify-content:center}.char-modal-add-btn{min-width:180px;background:hsla(0,0%,100%,.2);border:none;border-radius:12px;padding:14px;color:#fff;font-size:16px;font-family:Outfit-Bold;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .3s ease,transform .3s ease}.char-modal-add-btn:hover{background:hsla(0,0%,100%,.3);transform:translateY(-2px)}@media (max-width:768px){.char-modal-inspect-content{flex-direction:column;align-items:stretch;gap:0;padding:0;min-height:0}.char-modal-inspect-image-col{flex:none;flex-direction:column;align-items:center;padding:16px 16px 8px;gap:6px}.char-modal-inspect-headshot,.char-modal-inspect-headshot-placeholder{width:120px;height:180px;flex-shrink:0;border-radius:12px}.char-modal-inspect-creator{text-align:center;margin-top:0}.char-modal-inspect-info-col{padding:0 16px 8px;gap:10px}.char-modal-inspect-footer{padding:12px}}.char-modal-create-view{flex:1 1;overflow-y:auto;display:flex;flex-direction:column}.char-modal-create-content{display:flex;gap:24px;padding:24px;flex:1 1}.char-modal-create-image-col{flex:0 0 200px;display:flex;flex-direction:column;align-items:flex-start}.char-modal-create-headshot-wrapper{width:200px;height:300px;border-radius:12px;overflow:hidden;cursor:pointer;position:relative;flex-shrink:0;transition:transform .2s ease}.char-modal-create-headshot-wrapper:hover{transform:scale(1.02)}.char-modal-create-headshot-img{width:100%;height:100%;object-fit:cover;object-position:top}.char-modal-create-headshot-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:hsla(0,0%,100%,.3);font-size:13px;background:hsla(0,0%,100%,.05);border-radius:12px}.char-modal-create-headshot-placeholder i{font-size:64px;opacity:.3}.char-modal-create-headshot-overlay{position:absolute;inset:0;background:rgba(0,0,0,.6);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:#fff;font-size:13px;opacity:0;transition:opacity .15s ease}.char-modal-create-headshot-wrapper:hover .char-modal-create-headshot-overlay{opacity:1}.char-modal-create-headshot-overlay i{font-size:20px}.char-modal-create-info-col{flex:1 1;display:flex;flex-direction:column;gap:16px;min-width:0}.char-modal-create-section{background:hsla(0,0%,100%,.05);border-radius:8px;padding:16px}.char-modal-create-section-title{color:#fff;font-size:15px;font-family:Outfit,sans-serif;font-weight:600;margin:0 0 8px}.char-modal-create-input{width:100%;height:44px;background:transparent;border:1px solid hsla(0,0%,100%,.2);border-radius:8px;color:#fff;font-size:15px;padding:0 14px;outline:none;box-sizing:border-box;font-family:Outfit,sans-serif;transition:border-color .15s ease}.char-modal-create-input::placeholder{color:hsla(0,0%,100%,.35)}.char-modal-create-input:focus{border-color:rgba(102,126,234,.5)}.char-modal-create-textarea{width:100%;min-height:80px;background:transparent;border:1px solid hsla(0,0%,100%,.2);border-radius:8px;color:#fff;font-size:15px;padding:10px 14px;outline:none;box-sizing:border-box;font-family:Outfit,sans-serif;resize:vertical;transition:border-color .15s ease}.char-modal-create-textarea::placeholder{color:hsla(0,0%,100%,.35)}.char-modal-create-textarea:focus{border-color:rgba(102,126,234,.5)}.char-modal-create-footer{padding:20px;border-top:1px solid hsla(0,0%,100%,.1);flex-shrink:0;display:flex;justify-content:center}.char-modal-save-btn{min-width:200px;background:hsla(0,0%,100%,.15);border:none;border-radius:12px;padding:14px;color:#fff;font-size:16px;font-family:Outfit-Bold;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .3s ease,transform .3s ease,box-shadow .3s ease}.char-modal-save-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 16px rgba(102,126,234,.4)}.char-modal-save-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width:768px){.char-modal-create-content{flex-direction:column;gap:16px;padding:16px}.char-modal-create-image-col{flex:none;align-items:center}.char-modal-create-headshot-wrapper{width:150px;height:225px}.char-modal-create-footer{padding:16px}}.char-modal-photo-view{flex:1 1;overflow-y:auto;display:flex;flex-direction:column;padding:0 20px 12px;gap:16px}.char-modal-photo-section{background:hsla(0,0%,100%,.05);border-radius:8px;padding:16px}.char-modal-photo-section-title{color:#fff;font-size:15px;font-family:Outfit,sans-serif;font-weight:600;margin:0 0 8px}.char-modal-photo-generate-area{display:flex;flex-direction:column;gap:8px}.char-modal-photo-generate-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;background:hsla(0,0%,100%,.09);border:1px solid hsla(0,0%,100%,.15);border-radius:10px;color:#fff;font-size:14px;font-family:Outfit,sans-serif;cursor:pointer;transition:background .15s ease,border-color .15s ease}.char-modal-photo-generate-btn:hover:not(:disabled){background:hsla(0,0%,100%,.14);border-color:hsla(0,0%,100%,.22)}.char-modal-photo-generate-btn:disabled{opacity:.5;cursor:not-allowed}.char-modal-photo-divider{display:flex;align-items:center;text-align:center;color:hsla(0,0%,100%,.35);font-size:12px;text-transform:uppercase;letter-spacing:2px}.char-modal-photo-divider:after,.char-modal-photo-divider:before{content:"";flex:1 1;border-bottom:1px solid hsla(0,0%,100%,.1)}.char-modal-photo-divider span{padding:0 12px}.char-modal-upload-area{border:2px dashed hsla(0,0%,100%,.18);border-radius:10px;padding:28px 20px;text-align:center;cursor:pointer;transition:border-color .2s ease,background .2s ease;display:flex;flex-direction:column;align-items:center;gap:6px}.char-modal-upload-area:hover{border-color:rgba(102,126,234,.5);background:hsla(0,0%,100%,.02)}.char-modal-upload-area.dragover{border-color:rgba(102,126,234,.8);background:rgba(102,126,234,.08)}.char-modal-upload-icon{font-size:28px;color:hsla(0,0%,100%,.4)}.char-modal-upload-text{color:hsla(0,0%,100%,.75);font-size:14px;margin:0}.char-modal-upload-subtext{color:hsla(0,0%,100%,.4);font-size:12px;margin:0}.char-modal-url-wrap{position:relative}.char-modal-url-input{width:100%;height:44px;background:hsla(0,0%,100%,.06);border:1px solid hsla(0,0%,100%,.12);border-radius:10px;color:#fff;font-size:15px;padding:0 44px 0 14px;outline:none;box-sizing:border-box;font-family:Outfit,sans-serif;transition:border-color .15s ease}.char-modal-url-input::placeholder{color:hsla(0,0%,100%,.35)}.char-modal-url-input:focus{border-color:hsla(0,0%,100%,.3)}.char-modal-url-submit-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);width:24px;height:24px;border-radius:50%;background:hsla(0,0%,100%,.85);border:none;color:#333;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:10px;transition:background .15s ease}.char-modal-url-submit-btn:hover:not(:disabled){background:#fff}.char-modal-url-submit-btn:disabled{opacity:.5;cursor:not-allowed}.char-modal-spinner{width:32px;height:32px;border:3px solid hsla(0,0%,100%,.15);border-top-color:hsla(0,0%,100%,.7);border-radius:50%;animation:charModalSpin .7s linear infinite}@keyframes charModalSpin{to{transform:rotate(1turn)}}.char-modal-selected-chips{display:flex;gap:8px;padding:8px 16px;overflow-x:auto;flex-shrink:0;scrollbar-width:none;-ms-overflow-style:none}.char-modal-selected-chips::-webkit-scrollbar{display:none}.char-modal-chip{display:flex;align-items:center;gap:6px;background:hsla(0,0%,100%,.1);border-radius:20px;padding:4px 8px 4px 4px;flex-shrink:0}.char-modal-chip-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.char-modal-chip-name{color:hsla(0,0%,100%,.85);font-size:12px;font-family:Outfit,sans-serif;font-weight:500;white-space:nowrap;max-width:80px;overflow:hidden;text-overflow:ellipsis}.char-modal-chip-remove{background:none;border:none;color:hsla(0,0%,100%,.5);font-size:14px;cursor:pointer;padding:0 2px;line-height:1;display:flex;align-items:center}.char-modal-chip-remove:hover{color:hsla(0,0%,100%,.9)}.char-modal-card-item.is-selected{background:hsla(0,0%,100%,.08)}.char-modal-card-select-circle{position:absolute;top:6px;right:6px;width:22px;height:22px;border-radius:50%;border:2px solid hsla(0,0%,100%,.35);background:transparent;display:flex;align-items:center;justify-content:center;font-size:10px;color:transparent;z-index:5;transition:all .15s ease}.char-modal-card-select-circle.checked{border-color:hsla(0,0%,100%,.9);background:hsla(0,0%,100%,.9);color:#111}.char-modal-card-info-btn{position:absolute;bottom:6px;right:6px;width:24px;height:24px;border-radius:50%;border:none;background:rgba(0,0,0,.35);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:hsla(0,0%,100%,.55);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:5;padding:0;transition:all .15s ease}.char-modal-card-info-btn:hover{background:rgba(0,0,0,.55);color:hsla(0,0%,100%,.9)}.char-modal-multiselect-footer{flex-shrink:0;padding:12px 16px calc(12px + env(safe-area-inset-bottom, 0px));display:flex;justify-content:center}.char-modal-multiselect-btn{width:100%;max-width:400px;padding:14px 24px;border:none;border-radius:14px;background:hsla(0,0%,100%,.15);color:#fff;font-size:15px;font-weight:600;font-family:Outfit,sans-serif;cursor:pointer;transition:background .2s ease}.char-modal-multiselect-btn:hover{background:hsla(0,0%,100%,.22)}