:root{color-scheme:light;font-family:PingFang SC,MiSans,Microsoft YaHei,sans-serif;--bg: #fff8f3;--bg-accent: #f9e7ea;--bg-blue: #dfeffc;--panel: rgba(255, 255, 255, .78);--panel-strong: rgba(255, 255, 255, .92);--panel-soft: rgba(255, 248, 243, .72);--line: rgba(133, 110, 100, .12);--line-strong: rgba(133, 110, 100, .2);--text: #4f433d;--text-soft: #7f7068;--pink: #e88faa;--pink-deep: #c76485;--blue: #7db8e8;--blue-deep: #4a92cb;--green-bubble: #dcefd0;--white-bubble: #fffdfb;--danger-bg: #ffe6e3;--danger-text: #cc6f6a;--shadow: 0 18px 40px rgba(102, 75, 62, .08);--shadow-soft: 0 8px 24px rgba(102, 75, 62, .08);background:radial-gradient(circle at top left,rgba(255,224,232,.8),transparent 28%),radial-gradient(circle at top right,rgba(208,231,250,.9),transparent 26%),linear-gradient(180deg,#fffaf7,#fff3f6 54%,#fff8f3);color:var(--text)}*{box-sizing:border-box}html,body,#app{min-height:100%}body{margin:0;min-height:100vh}button,input,textarea{font:inherit}button{border:0}button,input,textarea,a{-webkit-tap-highlight-color:transparent}img,video{max-width:100%}.app-shell{min-height:100vh;padding:28px}.app-main{width:min(1320px,100%);margin:0 auto}.app-shell--gate .app-main{width:min(1180px,100%)}.surface-card{border:1px solid var(--line);border-radius:28px;background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.surface-card--soft{background:var(--panel-soft);box-shadow:none}h1,h2,p{margin:0}h1{font-size:clamp(2.4rem,5vw,4.5rem);line-height:1.04;letter-spacing:-.04em}h2{font-size:clamp(1.5rem,2vw,2rem);line-height:1.18;letter-spacing:-.03em}.brand-mark,.section-kicker{margin-bottom:10px;font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}.brand-mark{color:var(--pink-deep)}.section-kicker{color:var(--text-soft)}.soft-text,.message-time,.message-meta,.profile-preview-text,.role-stage-card small{color:var(--text-soft);line-height:1.6}.boot-card{max-width:520px;padding:40px}.gate-shell{display:grid;gap:24px}.gate-brand{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}.brand-pill,.capability-pill{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid rgba(255,255,255,.66);background:#ffffff9e;color:var(--text-soft)}.brand-pill{min-height:40px;padding:0 16px;font-size:.85rem;text-transform:lowercase}.entry-layout,.male-entry-layout{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(340px,420px);gap:24px;align-items:stretch}.entry-copy{display:grid;align-content:center;gap:20px;padding:20px 8px}.capability-row{display:flex;flex-wrap:wrap;gap:12px}.capability-pill{min-height:40px;padding:0 16px;font-size:.92rem}.entry-note{display:grid;gap:12px;max-width:460px;padding:20px 22px}.status-line{display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:.95rem}.entry-card,.role-layout{padding:28px}.entry-card{display:grid;gap:18px;align-content:start}.form{display:grid;gap:14px}.form label,.profile-field{display:grid;gap:8px}.form span,.profile-field span{font-size:.92rem;color:var(--text-soft)}.form input,.composer input,.profile-field input{width:100%;min-height:52px;padding:0 16px;border:1px solid var(--line);border-radius:18px;background:#ffffffe0;color:var(--text);outline:none;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.form input:focus,.composer input:focus,.profile-field input:focus{border-color:#c8748566;box-shadow:0 0 0 4px #e88faa24;transform:translateY(-1px)}.primary-button,.secondary-button,.ghost-button,.secondary-chip,.ghost-chip,.danger-chip,.icon-button,.role-stage-card{cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease,background .18s ease,border-color .18s ease,color .18s ease,filter .18s ease}.primary-button,.secondary-button,.ghost-button{min-height:52px;padding:0 18px;border-radius:18px;font-weight:600}.primary-button{background:linear-gradient(135deg,#f2a3bb,#e6849f);color:#fff8fb;box-shadow:0 14px 28px #e6849f38;border:1px solid rgba(222,120,148,.28)}.primary-button.compact,.primary-button.slim{min-height:44px;padding:0 16px}.secondary-button,.ghost-button,.secondary-chip,.ghost-chip,.icon-button,.danger-chip{background:#ffffffb3;color:var(--text);border:1px solid var(--line)}.ghost-button,.icon-button{background:transparent}.rail-logout{width:100%}.secondary-chip,.ghost-chip,.danger-chip{min-height:42px;padding:0 14px;border-radius:16px;font-size:.92rem}.ghost-chip{background:#f8e1e7b8}.danger-chip{background:var(--danger-bg);color:var(--danger-text);border-color:#cc6f6a2e}.primary-button:hover,.secondary-button:hover,.ghost-button:hover,.secondary-chip:hover,.ghost-chip:hover,.danger-chip:hover,.icon-button:hover,.role-stage-card:hover{transform:translateY(-1px)}.primary-button:hover{background:linear-gradient(135deg,#ee97b3,#dd7693);box-shadow:0 18px 32px #e6849f47}.secondary-button:hover,.secondary-chip:hover{background:#fffffff5;border-color:#7db8e857;box-shadow:0 10px 22px #4c769e1f}.ghost-button:hover,.ghost-chip:hover,.icon-button:hover{background:#ffffff7a;border-color:#c7ac9f4d}.danger-chip:hover{background:#ffd8d3;border-color:#cc6f6a47;box-shadow:0 10px 22px #cc6f6a24}.primary-button:active,.secondary-button:active,.ghost-button:active,.secondary-chip:active,.ghost-chip:active,.danger-chip:active,.icon-button:active,.role-stage-card:active{transform:translateY(1px) scale(.985);filter:saturate(1.05)}.primary-button:focus-visible,.secondary-button:focus-visible,.ghost-button:focus-visible,.secondary-chip:focus-visible,.ghost-chip:focus-visible,.danger-chip:focus-visible,.icon-button:focus-visible,.role-stage-card:focus-visible{outline:none;box-shadow:0 0 0 3px #ffffffeb,0 0 0 6px #7db8e857}.primary-button:disabled,.secondary-button:disabled,.ghost-button:disabled,.secondary-chip:disabled,.ghost-chip:disabled,.danger-chip:disabled,.icon-button:disabled{opacity:.55;cursor:default;transform:none}.role-layout{display:grid;gap:22px;padding:28px;background:#ffffffd1}.role-split-stage{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;padding:24px;border-radius:28px;background:linear-gradient(104deg,#dfeffccc,#dfeffccc 48%,#f9e7ead6 49%,#f9e7ead6)}.role-stage-card{position:relative;display:grid;padding:0;border-radius:24px;background:transparent;box-shadow:none;text-align:center}.role-stage-card--male{color:var(--blue-deep)}.role-stage-card--female{color:var(--pink-deep)}.role-stage-card__frame{position:relative;display:grid;gap:14px;padding:18px;height:100%;border-radius:24px;background:#ffffffdb;border:1px solid rgba(255,255,255,.7);box-shadow:0 14px 28px #4939321a}.role-stage-card:hover .role-stage-card__frame{background:#fffffff0}.role-stage-card--female .role-stage-card__frame{box-shadow:0 0 0 1px #a6e1f4b3,0 18px 30px #73d9ff38,0 14px 28px #49393214}.role-stage-card--male .role-stage-card__frame{box-shadow:0 0 0 1px #ffd6b0cc,0 18px 30px #ffb35d2e,0 14px 28px #49393214}.role-stage-card--female:hover .role-stage-card__frame,.role-stage-card--female:focus-visible .role-stage-card__frame{box-shadow:0 0 0 1px #7cd6f2eb,0 0 0 7px #a6e1f438,0 24px 36px #73d9ff42,0 16px 26px #49393214}.role-stage-card--male:hover .role-stage-card__frame,.role-stage-card--male:focus-visible .role-stage-card__frame{box-shadow:0 0 0 1px #ffc17cfa,0 0 0 7px #ffd6b03d,0 24px 36px #ffb35d3d,0 16px 26px #49393214}.role-stage-card:active .role-stage-card__frame{box-shadow:0 0 0 1px #ffffffc7,0 10px 18px #4939321a}.role-stage-card__art{position:relative;width:100%;aspect-ratio:4 / 5;border-radius:20px;overflow:hidden;border:1px solid rgba(255,255,255,.82)}.role-stage-card__art:before,.role-stage-card__art:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0}.role-stage-card__art:before{top:14px;right:14px;bottom:14px;left:14px;border-radius:10px;border:2px solid rgba(255,255,255,.82);z-index:1}.role-stage-card__art:after{top:0;right:0;bottom:0;left:0;z-index:0;opacity:.7}.role-stage-card__art--female,.role-preview-card--female .role-stage-card__art{background:linear-gradient(180deg,#cbe9ff,#b8d7fb)}.role-stage-card__art--female:after,.role-preview-card--female .role-stage-card__art:after{background:radial-gradient(circle at 20% 18%,rgba(255,255,255,.3) 0 10%,transparent 10.5%),radial-gradient(circle at 84% 24%,rgba(255,255,255,.26) 0 8%,transparent 8.5%),radial-gradient(circle at 78% 72%,rgba(255,255,255,.16) 0 5%,transparent 5.5%),linear-gradient(45deg,rgba(255,255,255,.14) 25%,transparent 25% 50%,rgba(255,255,255,.14) 50% 75%,transparent 75%);background-size:auto,auto,auto,32px 32px}.role-stage-card__art--male,.role-preview-card--male .role-stage-card__art{background:linear-gradient(180deg,#ffd6a8,#ffc487)}.role-stage-card__art--male:after,.role-preview-card--male .role-stage-card__art:after{background:linear-gradient(135deg,rgba(255,255,255,.18) 0 18%,transparent 18% 100%),repeating-linear-gradient(135deg,transparent 0 20px,rgba(255,255,255,.16) 20px 24px),radial-gradient(circle at 18% 18%,rgba(255,255,255,.24) 0 10%,transparent 10.5%)}.role-stage-card__label,.role-preview-card__label{display:grid;justify-items:center;gap:6px}.role-stage-card__label strong,.role-preview-card__label strong{font-size:clamp(1.45rem,2.6vw,2rem);line-height:1;color:var(--text)}.role-stage-card__label small,.role-preview-card__label small{font-size:.9rem;color:var(--text-soft)}.role-stage-card__label span{font-size:.86rem;color:var(--text-soft)}.role-stage-card__art--profile{display:grid;place-items:center;padding:20px}.role-stage-card__avatar-image{width:min(100%,240px);aspect-ratio:1 / 1;border-radius:24px;background-size:cover;background-position:center;background-repeat:no-repeat;box-shadow:inset 0 0 0 1px #ffffff61,0 14px 24px #50433d24}.role-stage-card__avatar-fallback{display:grid;place-items:center;width:min(100%,220px);aspect-ratio:1 / 1;border-radius:28px;background:#ffffff8f;color:#4f433db8;font-size:clamp(3.2rem,7vw,5rem);font-weight:800;box-shadow:inset 0 0 0 1px #ffffff9e}.poster-character{position:absolute;z-index:2;top:0;right:0;bottom:0;left:0}.poster-character__hair,.poster-character__face,.poster-character__neck,.poster-character__body,.poster-character__detail,.poster-character__hair:before,.poster-character__hair:after,.poster-character__face:before,.poster-character__face:after,.poster-character__body:before,.poster-character__body:after,.poster-character__detail:before,.poster-character__detail:after{content:"";position:absolute}.poster-character__detail{top:0;right:0;bottom:0;left:0}.poster-character--selection{transform:translateY(8px)}.poster-character__hair{top:56px;left:50%;width:148px;height:128px;transform:translate(-50%);border-radius:56px 56px 42px 42px}.poster-character__face{top:86px;left:50%;width:96px;height:108px;transform:translate(-50%);border-radius:44px 44px 36px 36px;background:linear-gradient(180deg,#fff3ea,#ffe2d0);box-shadow:0 14px 20px #47312d1f}.poster-character__face:before{top:38px;left:22px;width:10px;height:10px;border-radius:50%;background:#2e2936;box-shadow:40px 0 #2e2936}.poster-character__face:after{left:50%;bottom:18px;width:18px;height:8px;transform:translate(-50%);border-bottom:2px solid rgba(116,84,79,.78);border-radius:0 0 12px 12px}.poster-character__neck{top:188px;left:50%;width:26px;height:24px;transform:translate(-50%);border-radius:10px;background:#ffe5d7}.poster-character__body{left:50%;bottom:-18px;width:198px;height:188px;transform:translate(-50%);border-radius:72px 72px 0 0}.poster-character--male .poster-character__hair{background:linear-gradient(135deg,#1c1f32,#303855 55%,#54627e)}.poster-character--male .poster-character__hair:before{top:18px;left:-8px;width:64px;height:84px;border-radius:40px 18px 30px 26px;background:#292d42;transform:rotate(-8deg)}.poster-character--male .poster-character__hair:after{top:8px;right:-10px;width:72px;height:54px;border-radius:18px 32px 18px 18px;background:#202438;transform:rotate(12deg)}.poster-character--male .poster-character__body{background:linear-gradient(180deg,#314977 0,#314977 50%,#223860 50%,#223860)}.poster-character--male .poster-character__body:before{left:50%;top:18px;width:86px;height:74px;transform:translate(-50%);background:linear-gradient(135deg,#ffffff 0 48%,transparent 48% 52%,#ffffff 52% 100%);clip-path:polygon(0 0,100% 0,76% 100%,24% 100%)}.poster-character--male .poster-character__body:after{left:50%;top:38px;width:24px;height:110px;transform:translate(-50%);border-radius:10px;background:repeating-linear-gradient(180deg,#223148 0,#223148 10px,#d7a968 10px,#d7a968 13px)}.poster-character--male .poster-character__detail:before{right:22px;top:118px;width:34px;height:102px;border-radius:0 0 24px 24px;background:#293452e6;transform:rotate(6deg)}.poster-character--male .poster-character__detail:after{left:32px;top:154px;width:56px;height:52px;border-radius:20px 24px 18px 18px;background:#243759f0;transform:rotate(-8deg)}.poster-character--female .poster-character__hair{top:52px;height:156px;border-radius:52px 52px 46px 46px;background:linear-gradient(135deg,#513744,#715160 48%,#8e6775)}.poster-character--female .poster-character__hair:before{left:-12px;bottom:4px;width:50px;height:110px;border-radius:26px 34px 42px 24px;background:#614754;transform:rotate(6deg)}.poster-character--female .poster-character__hair:after{right:-10px;bottom:-4px;width:54px;height:118px;border-radius:28px 30px 44px 24px;background:#6d4e5d;transform:rotate(-8deg)}.poster-character--female .poster-character__body{background:linear-gradient(180deg,#a1a5b0 0,#a1a5b0 38%,#8c909d 38%,#8c909d)}.poster-character--female .poster-character__body:before{left:50%;top:26px;width:88px;height:60px;transform:translate(-50%);background:linear-gradient(135deg,#fff 0 48%,transparent 48% 52%,#fff 52% 100%);clip-path:polygon(0 0,100% 0,76% 100%,24% 100%)}.poster-character--female .poster-character__body:after{left:50%;top:26px;width:54px;height:34px;transform:translate(-50%);background:#38476f;clip-path:polygon(0 0,100% 0,78% 100%,50% 58%,22% 100%)}.poster-character--female .poster-character__detail:before{left:50%;top:138px;width:142px;height:108px;transform:translate(-50%);border-radius:0 0 74px 74px;background:repeating-linear-gradient(90deg,#222a3c33 0,#222a3c33 10px,#222a3c57 10px,#222a3c57 12px)}.poster-character--female .poster-character__detail:after{right:20px;top:104px;width:24px;height:92px;border-radius:18px;background:#f0cfcc;transform:rotate(-14deg)}.role-stage-footer{display:flex;justify-content:center}.role-preview{display:grid;align-content:center;justify-items:center;gap:14px;padding:28px;border-radius:28px;border:1px solid var(--line);background:linear-gradient(180deg,#fff8f2eb,#ffffffeb);box-shadow:var(--shadow-soft);text-align:center}.role-preview--male{color:var(--blue-deep)}.role-preview-card{display:grid;gap:12px;width:min(100%,260px)}.role-preview-card__label strong{font-size:1.5rem}.gate-error{padding-inline:8px}.chat-shell{display:grid;grid-template-columns:260px minmax(0,1fr);gap:20px;align-items:start}.left-rail,.chat-surface,.side-drawer{padding:22px}.left-rail{display:grid;gap:18px;align-content:start;position:sticky;top:28px}.profile-card,.contact-card,.profile-editor-head{display:flex;align-items:center;gap:14px}.rail-block,.admin-section{display:grid;gap:12px}.contact-card,.mini-card,.profile-editor-card{padding:16px;border-radius:22px;border:1px solid var(--line);background:#ffffff9e}.chat-surface{display:grid;grid-template-rows:auto auto auto minmax(0,1fr) auto auto;height:calc(100vh - 56px);min-height:calc(100vh - 56px);background-color:#fffcf9eb;position:relative;overflow:hidden}.chat-header,.call-banner,.voice-recorder-bar,.voice-preview-bar,.drawer-head,.drawer-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.chat-header{padding-bottom:16px;border-bottom:1px solid rgba(110,98,92,.08)}.chat-title{display:flex;align-items:center;gap:12px}.chat-actions,.call-banner-actions,.voice-preview-actions,.profile-editor-actions{display:flex;flex-wrap:wrap;gap:8px}.chat-search-panel{display:grid;gap:12px;margin-top:12px;padding:16px 18px;border-radius:22px;border:1px solid rgba(125,184,232,.14);background:linear-gradient(180deg,#fffcf9eb,#f8faffd1);box-shadow:0 12px 30px #664b3e0f}.chat-search-lead{display:grid;gap:4px}.status-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;padding:12px 14px;border-radius:18px;border:1px solid rgba(201,94,94,.16);background:linear-gradient(135deg,#ffede9f5,#fff5f3f5);box-shadow:0 10px 24px #c95e5e14}.status-banner--error{color:#b95f5a}.chat-search-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;align-items:center}.chat-search-input-wrap{display:grid;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:10px;min-height:52px;padding:0 14px;border-radius:18px;border:1px solid rgba(125,184,232,.16);background:#ffffffd6;box-shadow:inset 0 1px #fff9}.chat-search-form input{min-width:0;padding:0;border:0;background:transparent;box-shadow:none}.chat-search-form input:focus{outline:none}.chat-search-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;background:#7db8e829;color:var(--blue-deep);font-size:.8rem;font-weight:700}.chat-search-actions{display:flex;flex-wrap:wrap;gap:8px}.chat-search-results{display:grid;gap:10px;max-height:240px;overflow:auto;padding-right:4px}.chat-search-result{display:grid;gap:6px;padding:12px 14px;border:1px solid rgba(125,184,232,.12);border-radius:16px;background:#ffffffbd;text-align:left;box-shadow:0 8px 18px #664b3e0a}.chat-search-result-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.chat-search-result p{color:var(--text-soft)}.wechat-avatar,.wechat-avatar-image{width:48px;height:48px;border-radius:14px;flex:0 0 auto}.wechat-avatar{display:inline-flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700}.wechat-avatar-image{background-size:cover;background-position:center;background-repeat:no-repeat;box-shadow:inset 0 0 0 1px #fff9}.self-avatar{background:linear-gradient(135deg,#bedca8,#dcefd0)}.peer-avatar{background:linear-gradient(135deg,#f8d7e1,#fff7fa)}.call-banner,.voice-recorder-bar,.voice-preview-bar{margin-top:16px;padding:14px 16px;border-radius:18px;background:#ffffffb8;border:1px solid var(--line)}.media-panel{position:relative;margin-top:16px;padding:14px;border-radius:22px;background:#56443f14;overflow:hidden}.remote-video,.local-video{width:100%;border-radius:18px;background:#1a1716}.local-video{position:absolute;right:14px;bottom:14px;width:180px;max-width:34%;border:2px solid rgba(255,255,255,.72)}.media-hint{margin-top:10px}.message-list{min-height:0;overflow:auto;display:grid;gap:16px;margin-top:18px;padding-right:6px}.new-message-notice{position:absolute;left:50%;bottom:calc(92px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:26;min-height:40px;padding:0 18px;border-radius:999px;border:1px solid rgba(125,184,232,.16);background:#fffcf9f5;box-shadow:0 14px 32px #664b3e1f;color:var(--blue-deep);font-weight:700}.message-list-loader{display:flex;justify-content:center}.message-history-button{min-height:36px;padding:0 16px;border-radius:999px}.message-separator{display:flex;justify-content:center;margin:2px 0}.message-separator span{padding:6px 12px;border-radius:999px;background:#7162591f;color:var(--text-soft);font-size:.78rem}.message-row{display:flex;gap:12px;align-items:flex-start}.message-row.self{justify-content:flex-end}.message-avatar{margin-top:22px}.message-stack{display:grid;gap:6px;max-width:min(680px,100%)}.message-row.self .message-stack{justify-items:end}.message-head{display:flex;align-items:center;gap:8px;font-size:.82rem}.message-name{font-weight:600}.message-bubble{max-width:min(540px,100%);padding:14px 16px;border-radius:18px;border:1px solid rgba(110,98,92,.08);box-shadow:var(--shadow-soft)}.message-reply-preview{display:grid;gap:4px;margin-bottom:10px;padding:8px 10px;border-left:3px solid rgba(125,184,232,.8);border-radius:10px;background:#7db8e814}.message-reply-preview strong,.message-reply-preview span{font-size:.8rem}.message-tools{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.message-visibility-chip{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;background:#7db8e824;color:var(--blue-deep);font-size:.74rem;font-weight:600}.message-visibility-chip--hidden{background:#e88faa29;color:var(--pink-deep)}.message-visibility-chip--deleted{background:#6e625c1f;color:var(--text-soft)}.wechat-bubble{background:var(--white-bubble)}.message-row.self .wechat-bubble{background:var(--green-bubble)}.message-bubble p{margin-top:4px;line-height:1.65;color:var(--text)}.attachment-image,.attachment-video{display:block;width:100%;margin-top:12px;border-radius:16px}.attachment-audio{width:100%;margin-top:12px}.attachment-link{display:inline-block;margin-top:10px;color:var(--blue-deep);text-decoration:none}.composer{display:grid;grid-template-columns:minmax(0,1fr) repeat(3,auto);gap:10px;align-items:center;margin-top:12px;padding-top:16px;padding-bottom:max(12px,env(safe-area-inset-bottom));border-top:1px solid rgba(110,98,92,.08);position:sticky;bottom:0;z-index:24;background:#fffcf9f5;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.composer-reply-preview{grid-column:1 / -1;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:14px;background:#7db8e814;border:1px solid rgba(125,184,232,.18)}.composer-reply-preview div{display:grid;gap:2px;min-width:0}.composer-reply-preview span{color:var(--text-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-chip{min-height:30px;padding:0 10px;border-radius:999px;font-size:.76rem}.visibility-card{display:grid;gap:12px}.message-day-list{display:grid;gap:10px;max-height:320px;overflow:auto;padding-right:4px}.message-day-card{display:grid;gap:10px;padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:#ffffff8f}.day-message-manager{display:grid;gap:10px;padding:12px;border-radius:14px;background:#ffffffb8;border:1px solid rgba(110,98,92,.08)}.day-message-manager-toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.day-message-list{display:grid;gap:10px;max-height:240px;overflow:auto;padding-right:4px}.day-message-item{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px;align-items:start;padding:10px 12px;border-radius:12px;background:#fff8f3d1}.day-message-item input{margin-top:2px}.day-message-item div{min-width:0;display:grid;gap:4px}.day-message-meta{display:flex;flex-wrap:wrap;gap:8px}.day-message-item p{color:var(--text-soft);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.day-message-item--deleted{opacity:.65}.deleted-message-text{color:var(--text-soft);font-style:italic}.composer input{background:#ffffffe6}.hidden-input{display:none}.drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#4f433d2e;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:30}.side-drawer{position:fixed;top:20px;right:20px;bottom:20px;width:min(420px,calc(100vw - 40px));display:grid;grid-template-rows:auto auto 1fr auto;gap:16px;border:1px solid var(--line);border-radius:28px;background:var(--panel-strong);box-shadow:0 28px 60px #5b443929;transform:translate(calc(100% + 24px));transition:transform .24s ease;overflow:auto;z-index:40}.side-drawer.open{transform:translate(0)}.icon-button{min-height:42px;padding:0 14px;border-radius:14px}.drawer-lead{margin-top:-4px}.admin-role-list,.profile-editor-list{display:grid;gap:12px}.profile-editor-card{display:grid;gap:14px}.error-text{color:#c95e5e}@media(max-width:1100px){.entry-layout,.male-entry-layout,.chat-shell{grid-template-columns:1fr}.left-rail{position:static}.chat-surface{height:calc(100vh - 32px);min-height:72vh}}@media(max-width:780px){.app-shell{padding:16px 16px calc(16px + env(safe-area-inset-bottom))}.gate-brand,.chat-header,.call-banner,.voice-recorder-bar,.voice-preview-bar,.drawer-head,.drawer-footer{flex-direction:column;align-items:flex-start}.brand-pill{min-height:34px}.role-split-stage,.composer{grid-template-columns:1fr}.role-layout{padding:34px 20px 22px}.role-split-stage{gap:20px}.role-stage-card__art,.role-preview-card{width:min(100%,260px)}.left-rail{display:none}.chat-surface{display:grid;grid-template-rows:auto auto auto minmax(0,1fr) auto auto;padding:18px;height:calc(100dvh - 32px - env(safe-area-inset-bottom));min-height:calc(100dvh - 32px - env(safe-area-inset-bottom))}.message-list{overflow:auto;min-height:0;max-height:none;margin-top:20px;padding-right:0}.composer{margin-top:10px;padding-bottom:calc(10px + env(safe-area-inset-bottom))}.local-video{position:static;width:100%;max-width:100%;margin-top:12px}.message-stack,.message-bubble{max-width:100%}.side-drawer{top:auto;right:0;left:0;bottom:0;width:100%;max-height:min(88vh,760px);border-radius:28px 28px 0 0;transform:translateY(100%)}.side-drawer.open{transform:translateY(0)}}@media(max-width:780px)and (hover:none)and (pointer:coarse){.chat-header{position:sticky;top:calc(env(safe-area-inset-top) + 8px);z-index:25;margin:-18px -18px 0;padding:18px;background:#fffcf9f0;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-radius:28px 28px 18px 18px}}
