.character-selector-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.character-selector{background:#fff;border-radius:12px;width:100%;max-width:900px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0000004d}.character-selector-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px 12px 0 0}.character-selector-header h2{margin:0;font-size:1.5rem}.close-btn,.form-close-btn{background:none;border:none;font-size:1.5rem;color:#fff;cursor:pointer;padding:5px;border-radius:50%;width:35px;height:35px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.close-btn:hover,.form-close-btn:hover{background:#fff3}.selector-controls{display:flex;gap:15px;padding:20px;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.search-input,.category-select{flex:1;padding:10px;border:1px solid #ddd;border-radius:6px;font-size:14px}.search-input:focus,.category-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.character-options{padding:20px;max-height:400px;overflow-y:auto}.character-card{display:flex;align-items:center;padding:15px;border:2px solid #e0e0e0;border-radius:8px;margin-bottom:12px;cursor:pointer;transition:all .2s ease;background:#fff}.character-card:hover{border-color:#667eea;background:#f8f9ff;transform:translateY(-1px);box-shadow:0 4px 12px #667eea1a}.character-card.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea10,#764ba210);box-shadow:0 4px 12px #667eea26}.character-avatar{font-size:2.5rem;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#f0f0f0;border-radius:50%;margin-right:15px;flex-shrink:0}.character-info{flex:1}.character-info h3{margin:0 0 5px;font-size:1.1rem;color:#333}.character-info p{margin:0 0 8px;color:#666;font-size:.9rem;line-height:1.4}.character-expertise{margin:5px 0;font-size:.85rem;color:#555}.character-expertise strong{color:#333}.character-meta{display:flex;gap:8px;flex-wrap:wrap}.character-meta span{font-size:.75rem;padding:2px 6px;border-radius:10px;background:#f0f0f0;color:#666;font-weight:500}.category{background:#e3f2fd!important;color:#1976d2!important}.usage{background:#f3e5f5!important;color:#7b1fa2!important}.language{background:#e8f5e8!important;color:#2e7d32!important}.response-style{background:#fff3e0!important;color:#f57c00!important}.public-badge{background:#e0f2f1!important;color:#00695c!important}.loading-characters{text-align:center;padding:40px;color:#666}.spinner{width:40px;height:40px;border:4px solid #f0f0f0;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 15px}.no-characters{text-align:center;padding:40px;color:#666}.create-character-section{padding:20px;border-top:1px solid #e0e0e0;background:#f8f9fa}.create-character-btn{width:100%;padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:transform .2s}.create-character-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.create-form-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1001;padding:20px}.create-character-form{background:#fff;border-radius:12px;width:100%;max-width:700px;max-height:90vh;overflow-y:auto;box-shadow:0 10px 30px #0000004d}.form-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:12px 12px 0 0}.form-header h3{margin:0;font-size:1.3rem}.create-character-form form{padding:20px}.form-row{display:flex;gap:15px}.form-group{flex:1;margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#333}.form-group input,.form-group textarea,.form-group select{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.form-group textarea{height:80px;resize:vertical}.form-group textarea.custom-input{height:60px;margin-top:8px;background:#f8f9fa;border-style:dashed}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.form-group select{background:#fff;cursor:pointer}.form-group select option[value=custom]{font-style:italic;background:#f0f0f0}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px}.checkbox-label input[type=checkbox]{width:auto;margin:0}.form-buttons{display:flex;gap:10px;margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.cancel-btn,.create-btn{flex:1;padding:12px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s,transform .1s}.cancel-btn{background:#f0f0f0;color:#666}.cancel-btn:hover{background:#e0e0e0}.create-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.create-btn:hover:not(:disabled){background:linear-gradient(135deg,#5a67d8,#6b46a6);transform:translateY(-1px)}.create-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.character-card .character-info{position:relative}.character-card:hover .character-info{color:#333}.form-group:last-child{margin-bottom:0}.form-group textarea:not(.custom-input){height:90px}.character-meta{margin-top:8px}.character-meta span{white-space:nowrap}@media (max-width: 768px){.character-selector-overlay{padding:10px}.character-selector{max-height:95vh}.character-selector-header h2{font-size:1.3rem}.selector-controls{flex-direction:column;gap:10px}.form-row{flex-direction:column;gap:0}.character-card{padding:12px}.character-avatar{font-size:2rem;width:50px;height:50px;margin-right:12px}.character-info h3{font-size:1rem}.character-info p{font-size:.85rem}.character-expertise{font-size:.8rem}.character-meta span{font-size:.7rem;padding:1px 5px}.form-buttons{flex-direction:column}.create-character-form{max-width:100%}.form-header h3{font-size:1.2rem}}@media (max-width: 480px){.character-selector-overlay{padding:5px}.character-card{flex-direction:column;text-align:center;padding:15px}.character-avatar{margin-right:0;margin-bottom:10px}.character-meta{justify-content:center}}.loading-big-container{position:fixed;inset:0;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;z-index:9999}.loading-big-content{text-align:center;color:#fff}.loading-big-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}.loading-big-content h2{margin:0 0 10px;font-size:1.5rem;font-weight:300}.loading-big-content p{margin:0;opacity:.9;font-size:1rem}.loading-spinner{width:20px;height:20px;border:2px solid #f0f0f0;border-top:2px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.loading-with-text{display:flex;align-items:center;gap:10px;color:#666;font-size:14px}.loading-overlay-container{position:relative}.loading-overlay{position:absolute;inset:0;background:#ffffffe6;display:flex;align-items:center;justify-content:center;z-index:100;border-radius:inherit}.loading-overlay-content{display:flex;flex-direction:column;align-items:center;gap:10px;color:#666}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.loading-pulse{animation:pulse 1.5s ease-in-out infinite}.home-container{display:flex;height:100vh;background:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.sidebar{width:320px;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;transition:transform .3s ease;position:relative;z-index:100}.sidebar-closed{transform:translate(-100%)}.sidebar-header{padding:20px;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;align-items:center}.user-info{display:flex;align-items:center;gap:12px}.user-avatar{width:40px;height:40px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem}.user-details h3{margin:0;font-size:1rem}.user-details span{font-size:.8rem;opacity:.9}.logout-btn{background:none;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:8px;border-radius:50%;transition:background-color .2s}.logout-btn:hover{background:#fff3}.new-chat-section{padding:20px;border-bottom:1px solid #e0e0e0}.new-chat-btn{width:100%;padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:transform .2s}.new-chat-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.new-chat-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.chat-filter{padding:0 20px 15px}.filter-select{width:100%;padding:8px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff}.chat-list{flex:1;overflow-y:auto;padding:0 10px}.loading-chats{text-align:center;padding:40px 20px;color:#666}.chat-item{margin:8px 0;padding:12px;border-radius:8px;cursor:pointer;transition:all .2s;border:2px solid transparent}.chat-item:hover{background:#f8f9ff;border-color:#e0e7ff}.chat-item.active{background:linear-gradient(135deg,#667eea10,#764ba210);border-color:#667eea;box-shadow:0 2px 8px #667eea1a}.chat-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.character-indicator,.ai-indicator{font-size:.8rem;padding:2px 8px;border-radius:12px;font-weight:500}.character-indicator{background:#e8f5e8;color:#2e7d32}.ai-indicator{background:#e3f2fd;color:#1976d2}.delete-chat-btn{background:none;border:none;font-size:.9rem;cursor:pointer;padding:4px;border-radius:4px;opacity:.6;transition:opacity .2s}.delete-chat-btn:hover{opacity:1;background:#ffebee}.chat-item-content .chat-title{margin:0 0 4px;font-weight:500;font-size:.9rem;color:#333}.chat-item-content .latest-message{margin:0 0 4px;font-size:.8rem;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-item-content .chat-date{font-size:.7rem;color:#999}.no-chats{text-align:center;padding:40px 20px;color:#666}.start-chat-btn{margin-top:15px;padding:10px 20px;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px}.sidebar-toggle{display:none;position:absolute;top:50%;right:-40px;transform:translateY(-50%);background:#667eea;color:#fff;border:none;width:30px;height:60px;border-radius:0 6px 6px 0;cursor:pointer;font-size:1.2rem}.chat-area{flex:1;display:flex;flex-direction:column;background:#fff}.chat-header{padding:20px;border-bottom:1px solid #e0e0e0;background:#fff;display:flex;justify-content:space-between;align-items:center;min-height:80px}.current-chat-info h2{margin:0 0 5px;font-size:1.3rem;color:#333}.chat-type-badge{font-size:.8rem;padding:4px 12px;border-radius:12px;background:#f0f0f0;color:#666;font-weight:500}.chat-actions{display:flex;gap:10px}.switch-character-btn,.show-sidebar-btn{padding:8px 16px;background:#f8f9fa;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s}.switch-character-btn:hover,.show-sidebar-btn:hover{background:#e9ecef}.messages-container{flex:1;overflow-y:auto;padding:20px;background:#fafafa}.loading-messages{text-align:center;padding:40px;color:#666}.message-pair{margin-bottom:24px}.message{margin-bottom:12px;display:flex;align-items:flex-start;gap:12px}.user-message{justify-content:flex-end}.user-message .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:12px 16px;border-radius:18px 18px 4px;max-width:70%;word-wrap:break-word}.ai-message{justify-content:flex-start}.message-avatar{width:35px;height:35px;border-radius:50%;background:#f0f0f0;display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.ai-message .message-content{background:#fff;color:#333;padding:12px 16px;border-radius:18px 18px 18px 4px;max-width:70%;word-wrap:break-word;border:1px solid #e0e0e0}.message-content p{margin:0;line-height:1.4}.message-meta{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;color:#999;margin-top:4px;padding:0 16px}.user-message .message-meta{justify-content:flex-end;gap:8px}.no-messages{text-align:center;padding:60px 20px}.welcome-message{max-width:500px;margin:0 auto}.welcome-message h3{margin-bottom:15px;color:#333;font-size:1.4rem}.welcome-message p{color:#666;line-height:1.5}.message-input-container{padding:20px;border-top:1px solid #e0e0e0;background:#fff}.message-form{margin-bottom:8px}.input-wrapper{display:flex;gap:12px;align-items:flex-end}.message-input{flex:1;padding:12px 16px;border:2px solid #e0e0e0;border-radius:24px;font-size:14px;font-family:inherit;resize:none;max-height:120px;transition:border-color .2s}.message-input:focus{outline:none;border-color:#667eea}.send-button{width:45px;height:45px;border-radius:50%;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:1.2rem;cursor:pointer;transition:transform .2s;flex-shrink:0}.send-button:hover:not(:disabled){transform:scale(1.05)}.send-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.input-hint{text-align:center;font-size:.8rem;color:#999}.no-chat-selected{display:flex;align-items:center;justify-content:center;padding:40px;text-align:center}.welcome-screen{max-width:600px}.welcome-screen h1{margin-bottom:20px;color:#333;font-size:2.2rem}.welcome-screen>p{font-size:1.1rem;color:#666;margin-bottom:40px}.chat-options{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:40px}.chat-option{padding:30px;border:2px solid #e0e0e0;border-radius:12px;transition:all .2s;cursor:pointer}.chat-option:hover{border-color:#667eea;background:#f8f9ff;transform:translateY(-2px)}.option-icon{font-size:3rem;margin-bottom:15px}.chat-option h3{margin-bottom:10px;color:#333}.chat-option p{color:#666;font-size:.9rem;line-height:1.4}.get-started-btn{padding:15px 30px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:500;cursor:pointer;transition:transform .2s;margin-bottom:30px}.get-started-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 25px #667eea4d}.get-started-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.features-preview{margin-top:30px;padding:20px;background:#f8f9fa;border-radius:8px}.features-preview h4{margin-bottom:15px;color:#333}.character-preview{display:flex;justify-content:center;gap:15px;flex-wrap:wrap}.character-preview span{padding:6px 12px;background:#fff;border-radius:20px;font-size:.9rem;color:#666;border:1px solid #e0e0e0}.mobile-overlay{display:none}@media (max-width: 768px){.home-container{position:relative}.sidebar{position:absolute;top:0;left:0;height:100%;z-index:200;width:280px}.sidebar-toggle{display:block}.mobile-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:150}.chat-area{width:100%}.chat-header{padding:15px;min-height:70px}.current-chat-info h2{font-size:1.1rem}.chat-options{grid-template-columns:1fr;gap:20px}.chat-option{padding:20px}.welcome-screen h1{font-size:1.8rem}.message-content{max-width:85%!important}.messages-container,.message-input-container{padding:15px}.character-preview{gap:8px}.character-preview span{font-size:.8rem;padding:4px 8px}}@media (max-width: 480px){.sidebar{width:100%}.welcome-screen{padding:20px}.welcome-screen h1{font-size:1.5rem}.option-icon{font-size:2.5rem}.get-started-btn{padding:12px 24px;font-size:1rem}}.loading-spinner{width:20px;height:20px;border:2px solid #f0f0f0;border-top:2px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.chat-list::-webkit-scrollbar,.messages-container::-webkit-scrollbar{width:6px}.chat-list::-webkit-scrollbar-track,.messages-container::-webkit-scrollbar-track{background:#f1f1f1}.chat-list::-webkit-scrollbar-thumb,.messages-container::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.chat-list::-webkit-scrollbar-thumb:hover,.messages-container::-webkit-scrollbar-thumb:hover{background:#a8a8a8}*,: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:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;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]{display:none}*,: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: }.fixed{position:fixed}.absolute{position:absolute}.inset-0{inset:0}.bottom-0{bottom:0}.mb-2{margin-bottom:.5rem}.mb-20{margin-bottom:5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mt-2{margin-top:.5rem}.mt-4{margin-top:1rem}.block{display:block}.flex{display:flex}.h-screen{height:100vh}.max-h-\[500px\]{max-height:500px}.w-full{width:100%}.max-w-md{max-width:28rem}.flex-1{flex:1 1 0%}.-translate-x-full{--tw-translate-x: -100%;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))}.translate-x-0{--tw-translate-x: 0px;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))}.transform{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))}.cursor-pointer{cursor:pointer}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rounded{border-radius:.25rem}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.border{border-width:1px}.border-2{border-width:2px}.border-gray-300{--tw-border-opacity: 1;border-color:rgb(209 213 219 / var(--tw-border-opacity))}.bg-blue-500{--tw-bg-opacity: 1;background-color:rgb(59 130 246 / var(--tw-bg-opacity))}.bg-gray-50{--tw-bg-opacity: 1;background-color:rgb(249 250 251 / var(--tw-bg-opacity))}.bg-gray-700{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity))}.bg-gray-800{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity))}.bg-red-600{--tw-bg-opacity: 1;background-color:rgb(220 38 38 / var(--tw-bg-opacity))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.pr-2{padding-right:.5rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.tracking-widest{letter-spacing:.1em}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity))}.text-gray-800{--tw-text-opacity: 1;color:rgb(31 41 55 / var(--tw-text-opacity))}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity))}.underline{text-decoration-line:underline}.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-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.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{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter,-webkit-backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}body{--tw-bg-opacity: 1;background-color:rgb(15 23 42 / var(--tw-bg-opacity))}.thin-scrollbar{scrollbar-width:thin;scrollbar-color:#888 #f1f1f1}.character-selector{max-width:400px;padding:20px}.character-card{display:flex;align-items:center;gap:12px;padding:12px;border:2px solid #e0e0e0;border-radius:8px;margin-bottom:8px;cursor:pointer;transition:all .2s}.character-card:hover{border-color:#4caf50;background-color:#f9f9f9}.character-card.selected{border-color:#4caf50;background-color:#e8f5e8}.character-card .avatar{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:#f0f0f0;border-radius:50%}.character-card h4{margin:0 0 4px;font-size:16px}.character-card p{margin:0 0 4px;font-size:14px;color:#666}.character-card small{font-size:12px;color:#999}.create-character-btn{width:100%;padding:12px;background-color:#4caf50;color:#fff;border:none;border-radius:8px;font-size:16px;cursor:pointer;margin-top:8px}.create-form{margin-top:16px;padding:16px;border:1px solid #ddd;border-radius:8px;background-color:#f9f9f9}.create-form input,.create-form textarea,.create-form select{width:100%;padding:8px;margin-bottom:8px;border:1px solid #ddd;border-radius:4px;font-size:14px}.create-form textarea{height:60px;resize:vertical}.form-buttons{display:flex;gap:8px;margin-top:12px}.form-buttons button{flex:1;padding:8px;border:none;border-radius:4px;cursor:pointer}.form-buttons button:first-child{background-color:#4caf50;color:#fff}.form-buttons button:last-child{background-color:#f0f0f0;color:#333}.hover\:bg-blue-600:hover{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity))}.hover\:bg-blue-700:hover{--tw-bg-opacity: 1;background-color:rgb(29 78 216 / var(--tw-bg-opacity))}.hover\:bg-gray-600:hover{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity))}.hover\:bg-red-700:hover{--tw-bg-opacity: 1;background-color:rgb(185 28 28 / var(--tw-bg-opacity))}.hover\:text-gray-700:hover{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity))}.focus\:border-blue-500:focus{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity))}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-blue-500:focus{--tw-ring-opacity: 1;--tw-ring-color: rgb(59 130 246 / var(--tw-ring-opacity))}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}@media (min-width: 768px){.md\:relative{position:relative}.md\:mb-0{margin-bottom:0}.md\:block{display:block}.md\:hidden{display:none}.md\:w-1\/4{width:25%}.md\:w-\[500px\]{width:500px}.md\:translate-x-0{--tw-translate-x: 0px;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))}}
