:root{color-scheme:light;--text: #1f2937;--muted: #718096;--line: #e5e7eb;--panel: #ffffff;--soft: #f7fafc;--primary: #2563eb;--primary-dark: #1d4ed8;--accent: #10b981;--bubble: #fff7cf;--shadow: 0 24px 80px rgba(31, 41, 55, .2);font-family:Inter,Microsoft YaHei,PingFang SC,Arial,sans-serif}*{box-sizing:border-box}html,body,#app{min-width:1180px;min-height:100vh;margin:0}body{color:var(--text);background:#eef4f8}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}.auth-shell,.admin-page{min-height:100vh;background:linear-gradient(135deg,#ecf7fff0,#fff8e8e6),url(/assets/chat-reference-bg-CvB-alnp.png) center / cover no-repeat}.auth-layout,.create-layout{display:grid;grid-template-columns:1fr 440px;gap:56px;align-items:center;width:min(1120px,calc(100vw - 96px));min-height:100vh;margin:0 auto}.brand-mark{display:grid;width:64px;height:64px;place-items:center;border-radius:18px;background:linear-gradient(135deg,#111827,#2563eb);color:#fff;font-weight:800;letter-spacing:0;box-shadow:0 16px 40px #2563eb57}.brand-mark.small{width:38px;height:38px;border-radius:12px;font-size:14px}.eyebrow{margin:28px 0 12px;color:var(--primary);font-size:14px;font-weight:700}h1{max-width:640px;margin:0;font-size:54px;line-height:1.08;letter-spacing:0}.auth-copy,.create-hero p{max-width:560px;margin:22px 0 0;color:#4b5563;font-size:18px;line-height:1.8}.auth-stats{display:flex;gap:12px;margin-top:36px}.auth-stats span,.notice{border:1px solid rgba(37,99,235,.15);border-radius:8px;background:#ffffffb8;color:#334155;padding:10px 14px}.auth-card,.create-panel{border:1px solid rgba(255,255,255,.7);border-radius:8px;background:#ffffffeb;box-shadow:var(--shadow);padding:34px;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.panel-title{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:26px}.panel-title p{margin:0;font-size:22px;font-weight:800}.panel-title span{color:var(--muted);font-size:13px}.form-stack{display:grid;gap:18px}.form-stack label,.search-box{display:grid;gap:8px;color:#4b5563;font-size:13px;font-weight:700}input,textarea{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text);outline:none;transition:border-color .18s ease,box-shadow .18s ease}input{height:46px;padding:0 14px}textarea{resize:none;padding:14px}input:focus,textarea:focus{border-color:#2563eba6;box-shadow:0 0 0 4px #2563eb1a}.primary-button,.secondary-button,.ghost-button,.primary-link{display:inline-flex;align-items:center;justify-content:center;min-height:42px;border-radius:8px;border:0;cursor:pointer;font-weight:800}.primary-button{background:var(--primary);color:#fff}.primary-button:hover{background:var(--primary-dark)}.secondary-button,.ghost-button,.primary-link{border:1px solid var(--line);background:#fff;color:#1f2937;padding:0 16px}.wide{width:100%}.setup-panel{margin-top:22px}.notice{line-height:1.6;font-weight:500}.status-text{min-height:22px;margin:18px 0 0;color:var(--muted);font-size:14px}.status-text.error{color:#dc2626}.status-text.success{color:#059669}.toast-message{position:fixed;top:24px;left:50%;z-index:80;max-width:min(520px,calc(100vw - 32px));transform:translate(-50%);border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 16px 42px #0f172a29;padding:12px 16px;color:var(--text);font-size:14px;line-height:1.5}.toast-message.error{border-color:#fecaca;background:#fef2f2;color:#b91c1c}.toast-message.success{border-color:#bbf7d0;background:#f0fdf4;color:#047857}.topbar{display:flex;align-items:center;justify-content:space-between;width:min(1120px,calc(100vw - 96px));margin:0 auto;padding:24px 0}.brand-link,.top-actions,.workspace-brand{display:flex;align-items:center;gap:12px}.top-actions a{color:#334155;font-weight:700}.top-actions a.active{color:var(--primary)}.create-layout{min-height:calc(100vh - 86px)}.room-preview{display:grid;gap:14px;border:1px solid var(--line);border-radius:8px;background:var(--soft);padding:18px;margin-bottom:20px}.room-preview div{display:flex;align-items:center;gap:10px}.room-preview p{margin:0;color:var(--muted);line-height:1.7}.room-dot{width:10px;height:10px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 6px #10b9811f}.result-box{display:grid;gap:12px;margin-top:20px;border:1px solid rgba(16,185,129,.2);border-radius:8px;background:#f0fdf4;padding:16px}.result-box span{color:#047857;font-size:13px;font-weight:800}.result-box code{overflow-wrap:anywhere;color:#064e3b}.button-row{display:flex;gap:10px}.dashboard-layout,.settings-layout{width:min(1120px,calc(100vw - 96px));margin:0 auto;padding:42px 0 72px}.page-heading h1{font-size:42px}.page-heading p:last-child{max-width:680px;margin:16px 0 0;color:#4b5563;font-size:17px;line-height:1.8}.metric-grid{display:grid;grid-template-columns:190px 190px minmax(360px,1fr);gap:16px;align-items:stretch;margin:28px 0 18px}.metric-card,.table-panel,.settings-card{border:1px solid rgba(255,255,255,.7);border-radius:8px;background:#fffffff0;box-shadow:0 16px 50px #1f29371f}.metric-card{display:grid;gap:8px;padding:18px}.metric-card span{color:var(--muted);font-size:13px;font-weight:800}.metric-card strong{font-size:32px}.create-room-form{display:grid;grid-template-columns:minmax(0,1fr) 150px;gap:12px;align-items:end;justify-self:end;width:min(520px,100%)}.create-room-form label{display:grid;gap:8px;color:#4b5563;font-size:13px;font-weight:800}.create-action{min-width:150px}.table-panel{padding:20px}.room-table{display:grid;gap:0;overflow:hidden;border:1px solid var(--line);border-radius:8px;background:#fff}.room-row{display:grid;grid-template-columns:170px 100px 190px minmax(260px,1fr) 230px;gap:12px;align-items:center;min-height:58px;border-bottom:1px solid #edf0f3;padding:10px 14px;color:#475569;font-size:13px}.room-row:last-child{border-bottom:0}.room-head{min-height:44px;background:#f8fafc;color:#334155;font-weight:900}.room-name{display:grid;min-width:0;gap:3px;color:var(--primary);font-weight:900}.room-name strong,.room-name small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-name small{color:var(--muted);font-size:12px;font-weight:700}.room-row code{overflow:hidden;color:#334155;text-overflow:ellipsis;white-space:nowrap}.status-pill{justify-self:start;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:900}.status-pill.active{background:#dcfce7;color:#047857}.status-pill.closed{background:#f1f5f9;color:#64748b}.row-actions{display:flex;gap:8px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;background:#0f172a75;padding:24px}.room-edit-modal{display:grid;gap:18px;width:min(560px,calc(100vw - 32px));border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 24px 70px #0f172a3d;padding:22px}.modal-title-row{display:flex;align-items:start;justify-content:space-between;gap:16px}.modal-title-row h2{margin:4px 0 0;color:var(--text);font-size:22px;line-height:1.2}.modal-close-button{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid var(--line);border-radius:8px;background:#fff;color:#64748b;cursor:pointer;font-size:22px;line-height:1}.room-edit-modal label{display:grid;gap:8px;color:#334155;font-size:13px;font-weight:800}.room-edit-modal textarea{min-height:132px;resize:vertical;line-height:1.6}.modal-action-row{display:flex;justify-content:end;gap:10px}.danger-button{display:inline-flex;align-items:center;justify-content:center;min-height:42px;border:1px solid #fecaca;border-radius:8px;background:#fff;color:#dc2626;cursor:pointer;font-weight:800;padding:0 14px}.danger-button:disabled{cursor:not-allowed;opacity:.46}.empty-state{padding:28px;color:var(--muted);text-align:center}.settings-card{width:460px;margin-top:28px;padding:28px}.chat-page{display:grid;place-items:center;min-height:100vh;overflow:hidden;background:#25333a}.chat-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(#14222885,#14222885),url(/assets/chat-reference-bg-CvB-alnp.png) center / cover no-repeat;filter:saturate(.95)}.chat-workspace{position:relative;display:grid;grid-template-columns:300px 1fr;width:min(1120px,calc(100vw - 96px));height:min(720px,calc(100vh - 96px));overflow:hidden;border-radius:8px;background:var(--panel);box-shadow:0 30px 90px #0f172a57}.conversation-list{display:flex;min-width:0;flex-direction:column;border-right:1px solid var(--line);background:#fbfcfe}.room-side{display:flex;min-width:0;min-height:0;flex-direction:column;border-right:1px solid var(--line);background:linear-gradient(180deg,#fff,#f7fafc)}.side-room-card{display:grid;gap:10px;margin:18px;border:1px solid var(--line);border-radius:8px;background:#fff;padding:16px}.side-room-card span{color:var(--muted);font-size:12px;font-weight:900}.side-room-card strong{font-size:24px}.room-code-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.room-code-main{display:grid;min-width:0;gap:3px}.room-code-main strong,.room-code-main small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-code-main small{color:var(--muted);font-size:12px;font-weight:700}.copy-room-button{min-height:34px;border:1px solid rgba(37,99,235,.18);border-radius:8px;background:#eff6ff;color:var(--primary);cursor:pointer;font-size:12px;font-weight:900;padding:0 10px}.side-link{margin:auto 18px 18px}.room-user-section{display:grid;min-height:0;grid-template-rows:auto 1fr;padding:0 18px 16px}.side-section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;color:var(--muted);font-size:12px;font-weight:900}.side-section-title strong{color:var(--primary)}.room-user-list{display:grid;align-content:start;gap:8px;min-height:0;overflow:auto}.room-user-card{position:relative;display:grid;grid-template-columns:38px 1fr;gap:10px;width:100%;min-height:62px;border:1px solid transparent;border-radius:8px;background:transparent;cursor:pointer;padding:10px;text-align:left}.room-user-card.active,.room-user-card:hover{border-color:#2563eb29;background:#fff;box-shadow:0 10px 26px #0f172a0f}.room-user-card.self{cursor:default}.room-user-main{display:grid;min-width:0;gap:4px}.room-user-main strong,.room-user-main small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-user-main strong{color:#172033;font-size:14px}.room-user-main small{color:var(--muted);font-size:12px}.unread-badge{position:absolute;top:7px;right:7px;display:grid;min-width:20px;height:20px;place-items:center;border:2px solid #fff;border-radius:999px;background:#ef4444;color:#fff;font-size:11px;font-weight:900;padding:0 5px}.workspace-brand{height:58px;padding:0 18px;border-bottom:1px solid var(--line)}.workspace-brand div{display:grid;gap:2px;min-width:0}.workspace-brand span{color:var(--muted);font-size:12px}.room-title-remark{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-box{padding:12px 16px 4px}.search-box>span{position:absolute;width:1px;height:1px;overflow:hidden}.search-box input{height:36px;background:#fff}.tabs{display:flex;gap:20px;padding:12px 18px}.tabs button{border:0;background:transparent;color:var(--muted);cursor:pointer;font-weight:800;padding:0 0 6px}.tabs button.active{border-bottom:2px solid #facc15;color:var(--text)}.thread-list{overflow:auto;padding-bottom:10px}.thread-card{display:grid;grid-template-columns:42px 1fr auto;gap:10px;width:100%;border:0;border-bottom:1px solid #edf0f3;background:transparent;cursor:pointer;padding:12px 14px;text-align:left}.thread-card.active,.thread-card:hover{background:#fff}.avatar{display:grid;width:38px;height:38px;place-items:center;border-radius:50%;background:#dbeafe;color:#1d4ed8;font-weight:900}.avatar.admin{background:#dcfce7;color:#047857}.thread-main{min-width:0}.thread-title{display:flex;gap:6px;align-items:center;font-weight:800}.official-tag{border-radius:4px;background:#4b5563;color:#fff;font-size:11px;padding:1px 4px}.thread-preview,.thread-meta{display:block;overflow:hidden;color:var(--muted);font-size:12px;text-overflow:ellipsis;white-space:nowrap}.thread-price{color:#f97316;font-size:12px;font-weight:900}.chat-panel{display:grid;min-width:0;min-height:0;grid-template-rows:64px minmax(0,1fr) 192px;background:#f6f8fb}.chat-header{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--line);background:#fff;padding:0 18px}.chat-header div{display:grid;gap:3px}.chat-header span{color:var(--muted);font-size:12px}.chat-header-actions,.guest-header-actions,.chat-header .chat-header-actions{display:flex;align-items:center;gap:12px}.sound-reminder-toggle,.chat-history-toggle{display:inline-flex;align-items:center;min-height:42px;gap:8px;color:#374151;cursor:pointer;font-size:13px;font-weight:800;white-space:nowrap}.sound-reminder-toggle input,.chat-history-toggle input{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.message-timeline{min-height:0;overflow:auto;scroll-behavior:smooth;padding:30px 34px}.message-row{display:flex;gap:10px;margin-bottom:22px}.message-row.admin{justify-content:flex-end}.message-row.admin .message-body{align-items:flex-end}.message-body{display:grid;gap:7px;max-width:58%}.message-time{color:#94a3b8;font-size:12px}.message-bubble{border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 8px 24px #0f172a0a;padding:11px 13px;line-height:1.6;white-space:pre-wrap}.message-bubble.image{overflow:hidden;background:#fff;padding:6px}.message-image-button{display:block;border:0;background:transparent;cursor:zoom-in;padding:0}.message-image{display:block;max-width:min(320px,46vw);max-height:260px;border-radius:6px;object-fit:contain}.message-image-placeholder{position:relative;display:grid;width:min(240px,64vw);aspect-ratio:4 / 3;place-items:center;overflow:hidden;border-radius:8px;background:#e5e7eb;color:#475569;font-size:13px}.message-image-placeholder.failed{background:#fee2e2;color:#b91c1c}.message-image.preview{width:100%;height:100%;max-width:none;max-height:none;object-fit:cover;opacity:.72}.image-progress{position:absolute;max-width:calc(100% - 20px);overflow-wrap:anywhere;border-radius:6px;background:#0f172ab8;color:#fff;font-size:13px;line-height:1.35;padding:4px 8px;text-align:center}.image-viewer{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:grid;place-items:center;background:#0f172ac7;padding:48px}.image-viewer-image{display:block;width:auto;height:auto;max-width:calc(100vw - 96px);max-height:calc(100vh - 96px);border-radius:8px;box-shadow:0 24px 80px #0000005c;object-fit:contain}.image-viewer-close{position:fixed;top:24px;right:24px;display:grid;width:36px;height:36px;place-items:center;border:1px solid rgba(255,255,255,.28);border-radius:999px;background:#0f172ab8;color:#fff;cursor:pointer;font-size:24px;line-height:1;padding:0}.message-row.admin .message-bubble{border-color:#fff2bf;background:var(--bubble)}.composer{display:grid;border-top:1px solid var(--line);background:#fff;padding:16px 22px 18px}.chat-status{min-height:18px;margin:0 0 8px;font-size:13px}.message-form{display:grid;grid-template-columns:minmax(0,1fr) 64px;gap:10px;height:100%;align-items:end}.composer-input-wrap{display:grid;grid-template-rows:auto minmax(0,1fr);gap:8px;height:100%;min-height:112px;align-content:stretch;border:1px solid var(--line);border-radius:8px;background:#fff;padding:12px 14px;transition:border-color .18s ease,box-shadow .18s ease}.composer-input-wrap:focus-within{border-color:#2563eba6;box-shadow:0 0 0 4px #2563eb1a}.image-preview-list{display:flex;grid-row:1;flex-wrap:wrap;gap:8px}.image-preview{position:relative;flex:0 0 auto;width:86px;height:64px;border:1px solid var(--line);border-radius:8px;background:#f8fafc;padding:4px}.image-preview img{display:block;width:100%;height:100%;border-radius:6px;object-fit:cover}.image-preview-remove{position:absolute;top:-7px;right:-7px;display:grid;width:20px;height:20px;place-items:center;border:2px solid #fff;border-radius:999px;background:#ef4444;color:#fff;cursor:pointer;font-size:14px;font-weight:900;line-height:1;padding:0}.composer-action-stack{display:grid;gap:8px;justify-items:center;align-self:end}.composer-upload-button{display:grid;width:24px;height:24px;place-items:center;border:1px solid #d7dde8;border-radius:999px;background:#fff;color:#2563eb;cursor:pointer;font-size:18px;font-weight:500;line-height:1;padding:0}.composer-upload-button:hover{border-color:#2563eb5c;background:#eff6ff}.image-input{display:none}.composer-input-wrap textarea{grid-row:2;height:100%;min-height:0;border:0;border-radius:0;background:transparent;box-shadow:none;padding:0}.composer-input-wrap textarea:focus{border-color:transparent;box-shadow:none}.composer-input-wrap:has(.image-preview) textarea{min-height:46px}.send-button{width:64px;min-height:34px;padding:0 14px}.send-button:disabled{cursor:not-allowed;opacity:.55}.empty-chat-state{display:grid;min-height:100%;place-items:center;color:#94a3b8;font-weight:800}.empty-state.compact{border:1px dashed var(--line);border-radius:8px;background:#fff;padding:18px}.guest-chat-page{display:grid;place-items:center;min-height:100vh;background:linear-gradient(#14222875,#14222875),url(/assets/chat-reference-bg-CvB-alnp.png) center / cover no-repeat}.guest-chat-shell{display:grid;grid-template-rows:64px minmax(0,1fr) 192px;width:min(920px,calc(100vw - 96px));height:min(720px,calc(100vh - 96px));min-width:760px;overflow:hidden;border-radius:8px;background:#f8fafc;box-shadow:var(--shadow)}.guest-header{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:18px;border-bottom:1px solid var(--line);background:#fff;padding:0 18px}.guest-header div{display:flex;align-items:center;gap:12px}.guest-header-actions>span{color:var(--muted);font-size:13px;font-weight:800}.guest-refresh-warning{margin:0;color:#dc2626;font-size:13px;font-weight:900;text-align:center;white-space:nowrap}.guest-timeline{background:#f8fafc}.guest-chat-page .message-row.admin{justify-content:flex-start}.guest-chat-page .message-row.admin .message-body{align-items:flex-start}.guest-chat-page .message-row.admin .message-bubble{border-color:var(--line);background:#fff}.guest-chat-page .message-row.guest{justify-content:flex-end}.guest-chat-page .message-row.guest .message-body{align-items:flex-end}.guest-chat-page .message-row.guest .message-bubble{border-color:#fff2bf;background:var(--bubble)}@media (max-width: 767px){html,body,#app{min-width:0;min-height:100dvh;overscroll-behavior-y:none}.chat-page,.guest-chat-page{min-height:100dvh;overflow:hidden;overscroll-behavior-y:none;touch-action:pan-y}.chat-workspace{grid-template-columns:minmax(0,1fr);grid-template-rows:auto minmax(0,1fr);width:100vw;height:100dvh;overscroll-behavior-y:none;touch-action:pan-y;border-radius:0;box-shadow:none}.room-side{min-height:0;border-right:0;border-bottom:1px solid var(--line)}.workspace-brand{height:56px;padding:0 12px}.side-room-card,.side-link{display:none}.room-user-section{grid-template-rows:auto auto;padding:8px 12px 10px}.side-section-title{margin-bottom:8px}.room-user-list{display:flex;gap:8px;overflow-x:auto;overflow-y:hidden;padding-bottom:2px}.room-user-card{flex:0 0 150px;grid-template-columns:32px minmax(0,1fr);min-height:54px;padding:8px}.avatar{width:32px;height:32px;font-size:13px}.chat-panel,.guest-chat-shell{grid-template-rows:auto minmax(0,1fr) auto}.chat-header{min-height:56px;gap:10px;padding:8px 12px}.chat-header div,.guest-header div{min-width:0}.chat-header strong,.chat-header span,.guest-header strong,.guest-header-actions>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-header-actions,.guest-header-actions{gap:8px}.sound-reminder-toggle,.chat-history-toggle{min-height:44px}.sound-reminder-toggle>span,.chat-history-toggle>span{display:none}.message-timeline{overscroll-behavior:contain;padding:16px 12px;touch-action:pan-y;-webkit-overflow-scrolling:touch}.message-row{gap:8px;margin-bottom:16px}.message-body{max-width:calc(100% - 40px)}.message-bubble{overflow-wrap:anywhere;word-break:break-word}.message-image{max-width:min(240px,calc(100vw - 92px));max-height:220px}.composer{padding:10px 12px calc(10px + env(safe-area-inset-bottom));touch-action:manipulation}.message-form{grid-template-columns:minmax(0,1fr) 52px;gap:8px}.composer-input-wrap{min-height:84px;padding:10px 12px}.composer-input-wrap textarea{font-size:16px}.image-preview-list{gap:6px}.image-preview{width:64px;height:48px}.composer-action-stack{gap:8px}.composer-upload-button{width:44px;height:44px}.send-button{width:52px;min-height:44px;padding:0 8px}.guest-chat-shell{width:100vw;height:100dvh;min-width:0;overscroll-behavior-y:none;touch-action:pan-y;border-radius:0;box-shadow:none}.guest-header{grid-template-areas:"brand actions" "warning warning";grid-template-columns:minmax(0,1fr) auto;grid-template-rows:auto auto;min-height:0;gap:4px 8px;padding:6px 10px}.guest-header>div:first-child{grid-area:brand}.guest-header .brand-mark.small{width:32px;height:32px;border-radius:10px;font-size:12px}.guest-header strong{font-size:18px;line-height:1.2}.guest-refresh-warning{grid-area:warning;font-size:12px;line-height:1.25;text-align:left;white-space:normal}.guest-header-actions{grid-area:actions;justify-content:flex-end}.guest-header .sound-reminder-toggle,.guest-header .chat-history-toggle{min-height:32px;gap:4px}.guest-header .sound-reminder-toggle>span,.guest-header .chat-history-toggle>span{display:inline;font-size:12px}.guest-header-actions>span{max-width:none;font-size:12px}.image-viewer{padding:16px;touch-action:pinch-zoom}.image-viewer-image{max-width:calc(100vw - 32px);max-height:calc(100dvh - 32px);touch-action:pinch-zoom}.image-viewer-close{top:12px;right:12px;width:44px;height:44px}}
