/* ══════════════════════════════════════════════════
   Companion Hub — Modular CSS
   Warmstone Design Tokens
   ══════════════════════════════════════════════════ */

/* ── Dock (bottom tab bar) ── */
.hall-dock{position:fixed;bottom:0;left:0;right:0;z-index:20;display:flex;justify-content:space-around;align-items:center;background:var(--panel,#fff);border-top:1px solid var(--border,#e7e5e4);padding:6px 0 calc(6px + env(safe-area-inset-bottom));box-shadow:0 -2px 8px rgba(28,25,23,.06)}
.hall-dock-btn{appearance:none;border:none;background:transparent;color:var(--text-dim,#a8a29e);display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 12px;font:600 11px/1 var(--font-b,system-ui);cursor:pointer;transition:color .15s}
.hall-dock-btn i{font-size:18px}
.hall-dock-btn.active{color:var(--primary,#b45309)}

/* ── Hub shared ── */
.hub-tab{display:none;padding-bottom:72px}
.hub-tab.is-active{display:block}
.hub-sec{max-width:960px;margin:0 auto;padding:16px 16px 32px}
.hub-title{font:700 20px/1.3 var(--font-display,'Noto Sans SC',system-ui);color:var(--text,#1c1917);letter-spacing:-.01em}
.hub-sub{font-size:13px;color:var(--text-dim,#a8a29e);margin-top:4px;line-height:1.6}
.hub-btn{appearance:none;border:1px solid var(--border,#e7e5e4);background:var(--panel,#fff);color:var(--text,#1c1917);border-radius:9999px;padding:8px 16px;font:600 13px/1 var(--font-b,system-ui);cursor:pointer;transition:all .15s}
.hub-btn:hover{border-color:var(--primary,#b45309);color:var(--primary,#b45309)}
.hub-btn:disabled{opacity:.45;cursor:not-allowed}
.hub-btn.primary{background:var(--primary,#b45309);border-color:var(--primary,#b45309);color:#fff}
.hub-btn.primary:hover{background:var(--primary-hover,#92400e)}
.hub-pill{display:inline-block;font-size:11px;font-weight:600;padding:3px 10px;border-radius:9999px;background:var(--color-accent-subtle,rgba(180,83,9,.08));color:var(--primary,#b45309);line-height:1.4}
.hub-empty{text-align:center;padding:48px 16px;color:var(--text-dim,#a8a29e);font-size:14px;line-height:1.8}
.hub-empty i{display:block;font-size:28px;margin-bottom:12px;opacity:.5}
.hub-loading{text-align:center;padding:32px 16px;color:var(--text-dim,#a8a29e);font-size:13px}
.hub-error{padding:10px 14px;border-radius:12px;background:rgba(185,28,28,.08);color:var(--danger,#b91c1c);font-size:13px;line-height:1.6}
.cp-shell-sec{padding-top:0}
.cp-discover-sec{text-align:center;padding-top:0}

/* ── Discover Tab (邂逅) ── */

/* Balance badge */
.dsc-balance{display:inline-flex;align-items:center;gap:4px;padding:4px 12px;border-radius:9999px;background:linear-gradient(135deg,rgba(180,83,9,.10) 0%,rgba(180,83,9,.04) 100%);color:var(--primary,#b45309);font:600 13px/1.4 var(--font-b,system-ui)}

/* Game filter chips */
.dsc-filter{margin-top:14px;display:flex;flex-direction:column;gap:10px}
.dsc-filter-bar{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 12px;border:1px solid var(--border,#e7e5e4);border-radius:14px;background:var(--panel,#fff)}
.dsc-filter-summary{min-width:0;display:flex;align-items:center;gap:8px;font:600 12px/1.4 var(--font-b,system-ui);color:var(--text-dim,#a8a29e)}
.dsc-filter-summary strong{min-width:0;color:var(--text,#1c1917);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dsc-filter-toggle{appearance:none;border:1px solid var(--border,#e7e5e4);background:var(--color-bg-sunken,#f2efe9);color:var(--text,#1c1917);border-radius:9999px;padding:6px 10px;display:inline-flex;align-items:center;gap:5px;font:700 12px/1 var(--font-b,system-ui);cursor:pointer;flex-shrink:0}
.dsc-filter-toggle:hover{border-color:var(--primary,#b45309);color:var(--primary,#b45309)}
.dsc-game-chips{display:flex;flex-wrap:wrap;gap:8px}
.dsc-game-chip{appearance:none;border:1px solid var(--border,#e7e5e4);background:var(--panel,#fff);color:var(--text,#1c1917);border-radius:9999px;padding:6px 14px;font:600 12px/1 var(--font-b,system-ui);cursor:pointer;transition:all .15s}
.dsc-game-chip:hover{border-color:var(--primary,#b45309);color:var(--primary,#b45309)}
.dsc-game-chip.is-active{background:var(--primary,#b45309);border-color:var(--primary,#b45309);color:#fff}

/* Kanban layout */
.dsc-kanban{display:flex;flex-direction:column;gap:28px}
.dsc-kanban-section{border-radius:var(--radius-lg,20px);border:1px solid var(--border,#e7e5e4);background:var(--panel,#fff);padding:20px;box-shadow:var(--shadow-sm,0 1px 2px rgba(28,25,23,.05))}
.dsc-kanban-header{display:flex;justify-content:space-between;align-items:center;gap:12px;border-bottom:1px solid var(--border,#e7e5e4);padding-bottom:12px;margin-bottom:16px;font:600 16px/1.4 var(--font-b,system-ui);color:var(--text,#1c1917)}
.dsc-kanban-header-left{display:flex;align-items:center;gap:8px}
.dsc-kanban-header-left i{color:var(--primary,#b45309);font-size:16px}
.dsc-kanban-header-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.dsc-section-toggle{appearance:none;border:1px solid var(--border,#e7e5e4);background:var(--panel,#fff);color:var(--text-mid,#57534e);width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s}
.dsc-section-toggle:hover{border-color:var(--primary,#b45309);color:var(--primary,#b45309)}
.dsc-kanban-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}

/* Character cards */
.dsc-card{border-radius:var(--radius-lg,20px);border:1px solid var(--border,#e7e5e4);background:var(--panel,#fff);overflow:hidden;cursor:pointer;transition:transform .2s var(--easing-default,ease),box-shadow .2s var(--easing-default,ease)}
.dsc-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md,0 4px 12px rgba(28,25,23,.08))}
.dsc-card.is-unlocked{border-color:rgba(180,83,9,.25)}

/* Card cover — portrait */
.dsc-card-cover{position:relative;aspect-ratio:3/4;background:linear-gradient(180deg,rgba(180,83,9,.08) 0%,var(--color-bg-sunken,#f2efe9) 100%);overflow:hidden}
.dsc-card-cover img{display:block;width:100%;height:100%;object-fit:cover}
.dsc-card-cover-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--primary,#b45309);font:800 36px/1 var(--font-narrative,'Noto Serif SC',serif)}

/* Card badge */
.dsc-card-badge{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.dsc-card-badge.is-unlocked{background:rgba(180,83,9,.85);color:#fff}
.dsc-card-badge.is-locked{background:rgba(28,25,23,.35);color:rgba(255,255,255,.8)}

/* Card body */
.dsc-card-body{padding:12px 14px 14px}
.dsc-card-name{font:700 15px/1.3 var(--font-display,'Noto Sans SC',system-ui);color:var(--text,#1c1917);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dsc-card-game{font-size:12px;color:var(--text-dim,#a8a29e);margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dsc-card-tags{display:flex;flex-wrap:wrap;gap:4px}

/* ── Discover overlay (bottom sheet) ── */
.dsc-overlay-backdrop{position:fixed;inset:0;z-index:500;background:rgba(28,25,23,.48);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:dsc-fade-in .25s var(--easing-default,ease) both}
.dsc-overlay{position:fixed;bottom:0;left:50%;transform:translateX(-50%);z-index:501;width:100%;max-width:540px;max-height:min(85vh,720px);background:var(--panel,#fff);border-radius:var(--radius-lg,20px) var(--radius-lg,20px) 0 0;box-shadow:var(--shadow-lg,0 12px 32px rgba(28,25,23,.12));display:flex;flex-direction:column;overflow:hidden;animation:dsc-slide-up .4s cubic-bezier(.32,.72,0,1) both}

@keyframes dsc-fade-in{from{opacity:0}to{opacity:1}}
@keyframes dsc-slide-up{from{transform:translateX(-50%) translateY(100%)}to{transform:translateX(-50%) translateY(0)}}

.dsc-overlay-handle{display:flex;justify-content:center;padding:12px 0 8px}
.dsc-overlay-handle-bar{width:40px;height:5px;background:var(--border,#e7e5e4);border-radius:var(--radius-sm,6px);opacity:.6}
.dsc-overlay-scroll{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;position:relative;padding-bottom:40px}
.dsc-overlay-close{position:absolute;top:12px;right:12px;z-index:10;width:32px;height:32px;border-radius:50%;background:rgba(0,0,0,.3);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#fff;font-size:18px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;transition:transform .2s;line-height:1}
.dsc-overlay-close:hover{transform:rotate(90deg)}

/* Overlay cover */
.dsc-overlay-cover{width:100%;aspect-ratio:3/4;max-height:360px;overflow:hidden;background:linear-gradient(180deg,rgba(180,83,9,.08) 0%,var(--color-bg-sunken,#f2efe9) 100%)}
.dsc-overlay-cover img{display:block;width:100%;height:100%;object-fit:cover}
.dsc-overlay-cover-fallback{display:flex;align-items:center;justify-content:center;width:100%;height:100%;color:var(--primary,#b45309);font:800 52px/1 var(--font-narrative,'Noto Serif SC',serif)}

/* Overlay info */
.dsc-overlay-info{padding:20px 24px 0}
.dsc-overlay-name{font:700 22px/1.3 var(--font-display,'Noto Sans SC',system-ui);color:var(--text,#1c1917)}
.dsc-overlay-role{font-size:14px;color:var(--primary,#b45309);font-weight:600;margin-top:4px}
.dsc-overlay-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.dsc-overlay-bio{margin-top:16px;font:400 14px/1.8 var(--font-narrative,'Noto Serif SC',serif);color:var(--text-mid,#57534e)}
.dsc-overlay-relation{margin-top:12px;padding:12px 16px;border-radius:var(--radius-md,12px);background:var(--color-accent-subtle,rgba(180,83,9,.08));font:italic 400 13px/1.7 var(--font-narrative,'Noto Serif SC',serif);color:var(--text-mid,#57534e)}
.dsc-overlay-origin{margin-top:14px;font-size:13px;color:var(--text-dim,#a8a29e)}
.dsc-overlay-cost{margin-top:8px;font-size:13px;color:var(--text-mid,#57534e)}
.dsc-overlay-actions{padding:20px 24px 24px;display:flex;flex-direction:column;gap:10px}

/* ── Companion Chat (心动名单) ── */

/* Layout */
.cp-layout{display:flex;min-height:60vh;max-height:68vh;border-radius:var(--radius-lg,20px);border:1px solid var(--border,#e7e5e4);overflow:hidden;background:var(--panel,#fff)}

/* Sidebar list */
.cp-list{width:260px;flex-shrink:0;border-right:1px solid var(--border,#e7e5e4);overflow-y:auto;background:var(--color-bg-sunken,#f2efe9)}
.cp-list-head{padding:12px 14px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border,#e7e5e4)}
.cp-list-title{font:700 14px/1.4 var(--font-b,system-ui);color:var(--text,#1c1917)}

/* List items */
.cp-item{appearance:none;border:none;width:100%;text-align:left;padding:12px 14px;border-bottom:1px solid var(--border,#e7e5e4);background:transparent;cursor:pointer;transition:background .12s}
.cp-item:hover{background:var(--panel,#fff)}
.cp-item.active{background:var(--panel,#fff);box-shadow:inset 3px 0 0 var(--primary,#b45309)}
.cp-item-name{font:600 14px/1.4 var(--font-b,system-ui);color:var(--text,#1c1917);display:flex;align-items:center;gap:6px}
.cp-item-meta{font-size:12px;color:var(--text-dim,#a8a29e);margin-top:2px}
.cp-item-preview{font-size:12px;color:var(--text-dim,#a8a29e);margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:180px}
.cp-item-pick{font-size:10px;padding:2px 8px;border-radius:9999px;background:var(--primary,#b45309);color:#fff;font-weight:600;line-height:1.4}
.cp-item-depth{display:inline-block;font-size:10px;font-weight:600;padding:2px 8px;border-radius:9999px;background:var(--color-accent-subtle,rgba(180,83,9,.08));color:var(--primary,#b45309);line-height:1.4}
.cp-item-row{display:flex;gap:10px;align-items:center}
.cp-item-main{min-width:0;flex:1}

/* WeChat companion picker */
.cp-wx-picker{margin:10px;border:1px solid var(--border,#e7e5e4);border-radius:14px;background:var(--panel,#fff);padding:10px;display:flex;flex-direction:column;gap:8px}
.cp-wx-picker-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;font:700 12px/1.4 var(--font-b,system-ui);color:var(--text,#1c1917)}
.cp-wx-picker-head span{display:flex;align-items:center;gap:6px;min-width:0}
.cp-wx-picker-head i{color:#16a34a}
.cp-wx-picker-head em{font-style:normal;font-weight:500;color:var(--text-dim,#a8a29e);text-align:right}
.cp-wx-picker-note{font-size:12px;line-height:1.5;color:var(--primary,#b45309)}
.cp-wx-picker-list{display:flex;flex-direction:column;gap:6px}
.cp-wx-choice{appearance:none;border:1px solid transparent;background:var(--color-bg-sunken,#f2efe9);border-radius:12px;padding:8px;display:flex;align-items:center;gap:8px;text-align:left;cursor:pointer;transition:background .12s,border-color .12s}
.cp-wx-choice:hover{background:var(--panel,#fff);border-color:var(--border,#e7e5e4)}
.cp-wx-choice.active{border-color:rgba(21,128,61,.28);background:rgba(21,128,61,.08)}
.cp-wx-choice-main{min-width:0;flex:1;display:flex;flex-direction:column;gap:2px}
.cp-wx-choice-main strong{font-size:13px;line-height:1.35;color:var(--text,#1c1917);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cp-wx-choice-main em{font-style:normal;font-size:11px;line-height:1.35;color:var(--text-dim,#a8a29e);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cp-wx-choice .hub-pill{flex-shrink:0;padding:3px 8px}

/* Chat area */
.cp-chat{flex:1;display:flex;flex-direction:column;min-width:0}
.cp-chat-head{padding:14px;border-bottom:1px solid var(--border,#e7e5e4);display:flex;justify-content:space-between;align-items:center}
.cp-chat-head-main{min-width:0;flex:1}
.cp-chat-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}
.cp-mobile-back,.cp-mobile-wx{display:none}
.cp-chat-name{font:700 15px/1.4 var(--font-b,system-ui);color:var(--text,#1c1917)}
.cp-chat-hint{font-size:12px;color:var(--text-dim,#a8a29e)}
.cp-chat-body{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}

/* Chat profile header */
.cp-chat-profile{padding:12px 14px;display:flex;gap:12px;border-bottom:1px solid var(--border,#e7e5e4);align-items:center}
.cp-chat-cover{width:48px;height:48px;border-radius:50%;overflow:hidden;flex-shrink:0}
.cp-chat-cover.has-image img{width:100%;height:100%;object-fit:cover}
.cp-chat-cover-fallback{width:48px;height:48px;border-radius:50%;background:var(--color-accent-subtle,rgba(180,83,9,.08));display:flex;align-items:center;justify-content:center;color:var(--primary,#b45309);font:700 18px/1 var(--font-narrative,'Noto Serif SC',serif)}
.cp-chat-summary{font-size:12px;color:var(--text-mid,#57534e);line-height:1.6;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* Avatars */
.cp-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0}
.cp-avatar.has-image img{width:100%;height:100%;object-fit:cover}
.cp-avatar-fallback{width:36px;height:36px;border-radius:50%;background:var(--color-accent-subtle,rgba(180,83,9,.08));display:flex;align-items:center;justify-content:center;color:var(--primary,#b45309);font:700 14px/1 var(--font-narrative,'Noto Serif SC',serif)}

/* Message bubbles */
.cp-msg{display:flex;gap:8px}
.cp-msg.is-user{flex-direction:row-reverse}
.cp-msg.is-system{justify-content:center}
.cp-bubble{max-width:75%;padding:10px 14px;border-radius:16px;font-size:14px;line-height:1.7;word-break:break-word;white-space:pre-wrap}
.cp-msg.is-user .cp-bubble{background:var(--primary,#b45309);color:#fff;border-bottom-right-radius:4px}
.cp-msg.is-npc .cp-bubble{background:var(--color-bg-sunken,#f2efe9);border:1px solid var(--border,#e7e5e4);border-bottom-left-radius:4px}
.cp-msg.is-system .cp-bubble{max-width:100%;border-radius:9999px;background:var(--color-accent-subtle,rgba(180,83,9,.08));color:var(--primary,#b45309);font-size:12px;text-align:center}
.cp-msg-label{font-size:11px;color:var(--text-dim,#a8a29e);margin-bottom:2px}

/* Input area */
.cp-input{padding:10px 14px;border-top:1px solid var(--border,#e7e5e4);display:flex;gap:8px;align-items:flex-end;background:var(--color-bg-sunken,#f2efe9)}
.cp-input-wrap{flex:1;display:flex;flex-direction:column;gap:8px}
.cp-input-meta{display:flex;justify-content:space-between;flex-wrap:wrap}
.cp-textarea{width:100%;min-height:40px;max-height:120px;resize:vertical;padding:10px 14px;border-radius:16px;border:1px solid var(--border,#e7e5e4);font-size:16px;line-height:1.5;background:var(--panel,#fff);color:var(--text,#1c1917);outline:none;transition:border-color .15s}
.cp-textarea:focus{border-color:var(--primary,#b45309)}
.cp-toggle{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-mid,#57534e);cursor:pointer}

/* ── WeChat bind ── */
.wx-bind{margin-top:12px;padding:16px;border-radius:16px;border:1px solid var(--border,#e7e5e4);background:var(--panel,#fff)}
.wx-bind-title{display:flex;justify-content:space-between;align-items:center;font:700 14px/1.4 var(--font-b,system-ui);color:var(--text,#1c1917);margin-bottom:12px}
.wx-bind-body{display:flex;gap:20px;flex-wrap:wrap}
.wx-bind-qr{width:200px;height:200px;border-radius:var(--radius-md,12px);background:var(--color-bg-sunken,#f2efe9);display:flex;align-items:center;justify-content:center;overflow:hidden}
.wx-bind-qr img{width:100%;height:100%;object-fit:contain}
.wx-bind-qr-placeholder{padding:20px;text-align:center;font-size:13px;color:var(--text-dim,#a8a29e)}
.wx-bind-info{flex:1;min-width:200px}
.wx-bind-step{display:flex;align-items:center;gap:10px;margin-bottom:10px;font-size:13px;color:var(--text,#1c1917)}
.wx-bind-step-num{width:24px;height:24px;border-radius:50%;background:var(--primary,#b45309);color:#fff;font:700 12px/1 var(--font-b,system-ui);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.wx-bind-status-line{margin-top:8px;font-size:13px;color:var(--text-mid,#57534e)}
.wx-bind-status-line.is-waiting{color:var(--primary,#b45309)}
.wx-bind-status-line.is-connected,.wx-bind-status-line.is-scanned{color:var(--success,#15803d)}
.wx-bind-status-line.is-error,.wx-bind-status-line.is-expired{color:var(--danger,#b91c1c)}

/* ── WeChat onboarding guide ── */
.wx-guide-backdrop{position:fixed;inset:0;z-index:520;background:rgba(28,25,23,.46);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}
.wx-guide{position:fixed;left:50%;top:50%;z-index:521;width:min(420px,calc(100vw - 32px));transform:translate(-50%,-50%);border-radius:20px;background:var(--panel,#fff);box-shadow:0 24px 70px rgba(28,25,23,.24);padding:24px;color:var(--text,#1c1917)}
.wx-guide-backdrop{animation:dsc-fade-in .2s var(--easing-default,ease) both}
.wx-guide-handle{display:none}
.wx-guide-close{position:absolute;right:12px;top:12px;width:32px;height:32px;border:0;border-radius:50%;background:var(--color-bg-sunken,#f2efe9);color:var(--text-mid,#57534e);font-size:16px;line-height:1;cursor:pointer}
.wx-guide-visual{position:relative;margin:4px auto 18px;width:88px;height:88px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(180,83,9,.14),rgba(21,128,61,.14));color:#16a34a;font-size:40px}
.wx-guide-heart{position:absolute;right:-18px;bottom:4px;box-shadow:0 8px 18px rgba(28,25,23,.12)}
.wx-guide-title{font:700 22px/1.35 var(--font-display,'Noto Sans SC',system-ui);text-align:center;color:var(--text,#1c1917)}
.wx-guide-copy{margin:10px auto 18px;max-width:340px;text-align:center;font-size:14px;line-height:1.7;color:var(--text-mid,#57534e)}
.wx-guide-points{display:flex;flex-direction:column;gap:10px;margin:0 0 18px}
.wx-guide-points>div{display:flex;gap:12px;align-items:center;border:1px solid var(--border,#e7e5e4);border-radius:14px;background:var(--color-bg-sunken,#f2efe9);padding:10px 12px}
.wx-guide-points i{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(180,83,9,.10);color:var(--primary,#b45309);flex-shrink:0}
.wx-guide-points span{display:flex;flex-direction:column;gap:2px;min-width:0}
.wx-guide-points strong{font-size:13px;color:var(--text,#1c1917)}
.wx-guide-points em{font-style:normal;font-size:12px;color:var(--text-dim,#a8a29e)}
.wx-guide-actions{display:flex;gap:10px}
.wx-guide-actions .hub-btn{flex:1;justify-content:center}
.wx-guide-foot{margin-top:12px;text-align:center;font-size:11px;line-height:1.5;color:var(--text-dim,#a8a29e)}

/* ── Mobile responsive ── */
@media(max-width:768px){
  html[data-companion-chat-active="true"],html[data-companion-chat-active="true"] body,html[data-hub-mobile-page-active="true"],html[data-hub-mobile-page-active="true"] body{height:var(--hall-viewport-height,100dvh);overflow:hidden;overscroll-behavior:none}
  .hall-dock{z-index:430}
  .hub-tab[data-tab="discover"].is-active,.hub-tab[data-tab="companion"].is-active{position:fixed;inset:0;z-index:350;display:block;overflow-y:auto;background:var(--bg,#faf8f5);padding:0 0 calc(72px + env(safe-area-inset-bottom));overscroll-behavior:contain}
  .hub-tab[data-tab="discover"].is-active .hub-sec,.hub-tab[data-tab="companion"].is-active .hub-sec{padding-left:12px;padding-right:12px}
  .hub-tab[data-tab="companion"]{--cp-chrome-h:172px;--cp-chat-chrome-h:72px;--cp-dock-h:60px}
  .hub-tab[data-tab="companion"] .cp-discover-sec{display:none}
  .hub-tab[data-tab="companion"][data-mobile-view="chat"] .cp-hub-intro{display:none}
  .hub-tab[data-tab="companion"][data-mobile-view="chat"] .cp-shell-sec{padding:8px 0 0}
  .hub-tab[data-tab="companion"].is-active[data-mobile-view="chat"]{position:fixed;left:0;right:0;top:0;z-index:350;height:var(--hall-viewport-height,100dvh);display:flex;flex-direction:column;overflow:hidden;background:var(--bg,#faf8f5);padding:0 0 calc(var(--cp-dock-h,60px) + env(safe-area-inset-bottom))}
  .hub-tab[data-tab="companion"].is-active[data-mobile-view="chat"] .cp-shell-sec{flex:1;min-height:0;width:100%;max-width:none;margin:0;padding:0}
  .hub-tab[data-tab="companion"].is-active[data-mobile-view="chat"] .cp-layout{height:100%;min-height:0;max-height:none;border:0;border-radius:0}
  .cp-layout{flex-direction:column;min-height:0;max-height:none;height:calc(var(--hall-viewport-height,100dvh) - var(--cp-chrome-h,172px) - 72px - env(safe-area-inset-bottom));border-radius:16px}
  .cp-layout[data-mobile-view="chat"]{height:calc(var(--hall-viewport-height,100dvh) - var(--cp-chat-chrome-h,140px) - env(safe-area-inset-bottom));border-left:0;border-right:0;border-radius:0}
  .cp-layout[data-mobile-view="list"] .cp-chat{display:none}
  .cp-layout[data-mobile-view="chat"] .cp-list{display:none}
  .cp-list{height:100%;max-height:none;width:100%;border-right:none;border-bottom:0}
  .cp-list-head{position:sticky;top:0;z-index:1;background:var(--color-bg-sunken,#f2efe9)}
  .cp-item{padding:14px 16px}
  .cp-item-preview{max-width:none;white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
  .cp-chat{height:100%;min-height:0}
  .cp-chat-head{min-height:56px;padding:8px 10px;gap:8px;justify-content:flex-start;flex-shrink:0}
  .cp-chat-head-main{min-width:0}
  .cp-chat-name,.cp-chat-hint{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .cp-mobile-back,.cp-mobile-wx{appearance:none;border:0;background:transparent;color:var(--text,#1c1917);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
  .cp-mobile-back:active,.cp-mobile-wx:active{background:var(--color-bg-sunken,#f2efe9)}
  .cp-mobile-wx{color:var(--primary,#b45309);background:rgba(180,83,9,.08)}
  .cp-chat-profile{display:none}
  .cp-chat-body{min-height:0;flex:1;padding:14px 12px 12px;overscroll-behavior:contain}
  .cp-bubble{max-width:82%;padding:10px 16px;border-radius:18px}
  .cp-msg.is-user .cp-bubble{border-bottom-right-radius:6px}
  .cp-msg.is-npc .cp-bubble{border-bottom-left-radius:6px}
  .cp-msg-label{font-size:11px;text-align:right;margin-top:6px;opacity:.72}
  .cp-input{position:sticky;bottom:0;z-index:2;flex-shrink:0;padding:8px 10px calc(8px + env(safe-area-inset-bottom));align-items:flex-end}
  .cp-layout[data-mobile-view="chat"] .cp-input{position:relative;bottom:auto}
  .cp-input-meta:empty{display:none}
  .cp-textarea{resize:none;max-height:96px;border-radius:18px}
  .cp-input .hub-btn.primary{min-width:64px;padding:12px 14px;border-radius:18px}
  .wx-guide{top:auto;bottom:0;width:100%;max-width:none;transform:translateX(-50%);border-radius:20px 20px 0 0;padding:24px 20px calc(24px + env(safe-area-inset-bottom))}
  .wx-guide-handle{display:block;width:42px;height:5px;border-radius:999px;background:var(--border,#e7e5e4);margin:-12px auto 16px}
  .wx-guide-actions{flex-direction:column}
  .dsc-filter{margin-top:12px}
  .dsc-filter-bar{padding:9px 10px}
  .dsc-filter-summary{flex-direction:column;align-items:flex-start;gap:1px}
  .dsc-filter-summary strong{max-width:220px}
  .dsc-kanban{gap:18px}
  .dsc-kanban-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}
  .dsc-kanban-section{padding:14px}
  .dsc-overlay{max-width:100%;border-radius:16px 16px 0 0}
  .dsc-overlay-cover{max-height:260px}
  .hub-sec{padding:12px 12px 24px}
}
