.admin-login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#f5f5f5;padding:20px}.login-card{background:#fff;padding:40px;border-radius:12px;box-shadow:0 4px 20px #0000001a;width:100%;max-width:400px}.login-card h1{margin:0 0 8px;color:#db1237;font-size:28px}.login-card p{margin:0 0 24px;color:#667781}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#303030}.form-group input{width:100%;padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:16px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#db1237}.error-message{background:#fee;color:#c00;padding:10px 14px;border-radius:6px;margin-bottom:16px;font-size:14px}.login-card button{width:100%;padding:14px;background:#db1237;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:background .2s}.login-card button:hover{background:#b00f2d}.login-card button:disabled{background:#999;cursor:not-allowed}html:has(.admin-container),html:has(.admin-login),body:has(.admin-container),body:has(.admin-login),#root:has(.admin-container),#root:has(.admin-login){height:auto!important;min-height:100vh;overflow:auto!important}.admin-container{min-height:100vh;background:#f5f5f5;padding:20px 20px 40px;overflow-y:auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}.admin-header h1{margin:0;color:#db1237;font-size:24px}.back-btn{background:none;border:1px solid #db1237;color:#db1237;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px}.back-btn:hover{background:#db1237;color:#fff}.export-btn{background:#db1237;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.export-btn:hover{background:#b00f2d}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:#fff;padding:20px;border-radius:10px;box-shadow:0 2px 8px #0000000f}.stat-card.wide{grid-column:span 2}.stat-card h3{margin:0 0 8px;font-size:14px;color:#667781;font-weight:500}.stat-value{margin:0;font-size:32px;font-weight:600;color:#db1237}.character-stats{display:flex;flex-wrap:wrap;gap:8px}.char-stat{background:#fce8ec;color:#db1237;padding:6px 12px;border-radius:20px;font-size:14px}.filter-bar{background:#fff;padding:16px;border-radius:10px;margin-bottom:20px;display:flex;align-items:center;gap:12px;box-shadow:0 2px 8px #0000000f}.filter-bar label{font-weight:500;color:#303030}.filter-bar select{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;min-width:180px}.conversations-table{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000f;overflow:hidden}.conversations-table table{width:100%;border-collapse:collapse}.conversations-table th,.conversations-table td{padding:14px 16px;text-align:left;border-bottom:1px solid #eee}.conversations-table th{background:#f9f9f9;font-weight:600;color:#303030;font-size:14px}.conversations-table td{font-size:14px;color:#303030}.conversations-table tr:hover{background:#f9f9f9}.view-btn{background:#db1237;color:#fff;border:none;padding:6px 14px;border-radius:4px;cursor:pointer;font-size:13px}.view-btn:hover{background:#b00f2d}.loading{text-align:center;padding:20px;color:#667781}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;padding:16px;border-top:1px solid #eee}.pagination button{background:#f0f0f0;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px}.pagination button:hover:not(:disabled){background:#e0e0e0}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{color:#667781;font-size:14px}.conversation-nav{display:flex;justify-content:center;align-items:center;gap:20px;margin-bottom:16px;padding:12px;background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000f}.nav-btn{background:#db1237;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.nav-btn:hover:not(:disabled){background:#b00f2d}.nav-btn:disabled{background:#ccc;cursor:not-allowed}.nav-info{color:#667781;font-size:14px;min-width:80px;text-align:center}.conversation-detail{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000f;overflow:hidden;max-height:calc(100vh - 200px);display:flex;flex-direction:column}.detail-meta{padding:20px;background:#f9f9f9;border-bottom:1px solid #eee;flex-shrink:0}.detail-meta p{margin:4px 0;font-size:14px;color:#303030}.messages-list{padding:20px;overflow-y:auto;flex:1}.messages-list h3{margin:0 0 16px;font-size:16px;color:#303030;position:sticky;top:0;background:#fff;padding-bottom:10px}.message{margin-bottom:16px;padding:12px 16px;border-radius:10px;max-width:85%}.message.user{background:#dcf8c6;margin-left:auto}.message.assistant{background:#f0f0f0}.message-header{display:flex;justify-content:space-between;margin-bottom:6px;font-size:12px}.message-header .role{font-weight:600;color:#db1237;text-transform:capitalize}.message-header .time{color:#667781}.message-content{font-size:14px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}@media(max-width:768px){.stat-card.wide{grid-column:span 1}.conversations-table{overflow-x:auto}.conversations-table table{min-width:600px}.filter-bar{flex-direction:column;align-items:stretch}.filter-bar select{min-width:auto}}*{margin:0;padding:0;box-sizing:border-box}:root{--header-bg: #db1237;--header-text: #ffffff;--chat-bg: #1a1a1a;--user-bubble: #db1237;--bot-bubble: #2d2d2d;--text-primary: #ffffff;--text-secondary: #a0a0a0;--input-bg: #2d2d2d;--send-btn: #db1237;--safe-area-bottom: env(safe-area-inset-bottom, 0px)}html,body,#root{height:100%;height:100dvh;width:100%;overflow:hidden}@supports (height: 100dvh){html,body,#root{height:100dvh}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:16px;line-height:1.4;color:var(--text-primary);background:var(--chat-bg);-webkit-font-smoothing:antialiased}.loading-screen,.error-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;background:var(--chat-bg);color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:var(--header-bg);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}.chat-window{display:flex;flex-direction:column;height:100%;height:100dvh;max-width:100%;margin:0 auto;background:var(--chat-bg);position:relative}.chat-header{display:flex;align-items:center;padding:10px 16px;background:linear-gradient(135deg,#db1237,#8a0c24);color:var(--header-text);flex-shrink:0;padding-top:max(10px,env(safe-area-inset-top))}.header-avatar{width:40px;height:40px;border-radius:50%;overflow:hidden;margin-right:12px;flex-shrink:0}.header-avatar img{width:100%;height:100%;object-fit:cover}.header-info{flex:1;min-width:0}.header-name{font-size:17px;font-weight:500;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-show{font-size:13px;opacity:.8}.header-user{margin-left:auto;padding-left:12px;flex-shrink:0}.user-phone{font-size:12px;background:#fff3;padding:4px 10px;border-radius:12px;opacity:.9}.chat-messages{flex:1;overflow-y:auto;overflow-x:hidden;padding:8px 12px;background:var(--chat-bg)}.message-list{display:flex;flex-direction:column;gap:4px}.message-bubble{display:flex;flex-direction:column;max-width:85%;position:relative;margin-bottom:2px}.message-bubble.user{align-self:flex-end;align-items:flex-end}.message-bubble.bot{align-self:flex-start;align-items:flex-start}.bubble-content{padding:8px 12px;border-radius:8px;position:relative;box-shadow:0 1px .5px #00000021}.message-bubble.user .bubble-content{background:var(--user-bubble);border-top-right-radius:0}.message-bubble.bot .bubble-content{background:var(--bot-bubble);border-top-left-radius:0}.bubble-content p{margin:0;word-wrap:break-word;white-space:pre-wrap}.bubble-time{display:block;font-size:11px;color:var(--text-secondary);margin-top:4px;text-align:right}.bubble-tail{position:absolute;top:0;width:8px;height:13px}.message-bubble.user .bubble-tail{right:-8px;background:var(--user-bubble);clip-path:polygon(0 0,100% 0,0 100%)}.message-bubble.bot .bubble-tail{left:-8px;background:var(--bot-bubble);clip-path:polygon(100% 0,0 0,100% 100%)}.typing-indicator{display:flex;gap:4px;padding:4px 0}.typing-indicator span{width:8px;height:8px;background:#90949c;border-radius:50%;animation:typing 1.4s infinite ease-in-out both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.chat-input{flex-shrink:0;padding:8px 12px;padding-bottom:calc(8px + var(--safe-area-bottom));background:#1a1a1a}.input-container{display:flex;align-items:flex-end;gap:8px;background:var(--input-bg);border-radius:24px;padding:6px 6px 6px 16px}.input-container textarea{flex:1;border:none;outline:none;font-size:16px;line-height:1.4;resize:none;max-height:120px;padding:6px 0;background:transparent;font-family:inherit;color:#fff}.input-container textarea::placeholder{color:#888}.send-button{width:44px;height:44px;border:none;border-radius:50%;background:var(--send-btn);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:opacity .2s}.send-button:disabled{opacity:.5;cursor:not-allowed}.send-button:not(:disabled):active{opacity:.8}.send-button svg{transform:translate(2px)}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.back-button{background:none;border:none;color:var(--header-text);padding:8px;margin-right:4px;margin-left:-8px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%}.back-button:active{background:#ffffff1a}.character-list-screen{display:flex;flex-direction:column;height:100%;background:var(--chat-bg)}.character-list-header{background:linear-gradient(135deg,#db1237,#8a0c24);color:var(--header-text);padding:24px 16px;padding-top:max(24px,env(safe-area-inset-top));text-align:center}.character-list-header h1{font-size:24px;font-weight:600;margin:0 0 4px}.character-list-header p{font-size:14px;opacity:.85;margin:0}.character-list{flex:1;overflow-y:auto;padding:12px}.character-card{display:flex;align-items:center;width:100%;background:#2d2d2d;border:none;border-radius:12px;padding:12px 16px;margin-bottom:8px;cursor:pointer;text-align:left;box-shadow:0 1px 2px #0000004d;transition:transform .1s,box-shadow .1s}.character-card:active{transform:scale(.98);box-shadow:0 1px 1px #0006}.character-avatar{width:56px;height:56px;border-radius:50%;overflow:hidden;margin-right:14px;flex-shrink:0;background:var(--header-bg)}.character-avatar img{width:100%;height:100%;object-fit:cover}.avatar-fallback{width:100%;height:100%;display:none;align-items:center;justify-content:center;font-size:24px;font-weight:600;color:#fff;background:var(--header-bg)}.character-info{flex:1;min-width:0}.character-info h3{font-size:17px;font-weight:500;margin:0 0 2px;color:#fff}.character-show{font-size:14px;color:#a0a0a0}.character-arrow{color:#a0a0a0;flex-shrink:0}.series-list-screen{display:flex;flex-direction:column;height:100%;background:var(--chat-bg)}.series-list-header{background:linear-gradient(135deg,#db1237,#8a0c24);color:var(--header-text);padding:40px 16px;padding-top:max(40px,calc(env(safe-area-inset-top) + 20px));text-align:center;position:relative}.stage-logo{height:48px;width:auto;margin-bottom:12px}.header-back-button{position:absolute;left:12px;top:max(16px,env(safe-area-inset-top));background:#ffffff26;border:none;color:var(--header-text);padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%}.header-back-button:active{background:#ffffff40}.series-list-header h1{font-size:32px;font-weight:700;margin:0 0 8px;letter-spacing:2px}.series-list-header p{font-size:16px;opacity:.9;margin:0;font-weight:400}.series-list{flex:1;overflow-y:auto;padding:16px}.series-card{display:flex;align-items:center;width:100%;background:#2d2d2d;border:none;border-radius:16px;padding:16px;margin-bottom:12px;cursor:pointer;text-align:left;box-shadow:0 2px 8px #0000004d;transition:transform .1s,box-shadow .1s}.series-card:active{transform:scale(.98);box-shadow:0 1px 4px #0006}.series-poster{width:72px;height:72px;border-radius:12px;overflow:hidden;margin-right:16px;flex-shrink:0;background:linear-gradient(135deg,var(--header-bg) 0%,#8a0c24 100%)}.series-poster img{width:100%;height:100%;object-fit:cover}.series-poster-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;color:#fff}.series-info{flex:1;min-width:0}.series-info h3{font-size:18px;font-weight:600;margin:0 0 4px;color:#fff}.series-count{font-size:14px;color:#a0a0a0}.series-arrow{color:#a0a0a0;flex-shrink:0}.series-page-screen{display:flex;flex-direction:column;height:100%;background:var(--chat-bg)}.series-page-header{display:flex;align-items:center;background:linear-gradient(135deg,#db1237,#8a0c24);color:var(--header-text);padding:16px;padding-top:max(16px,env(safe-area-inset-top))}.series-page-header .back-button{margin-right:12px;margin-left:0}.series-page-title{flex:1}.series-page-title h1{font-size:20px;font-weight:600;margin:0 0 2px}.series-page-title p{font-size:13px;opacity:.85;margin:0}@media(min-width:768px){.chat-window,.character-list-screen,.series-list-screen,.series-page-screen{max-width:500px;margin:0 auto;border-left:1px solid #ddd;border-right:1px solid #ddd}}
