:root{color:#342b3a;background:#f4eaf4;font-family:PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html{min-height:100%}body{margin:0;min-width:320px;min-height:100vh;min-height:100dvh;overflow:hidden}button,input,select,textarea{font:inherit}button{cursor:pointer}.app-shell{height:100vh;height:100dvh;min-height:-webkit-fill-available;display:grid;place-items:center;padding:12px;background:linear-gradient(90deg,rgba(255,255,255,.45) 1px,transparent 1px),linear-gradient(rgba(255,255,255,.42) 1px,transparent 1px),radial-gradient(circle at 45% 12%,rgba(198,215,255,.36),transparent 24%),#f4eaf4;background-size:30px 30px,30px 30px,auto,auto;overflow:hidden}.phone{position:relative;width:min(390px,calc(100vw - 24px));height:min(844px,calc(100vh - 24px));height:min(844px,calc(100dvh - 24px));overflow:hidden;display:flex;flex-direction:column;padding:18px 16px 14px;border:2px solid #e4bfd4;border-radius:24px;background:linear-gradient(180deg,#fffffff2,#fdf2f8f5 52%,#f1e6f1);box-shadow:0 18px 44px #503d5633}.topbar,.panel header{display:flex;align-items:center;justify-content:space-between;gap:12px}.topbar{position:relative;z-index:40;flex-shrink:0;min-height:42px}h1,h2,p{margin:0}.topbar h1{color:#4d4257;font-size:22px;line-height:1.05}.topbar p,.door-subtitle,.door-meta,.hint-text,.empty-text{color:#766b7e;font-size:12px;line-height:1.45}.top-actions{display:flex;align-items:center;gap:7px}.coin-button{min-width:72px;height:38px;display:flex;align-items:center;justify-content:center;gap:5px;border:1px solid #cdb5d8;border-radius:10px;background:#fff;color:#6b5678;font-size:15px;font-weight:700}.coin-button img,.settings-button img,.quick-actions img,.memory-preview img,.gift-icon,.pixel-icon,.pixel-door{image-rendering:pixelated;image-rendering:crisp-edges}.coin-button img{width:22px;height:22px}.settings-button{display:grid;place-items:center;width:38px;height:38px;border:1px solid #cdb5d8;border-radius:10px;background:#fff}.settings-button img{width:24px;height:24px}.account-menu-wrap{position:relative;z-index:80}.account-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:120;min-width:104px;padding:6px;border:1px solid #d8bdd4;border-radius:11px;background:#fffafdfa;box-shadow:0 10px 24px #4935502e}.account-menu button{width:100%;min-height:34px;border:0;border-radius:8px;background:#f5d9e8;color:#513f5a;font-size:12px;font-weight:800}.auth-page{width:min(390px,calc(100vw - 24px));min-height:min(720px,calc(100vh - 24px));display:grid;place-items:center;padding:18px;border:2px solid #e4bfd4;border-radius:28px;background:linear-gradient(180deg,#fffffff0,#fdf2f8f5),#fff7fb;box-shadow:0 18px 44px #503d5633}.auth-card{width:100%;display:grid;gap:20px}.auth-hero{display:flex;align-items:center;gap:14px;padding:14px;border:1px solid #ead2df;border-radius:18px;background:#ffffffc7}.auth-hero img,.loading-page img{width:72px;height:72px;object-fit:contain;image-rendering:auto;filter:drop-shadow(0 8px 14px rgba(68,49,76,.22))}.auth-hero h1{color:#4d4257;font-size:30px;line-height:1.05}.auth-hero p,.loading-page p{margin-top:7px;color:#766b7e;font-size:13px;line-height:1.55}.auth-switch{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:5px;border:1px solid #ead2df;border-radius:14px;background:#ffffffb8}.auth-switch button{height:44px;border:0;border-radius:10px;background:transparent;color:#75627d;font-size:17px;font-weight:900}.auth-switch button.active{background:#f5d9e8;color:#513f5a;box-shadow:inset 0 -4px #8d607d1a}.mobile-auth-fields{display:grid;gap:14px}.mobile-auth-fields label{display:grid;gap:7px;color:#594a62;font-size:16px;font-weight:900}.mobile-auth-fields input{width:100%;height:48px;padding:0 14px;border:1px solid #d9bdd4;border-radius:13px;background:#fffffff5;color:#3f3547;font-size:16px;outline:none}.mobile-auth-fields input:focus{border-color:#c59ac0;box-shadow:0 0 0 3px #f5d9e8e6}.auth-submit{height:52px;margin-top:4px;border:1px solid #c8a9ca;border-radius:14px;background:linear-gradient(180deg,#fff,#f5d9e8);color:#513f5a;font-size:18px;font-weight:900;box-shadow:inset 0 -5px #8d607d1a}.auth-submit:disabled{opacity:.58;cursor:wait}.loading-page{width:min(390px,calc(100vw - 24px));min-height:min(640px,calc(100vh - 24px));display:grid;place-items:center;align-content:center;gap:12px;padding:24px;border:2px solid #e4bfd4;border-radius:28px;background:#fffafddb;box-shadow:0 18px 44px #503d5629;text-align:center}.loading-page img{width:96px;height:96px}.intro-backdrop{align-items:center}.intro-panel{width:100%;overflow:hidden;border:2px solid #d9bdd4;border-radius:20px;background:linear-gradient(180deg,#fffffff5,#fdf2f8fa),#fffafd;box-shadow:0 18px 40px #44314c3d}.intro-portrait{height:212px;overflow:hidden;border-bottom:1px solid #ead2df;background:#f4eaf4}.intro-portrait img{width:100%;height:100%;object-fit:cover;object-position:center 15%}.intro-copy{display:grid;gap:9px;padding:14px}.intro-copy h2{color:#44394c;font-size:18px;line-height:1.3}.intro-copy p{color:#5c5064;font-size:13px;line-height:1.6}.intro-copy button{min-height:42px;margin-top:4px;border:1px solid #c8a9ca;border-radius:11px;background:linear-gradient(180deg,#fff,#f5d9e8);color:#513f5a;font-weight:900}.highlight-card{position:relative;min-height:136px;margin-top:10px;margin-bottom:14px;padding:12px;overflow:hidden;border:1px solid #dac5df;border-radius:14px;background:linear-gradient(90deg,#fffffff5 0 54%,#f6e6f17a 54% 100%),#fffafd}.highlight-copy{position:relative;z-index:2;display:grid;grid-template-rows:auto minmax(34px,auto) auto;align-content:center;width:52%;min-height:112px}.nameplate,.door-nameplate{display:block;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges}.nameplate{width:104px;height:42px;object-position:left center}.highlight-copy p{display:-webkit-box;margin-top:2px;overflow:hidden;color:#4d4353;font-size:12px;line-height:1.4;-webkit-box-orient:vertical;-webkit-line-clamp:2}.highlight-copy span{display:-webkit-box;margin-top:3px;overflow:hidden;color:#766b7e;font-size:11px;line-height:1.4;-webkit-box-orient:vertical;-webkit-line-clamp:2}.highlight-actions{display:flex;gap:6px;margin-top:8px}.highlight-actions button{min-height:27px;display:inline-flex;align-items:center;gap:4px;padding:0 8px;border:1px solid #c9b2d1;border-radius:8px;background:#fff;color:#594760;font-size:11px;font-weight:800}.highlight-actions img,.butler-actions img{width:18px;height:18px;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges}.highlight-frame{position:absolute;top:12px;right:12px;bottom:12px;z-index:1;width:146px;overflow:hidden;border:1px solid #dbc1d5;border-radius:12px;background:#f7edf5}.highlight-fullbody{width:100%;height:100%;object-fit:cover;object-position:center top;filter:saturate(.92) contrast(1.02)}.highlight-sticker{position:absolute;right:2px;bottom:-3px;z-index:2;width:46px;height:46px;object-fit:contain;filter:drop-shadow(0 5px 10px rgba(67,51,75,.24))}.door-wall{flex:1;min-height:0;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-auto-rows:164px;gap:8px;margin-top:10px;padding:8px;border:1px solid #e0c8da;border-radius:14px;background:linear-gradient(180deg,#ffffffbf,#f6ebf59e),#fff7fb;overflow-y:auto}.door-card{position:relative;display:grid;grid-template-rows:88px minmax(0,1fr);gap:5px;min-width:0;min-height:0;padding:7px 8px 9px;border:1px solid color-mix(in srgb,var(--accent, #9b7ba8),#fff 28%);border-radius:10px;background:linear-gradient(180deg,#fff 0%,var(--door, #f6d6e7) 100%);color:#4c4054;text-align:left;box-shadow:inset 0 -7px #835d771c}.door-card.selected{outline:2px solid rgba(255,255,255,.95);box-shadow:inset 0 -7px #835d771c,0 0 0 2px color-mix(in srgb,var(--accent),#fff 40%)}.door-art{position:relative;display:grid;place-items:end center;min-width:0;border:1px solid rgba(123,95,133,.25);border-radius:8px;background:linear-gradient(180deg,rgba(255,255,255,.32),transparent 46%),#f7eff6;overflow:hidden}.pixel-door{width:64px;height:96px;object-fit:contain}.door-card-portrait{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 20%;opacity:.38}.door-sticker{position:absolute;right:-6px;bottom:-9px;width:64px;height:64px;object-fit:contain;filter:drop-shadow(0 5px 8px rgba(62,46,70,.22))}.character-sticker,.character-avatar,.detail-fullbody,.chat-fullbody,.highlight-fullbody{image-rendering:auto}.door-copy{min-width:0;min-height:0;overflow:hidden}.door-name{display:block;font-size:17px;font-weight:800;line-height:1.1}.door-nameplate{width:82px;height:31px;margin-left:-4px;object-position:left center}.door-subtitle{display:-webkit-box;margin-top:3px;min-height:16px;overflow:hidden;line-height:1.3;-webkit-box-orient:vertical;-webkit-line-clamp:1}.door-meta{display:-webkit-box;margin-top:2px;overflow:hidden;color:#5e5268;font-weight:700;line-height:1.25;-webkit-box-orient:vertical;-webkit-line-clamp:1}.rent-tag{position:absolute;right:9px;bottom:10px;display:inline-flex;align-items:center;justify-content:center;gap:2px;min-width:32px;height:20px;padding:0 5px;border:1px solid #705a7d;border-radius:6px;background:#fff8c9;color:#5f5268;font-size:10px;font-weight:800}.rent-tag img{width:13px;height:13px;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges}.empty-door{border-style:dashed;background:#fff}.door-action{margin-top:8px;color:#8a6280;font-size:13px;font-weight:800}.porch-panel,.memory-preview,.butler-dashboard{flex:1;min-height:0;display:grid;align-content:start;gap:10px;margin-top:10px;padding:12px;border:2px solid #e7c5d7;border-radius:14px;background:#fff7fb;overflow:auto}.visitor-door-card,.memory-preview article{display:grid;grid-template-columns:76px 1fr;align-items:center;gap:12px;min-height:102px;padding:10px;border:1px solid #ead2df;border-radius:10px;background:#fff;color:#4d4056;text-align:left}.visitor-door-card strong{display:block;margin-bottom:4px;font-size:14px}.visitor-door-card p{font-size:12px;line-height:1.45}.porch-logout{display:flex;justify-content:center;padding:18px 0 6px}.porch-logout button{min-height:34px;display:inline-flex;align-items:center;gap:6px;padding:0 14px;border:1px solid #ead2df;border-radius:10px;background:#fffafdb8;color:#5d5066;font-size:12px;font-weight:800;box-shadow:inset 0 1px #ffffffe0,0 8px 18px #58426714}.porch-logout img{width:20px;height:20px;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges}.memory-preview article{grid-template-columns:34px 1fr;min-height:auto}.memory-preview img{width:28px;height:28px}.memory-preview p{color:#4f4358;font-size:13px;line-height:1.5}.memory-preview strong{display:block;color:#4d4056;font-size:14px}.butler-dashboard{gap:12px}.butler-card{display:grid;grid-template-columns:118px 1fr;gap:12px;min-height:176px;padding:10px;border:1px solid #ead2df;border-radius:14px;background:linear-gradient(135deg,#ffffffeb,#f7edf5b8),#fff}.butler-portrait{overflow:hidden;border:1px solid #d8bdd4;border-radius:13px;background:#f7edf5}.butler-portrait img{width:100%;height:100%;object-fit:cover;object-position:center top}.butler-copy{align-self:center;min-width:0}.butler-copy p{display:-webkit-box;margin-top:5px;overflow:hidden;color:#4f4358;font-size:13px;line-height:1.5;-webkit-box-orient:vertical;-webkit-line-clamp:3}.butler-copy span{display:block;margin-top:8px;color:#766b7e;font-size:12px}.butler-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.butler-actions button{min-height:58px;display:flex;align-items:center;justify-content:center;gap:7px;border:1px solid #ccb5d3;border-radius:11px;background:#fff;color:#5d5066;font-size:13px;font-weight:900}.butler-actions button:disabled{opacity:.52;cursor:not-allowed}.butler-actions button span{display:grid;gap:1px;line-height:1.1}.butler-actions button small{color:#8c7b94;font-size:10px;font-weight:800}.memory-preview button{min-height:38px;border:1px solid #ccb5d3;border-radius:9px;background:#fff;color:#5d5066;font-size:13px;font-weight:800}.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:10px}.quick-actions button,.split-actions button,.collect-box button,.oc-form button,.panel header button,.memory-list button,.detail-actions button,.chat-compose button{border:1px solid #ccb5d3;border-radius:9px;background:#fff;color:#5d5066;font-weight:800}.quick-actions button{height:56px;font-size:12px}.module-nav{position:sticky;bottom:0;z-index:3;flex-shrink:0;padding:6px 0 max(0px,env(safe-area-inset-bottom));background:linear-gradient(180deg,#fff7fb00,#fff7fbf5 18%),#fff7fbdb}.module-nav button.active{background:#f5d9e8;box-shadow:inset 0 -5px #8d607d1a}.quick-actions img{width:23px;height:23px;margin:0 auto 5px;display:block}.panel-backdrop{position:absolute;inset:0;display:flex;align-items:end;padding:14px;background:#48384e3d;z-index:4}.panel{width:100%;max-height:86%;overflow:auto;padding:0 14px 14px;border:2px solid #d9bdd4;border-radius:18px;background:#fffafd;box-shadow:0 -10px 30px #58425233}.panel-chat-shell{height:min(86%,660px);display:flex;flex-direction:column;overflow:hidden}.panel header{position:sticky;top:0;z-index:3;margin:0 -14px 12px;padding:12px 14px 10px;border-bottom:1px solid #efd7e6;background:#fffafdf5;border-radius:16px 16px 0 0}.panel-chat-shell header{flex-shrink:0}.panel h2{font-size:16px}.panel header button{width:32px;height:32px;font-size:18px}.logout-confirm{max-height:none}.logout-confirm p{color:#5d5066;font-size:13px;line-height:1.6}.logout-confirm .split-actions{margin-top:12px}.logout-confirm .split-actions button{font-size:13px}.chat-panel{min-height:0;flex:1;display:flex;flex-direction:column}.chat-strip{flex-shrink:0;display:grid;grid-template-columns:54px 1fr;gap:10px;align-items:center;min-height:78px;padding:9px;overflow:hidden;border:1px solid #ead2df;border-radius:13px;background:linear-gradient(180deg,#fffffff0,#f7edf5b8),#fff}.chat-avatar{width:54px;height:54px;border:1px solid #d8bdd4;border-radius:12px;background:#f7edf5;object-fit:cover}.chat-strip-copy{min-width:0}.chat-strip .nameplate{width:96px;height:33px}.chat-strip p{display:-webkit-box;margin-top:2px;overflow:hidden;color:#4f4358;font-size:12px;line-height:1.35;-webkit-box-orient:vertical;-webkit-line-clamp:1}.chat-strip span{display:block;margin-top:3px;overflow:hidden;color:#766b7e;font-size:11px;line-height:1.3;text-overflow:ellipsis;white-space:nowrap}.message-list{flex:1;min-height:0;display:grid;align-content:start;gap:8px;margin-top:10px;padding:0 2px 8px;overflow-y:auto;overscroll-behavior:contain}.message{max-width:85%;padding:9px 10px;border:1px solid #e2c7d8;border-radius:11px;background:#fff;font-size:13px;line-height:1.5}.message.player{justify-self:end;background:#f5d9e8}.message.typing{color:#766b7e;min-width:46px;letter-spacing:2px}.chat-footer{flex-shrink:0;padding-top:8px;border-top:1px solid #f0dbe8;background:#fffafd}.chat-compose{display:grid;grid-template-columns:minmax(0,1fr) 68px;gap:8px;width:100%}.chat-compose textarea,.memory-writer textarea{width:100%;min-height:54px;resize:none;padding:9px 10px;border:1px solid #d9bdd4;border-radius:10px;background:#fff;color:#3f3547;font-size:13px;line-height:1.45}.chat-compose button{min-height:54px;font-size:13px}.chat-compose button:disabled,.memory-writer button:disabled{opacity:.48;cursor:not-allowed}.chat-status{margin-top:5px;color:#766b7e;font-size:12px;text-align:right}.observe-panel{text-align:center}.door-detail{display:grid;gap:12px}.door-stage{position:relative;display:grid;place-items:end center;height:390px;border:1px solid #ead2df;border-radius:12px;background:linear-gradient(180deg,transparent 70%,rgba(32,23,38,.28) 70%),#f4eaf4;overflow:hidden}.door-stage.portrait-only{place-items:center;height:292px;background:#f4eaf4}.detail-fullbody{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center top}.portrait-only .detail-fullbody{object-position:center 14%}.detail-room{position:absolute;left:10px;bottom:11px;width:122px;height:92px;object-fit:contain;filter:drop-shadow(0 5px 8px rgba(39,29,48,.24))}.detail-door{position:absolute;right:20px;bottom:10px;width:128px;height:192px;object-fit:contain}.detail-sticker{position:absolute;right:126px;bottom:8px;width:78px;height:78px;object-fit:contain;filter:drop-shadow(0 7px 12px rgba(39,29,48,.28))}.detail-copy{padding:10px;border:1px solid #ead2df;border-radius:10px;background:#fff}.detail-copy p{margin-top:5px;color:#4f4358;font-size:13px;line-height:1.5}.detail-copy span{display:block;margin-top:6px;color:#7a6e82;font-size:12px}.detail-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.detail-actions button{min-height:38px;font-size:13px}.pixel-room{position:relative;display:grid;place-items:center;width:180px;height:150px;margin:0 auto 10px;border:2px solid #d8b8cc;border-radius:14px;background:linear-gradient(180deg,transparent 65%,rgba(197,157,181,.18) 65%),#fff3fa}.room-stage{position:relative;width:254px;height:192px;margin:0 auto 10px;overflow:hidden;border:1px solid #d8b8cc;border-radius:13px;background:#fff3fa}.room-backdrop{width:100%;height:100%;object-fit:cover}.room-avatar{position:absolute;right:8px;bottom:8px;width:58px;height:58px;border:2px solid #fff;border-radius:13px;object-fit:cover;box-shadow:0 5px 12px #30233a33}.room-prop{position:absolute;left:12px;bottom:12px;width:46px;height:46px;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges}.observe-panel p{margin:6px auto 12px;color:#6e6077;font-size:13px;line-height:1.5}.split-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.split-actions button,.collect-box button,.oc-form button{min-height:38px}.scene-mood{display:block;margin-bottom:10px;color:#8b7a93;font-size:12px;font-weight:800}.observe-actions{display:grid}.observe-actions button{min-height:40px;border:1px solid #ccb5d3;border-radius:9px;background:#f5d9e8;color:#5d5066;font-weight:900}.gift-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.gift-recipient{grid-column:1 / -1;display:flex;align-items:center;gap:10px;padding:10px;border:1px solid #ead2df;border-radius:12px;background:#fff}.gift-feedback{grid-column:1 / -1;display:flex;align-items:center;gap:10px;padding:10px;border:1px solid #dfc4d8;border-radius:12px;background:#f8e5ef}.gift-feedback p{color:#4f4358;font-size:13px;line-height:1.45}.character-avatar{width:50px;height:50px;border-radius:12px;object-fit:cover}.gift-recipient p{color:#766b7e;font-size:12px}.gift-grid button{min-height:112px;padding:10px;border:1px solid #dfc4d8;border-radius:12px;background:#fff;color:#4d4056}.gift-grid small,.memory-list span,.mail-panel span{display:block;color:#7a6e82;font-size:12px}.gift-icon{display:block;width:38px;height:38px;margin:0 auto 8px;object-fit:contain}.hint-text{grid-column:1 / -1;margin-top:4px}.tarot-panel{display:grid;gap:12px}.tarot-intro,.tarot-question-card{display:grid;grid-template-columns:54px 1fr;align-items:center;gap:10px;padding:10px;border:1px solid #ead2df;border-radius:14px;background:linear-gradient(135deg,#ffffffe0,#f7edf5ad),#fff}.tarot-question-card{grid-template-columns:1fr}.tarot-question-card span,.tarot-card span,.tarot-card small{display:block;color:#7a6e82;font-size:12px}.tarot-question-card p{color:#4f4358;font-size:13px;line-height:1.55}.tarot-oracle{width:46px;height:46px;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges}.tarot-intro p{margin-top:4px;color:#6e6077;font-size:13px;line-height:1.5}.tarot-question{display:grid;gap:7px;color:#5b4b63;font-size:13px;font-weight:900}.tarot-question textarea{width:100%;min-height:88px;resize:none;padding:11px 12px;border:1px solid #d9bdd4;border-radius:14px;background:#fff;color:#3f3547;line-height:1.55}.tarot-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.tarot-cards.is-hidden{opacity:.72}.tarot-card{min-height:148px;display:grid;align-content:start;gap:5px;padding:10px 8px;border:1px solid #dfc4d8;border-radius:14px;background:radial-gradient(circle at 50% 16%,rgba(255,255,255,.76),transparent 34%),linear-gradient(160deg,#ffffffe6,#f5d9e894),#fff7fb;color:#4d4056;text-align:center;box-shadow:inset 0 1px #ffffffdb,0 10px 22px #60466c14}.tarot-card.reversed{background:radial-gradient(circle at 50% 16%,rgba(255,255,255,.76),transparent 34%),linear-gradient(160deg,#ffffffe0,#efe9ffad),#f8f4ff}.tarot-card img{width:38px;height:38px;margin:22px auto 8px;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges}.tarot-card strong{color:#46364f;font-size:15px;line-height:1.2}.tarot-card p{color:#5c5064;font-size:12px;line-height:1.38}.tarot-reply{max-width:100%;margin:0}.tarot-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.tarot-actions button{font-size:13px}.memory-list,.mail-panel{display:grid;gap:10px}.memory-tabs{display:flex;gap:7px;overflow-x:auto;padding-bottom:2px}.memory-tabs button{flex:0 0 auto;display:inline-flex;align-items:center;gap:5px;min-height:32px;padding:0 10px}.memory-tabs button.active{background:#f5d9e8}.memory-tabs img{width:20px;height:20px;border-radius:6px;object-fit:cover}.memory-writer{display:grid;grid-template-columns:50px 1fr 58px;gap:8px;align-items:stretch;padding:10px;border:1px solid #ead2df;border-radius:12px;background:#fff}.memory-writer button{min-height:54px;font-size:13px}.memory-list article,.mail-panel article,.collect-box,.rain-card{padding:10px;border:1px solid #ead2df;border-radius:12px;background:#fff}.memory-section article{display:grid;grid-template-columns:minmax(0,1fr);gap:8px}.memory-section article div{grid-column:1 / -1}.memory-section{display:grid;gap:10px}.memory-section h3{margin:4px 0 0;color:#5d5066;font-size:14px}.memory-avatar{width:34px;height:34px;border-radius:9px;object-fit:cover}.memory-list p,.mail-panel p,.rain-card p{color:#4f4358;font-size:13px;line-height:1.5}.memory-section article>div{display:flex;align-items:center;gap:7px;margin-top:8px}.memory-list span{flex:1}.memory-list button{min-height:28px;padding:0 8px;font-size:12px}.memory-list button:disabled{opacity:.45;cursor:not-allowed}.collect-box{display:flex;align-items:center;justify-content:space-between;gap:10px;background:#f8e5ef}.mail-panel article.claimed{opacity:.62}.visitor-panel{display:grid;gap:12px}.rain-card{text-align:center;background:linear-gradient(120deg,rgba(216,227,255,.62),transparent),#fff}.visitor-door{width:96px;height:144px;margin:0 auto 8px;object-fit:contain}.oc-form{display:grid;gap:11px}.oc-upload{display:grid;grid-template-columns:96px 1fr;gap:10px;align-items:center;padding:10px;border:1px solid #ead0df;border-radius:14px;background:linear-gradient(135deg,#fff,#fff4fa)}.oc-upload p{grid-column:1 / -1;margin:0;color:#746579;font-size:12px;line-height:1.45}.oc-preview{width:96px;height:128px;display:grid;place-items:center;overflow:hidden;border:1px solid #d5bad9;border-radius:12px;background:#f9edf5;color:#9a7f99;font-weight:800}.oc-preview img{width:100%;height:100%;object-fit:cover}.upload-button{min-height:44px;display:grid;place-items:center;border:1px solid #c9b2d1;border-radius:11px;background:#fff;color:#5d5066;cursor:pointer}.upload-button input{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.oc-form label{display:grid;gap:5px;color:#5b4b63;font-size:13px;font-weight:800}.oc-form input,.oc-form select{width:100%;min-height:38px;border:1px solid #cdb5d8;border-radius:9px;background:#fff;color:#4c4054;padding:0 10px}.oc-form input[type=color]{padding:3px}.oc-questionnaire{display:grid;gap:7px;margin:0;padding:9px;border:1px solid #ecd4e2;border-radius:12px;background:#ffffffb8}.oc-questionnaire legend{padding:0 4px;color:#5b4b63;font-size:13px;font-weight:900}.chip-group{display:flex;flex-wrap:wrap;gap:7px}.chip-group button{min-height:31px;padding:0 10px;border-radius:999px;background:#fff;color:#66586f;font-size:12px}.chip-group button.active{border-color:#d39fbd;background:#f7d8ea;color:#49394d;box-shadow:inset 0 -2px #7049691f}@keyframes blink{50%{background:#ffd1ed}}@keyframes idle{50%{margin-top:4px}}@keyframes sleep{50%{transform:rotate(8deg) translateY(3px)}}:root{--ink: #342b3a;--ink-soft: #6c5d74;--ink-muted: #8a7d91;--rose-50: #fffafd;--rose-100: #fdf2f8;--rose-200: #f5d9e8;--rose-300: #e4bfd4;--lavender-100: #efe9ff;--lavender-300: #cdb5d8;--violet: #9a65d6;--glass-fill: rgba(255, 255, 255, .58);--glass-fill-strong: rgba(255, 255, 255, .74);--glass-line: rgba(255, 255, 255, .82);--glass-shadow: 0 20px 54px rgba(88, 66, 103, .18);--glass-inner: inset 0 1px 0 rgba(255, 255, 255, .92), inset 0 -1px 0 rgba(199, 167, 198, .14)}body{background:radial-gradient(circle at 18% 10%,rgba(255,232,246,.95),transparent 28%),radial-gradient(circle at 84% 20%,rgba(221,232,255,.82),transparent 30%),linear-gradient(135deg,#f9edf6,#eef1ff 48%,#fff6fa)}.app-shell{position:relative;isolation:isolate;background:radial-gradient(circle at 18% 16%,rgba(255,216,237,.82),transparent 24%),radial-gradient(circle at 82% 12%,rgba(203,218,255,.78),transparent 25%),radial-gradient(circle at 65% 88%,rgba(255,244,214,.54),transparent 22%),linear-gradient(135deg,#f9edf6,#eef1ff 52%,#fff7fb);background-size:auto}.app-shell:before,.app-shell:after{content:"";position:absolute;z-index:-1;border-radius:999px;pointer-events:none}.app-shell:before{inset:8% auto auto 7%;width:190px;height:190px;background:#ffffff57;filter:blur(2px)}.app-shell:after{right:9%;bottom:10%;width:220px;height:220px;background:#f5d9e84d;filter:blur(10px)}.phone,.auth-page,.loading-page{position:relative;border:1px solid rgba(255,255,255,.84);background:linear-gradient(145deg,#ffffffc2,#fff9fd6b),linear-gradient(180deg,#fdf2f8ad,#efe9ff7a);box-shadow:var(--glass-shadow),var(--glass-inner);backdrop-filter:blur(24px) saturate(1.18);-webkit-backdrop-filter:blur(24px) saturate(1.18)}.phone:before,.auth-page:before,.loading-page:before{content:"";position:absolute;inset:1px;z-index:0;border-radius:inherit;background:linear-gradient(115deg,rgba(255,255,255,.74),transparent 34%),radial-gradient(circle at 82% 8%,rgba(255,255,255,.62),transparent 16%);pointer-events:none}.phone>*,.auth-page>*,.loading-page>*{position:relative;z-index:1}.topbar{padding:3px 2px 4px}.topbar h1,.auth-hero h1{color:#483652;text-shadow:0 1px 0 rgba(255,255,255,.82)}.topbar p,.door-subtitle,.door-meta,.hint-text,.empty-text,.chat-status{color:var(--ink-muted)}.coin-button,.settings-button,.auth-switch,.auth-hero,.highlight-card,.door-wall,.porch-panel,.memory-preview,.butler-dashboard,.panel,.chat-strip,.detail-copy,.gift-recipient,.gift-feedback,.memory-writer,.memory-list article,.mail-panel article,.collect-box,.rain-card,.oc-upload,.oc-questionnaire{border:1px solid var(--glass-line);background:linear-gradient(145deg,#ffffffc7,#fff9fd6b),#ffffff6b;box-shadow:var(--glass-inner),0 12px 30px #60466c1c;backdrop-filter:blur(18px) saturate(1.18);-webkit-backdrop-filter:blur(18px) saturate(1.18)}.coin-button,.settings-button,.quick-actions button,.split-actions button,.collect-box button,.oc-form button,.panel header button,.memory-list button,.detail-actions button,.chat-compose button,.memory-preview button,.butler-actions button,.highlight-actions button,.upload-button,.auth-submit{border:1px solid rgba(255,255,255,.86);background:linear-gradient(180deg,#ffffffe0,#fff7fca8),#ffffff7a;color:#563d62;box-shadow:inset 0 1px #fffffff0,inset 0 -3px 8px #cdb5d82e,0 8px 18px #5842671a;backdrop-filter:blur(14px) saturate(1.12);-webkit-backdrop-filter:blur(14px) saturate(1.12);transition:border-color .16s ease,box-shadow .16s ease,background .16s ease,opacity .16s ease}.coin-button:hover,.settings-button:hover,.quick-actions button:hover,.split-actions button:hover,.collect-box button:hover,.oc-form button:hover,.panel header button:hover,.memory-list button:hover,.detail-actions button:hover,.chat-compose button:hover,.memory-preview button:hover,.butler-actions button:hover,.highlight-actions button:hover,.upload-button:hover,.auth-submit:hover{border-color:#cdb5d8d1;box-shadow:inset 0 1px #fffffff5,inset 0 -3px 8px #cdb5d838,0 10px 24px #58426724}.quick-actions button:active,.split-actions button:active,.collect-box button:active,.oc-form button:active,.detail-actions button:active,.chat-compose button:active,.memory-preview button:active,.butler-actions button:active,.highlight-actions button:active,.auth-submit:active{background:linear-gradient(180deg,#f5d9e8b8,#ffffffad),#ffffff80;box-shadow:inset 0 2px 8px #7e5b8b1f,inset 0 1px #ffffffd1}.account-menu,.intro-panel{border:1px solid rgba(255,255,255,.82);background:linear-gradient(145deg,#ffffffd6,#fff9fd8f),#ffffff8f;box-shadow:var(--glass-inner),0 18px 42px #48384e2e;backdrop-filter:blur(22px) saturate(1.18);-webkit-backdrop-filter:blur(22px) saturate(1.18)}.account-menu button,.intro-copy button,.observe-actions button{border:1px solid rgba(255,255,255,.86);background:linear-gradient(180deg,#ffffffd1,#f5d9e8b8),#ffffff8a;color:#563d62;box-shadow:var(--glass-inner),0 8px 18px #5842671a}.auth-switch{padding:6px;border-radius:18px}.auth-switch button.active,.module-nav button.active,.memory-tabs button.active,.chip-group button.active{background:linear-gradient(180deg,#ffffffb8,#f5d9e8c7),linear-gradient(135deg,#9a65d629,#f5d9e866);color:#4a2e58;box-shadow:inset 0 1px #fffffff2,0 8px 18px #9a65d621}.mobile-auth-fields input,.chat-compose textarea,.memory-writer textarea,.oc-form input,.oc-form select{border:1px solid rgba(255,255,255,.82);background:#ffffffa8;box-shadow:inset 0 1px #ffffffdb,0 8px 18px #60466c12;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.mobile-auth-fields input:focus,.chat-compose textarea:focus,.memory-writer textarea:focus,.oc-form input:focus,.oc-form select:focus{border-color:#9a65d66b;outline:none;box-shadow:0 0 0 3px #f5d9e8b8,inset 0 1px #ffffffeb}.highlight-card{min-height:142px;border-radius:20px;background:linear-gradient(105deg,#ffffffc2 0 52%,#f5d9e847 52% 100%),#ffffff73}.highlight-frame,.door-art,.butler-portrait,.chat-avatar,.door-stage,.room-stage,.oc-preview,.pixel-room{border:1px solid rgba(255,255,255,.8);background:linear-gradient(180deg,#ffffff8a,#f5d9e838),#ffffff47;box-shadow:inset 0 1px #ffffffdb}.door-wall{gap:9px;padding:9px;border-radius:22px}.door-card{border:1px solid rgba(255,255,255,.78);border-radius:16px;background:linear-gradient(165deg,#ffffffd1,#ffffff57 42%),linear-gradient(180deg,color-mix(in srgb,var(--door, #f6d6e7),#fff 64%),color-mix(in srgb,var(--door, #f6d6e7),#fff 12%));box-shadow:inset 0 1px #ffffffe6,inset 0 -10px 20px #835d7714,0 10px 22px #60466c1a}.door-card.selected{outline:0;border-color:#fffffff5;box-shadow:inset 0 1px #fffffff5,inset 0 -10px 20px #835d7717,0 0 0 2px color-mix(in srgb,var(--accent),#fff 48%),0 14px 28px #60466c24}.rent-tag{border-color:#ffffffdb;border-radius:999px;background:#fff8c9b8;box-shadow:inset 0 1px #ffffffe0}.butler-card,.visitor-door-card,.memory-preview article,.gift-grid button{border:1px solid rgba(255,255,255,.78);background:linear-gradient(145deg,#ffffffd1,#fff9fd75),#ffffff70;box-shadow:var(--glass-inner),0 10px 24px #60466c17;backdrop-filter:blur(16px) saturate(1.12);-webkit-backdrop-filter:blur(16px) saturate(1.12)}.module-nav{margin:10px -2px 0;padding:7px 7px max(7px,env(safe-area-inset-bottom));border:1px solid rgba(255,255,255,.78);border-radius:20px;background:#ffffff7a;box-shadow:var(--glass-inner),0 12px 30px #5842671f;backdrop-filter:blur(22px) saturate(1.18);-webkit-backdrop-filter:blur(22px) saturate(1.18)}.quick-actions button{height:58px;border-radius:15px}.panel-backdrop{background:radial-gradient(circle at 50% 18%,rgba(255,255,255,.32),transparent 30%),#48384e33;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.panel{border-radius:24px 24px 20px 20px;background:linear-gradient(145deg,#ffffffd1,#fff9fd8f),#ffffff85;box-shadow:0 -18px 48px #48384e38,var(--glass-inner)}.panel header{border-bottom:1px solid rgba(255,255,255,.74);background:#ffffff8a;backdrop-filter:blur(20px) saturate(1.12);-webkit-backdrop-filter:blur(20px) saturate(1.12)}.panel header button{border-radius:50%}.chat-strip{border-radius:18px}.chat-avatar,.character-avatar,.memory-avatar,.room-avatar{box-shadow:0 0 0 1px #ffffffe6,0 8px 18px #48384e24}.message-list,.door-wall,.porch-panel,.memory-preview,.butler-dashboard,.panel{scrollbar-color:rgba(205,181,216,.72) transparent}.message-list::-webkit-scrollbar,.door-wall::-webkit-scrollbar,.porch-panel::-webkit-scrollbar,.memory-preview::-webkit-scrollbar,.butler-dashboard::-webkit-scrollbar,.panel::-webkit-scrollbar{width:8px}.message-list::-webkit-scrollbar-thumb,.door-wall::-webkit-scrollbar-thumb,.porch-panel::-webkit-scrollbar-thumb,.memory-preview::-webkit-scrollbar-thumb,.butler-dashboard::-webkit-scrollbar-thumb,.panel::-webkit-scrollbar-thumb{border:2px solid transparent;border-radius:999px;background:#cdb5d89e;background-clip:padding-box}.message{border:1px solid rgba(255,255,255,.78);border-radius:18px 18px 18px 7px;background:#ffffffa3;box-shadow:var(--glass-inner),0 8px 18px #60466c14;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}.message.player{border-radius:18px 18px 7px;background:linear-gradient(145deg,#ffffffa8,#f5d9e8c2),#f5d9e8a3;color:#432d4e}.chat-footer{margin:8px -14px -14px;padding:10px 14px max(12px,env(safe-area-inset-bottom));border-top:1px solid rgba(255,255,255,.7);background:#fffafd75;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}.panel-chat-shell .chat-footer{border-radius:0 0 18px 18px}.chat-compose textarea,.chat-compose button{border-radius:16px}.detail-copy,.memory-writer,.collect-box,.oc-upload{border-radius:18px}.gift-recipient,.gift-feedback,.memory-list article,.mail-panel article,.rain-card,.oc-questionnaire{border-radius:16px}.chip-group button,.memory-tabs button{border-radius:999px}.door-stage.portrait-only{background:linear-gradient(180deg,#ffffff57,#f5d9e81f),radial-gradient(circle at 50% 18%,rgba(255,255,255,.5),transparent 34%),#f4eaf494}.detail-fullbody,.chat-fullbody,.highlight-fullbody{filter:saturate(.96) contrast(1.02) drop-shadow(0 12px 22px rgba(72,56,78,.1))}.empty-text{padding:10px 12px;border:1px dashed rgba(255,255,255,.8);border-radius:15px;background:#ffffff57}@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))){.phone,.auth-page,.loading-page,.panel,.door-card,.message{background-color:#fffafdf0}}@media(max-width:420px){.app-shell{padding:0;height:100dvh}.phone{width:100vw;height:100vh;height:100dvh;padding:16px 14px 10px;border:0;border-radius:0;background:linear-gradient(145deg,#ffffffb8,#fff9fd75),linear-gradient(180deg,#fdf2f8ad,#efe9ff85)}.phone:before{border-radius:0}.door-wall{grid-auto-rows:160px;gap:8px;margin-top:8px;padding:8px}.door-card{grid-template-rows:84px minmax(0,1fr);padding:6px 7px 8px}.door-nameplate{width:78px;height:29px}.quick-actions{gap:7px;margin-top:8px}.quick-actions button{height:55px;border-radius:14px}.panel-backdrop{padding:10px}.panel{max-height:88%}.panel-chat-shell{height:min(88%,650px)}}.phone>.module-nav{position:sticky;bottom:0;z-index:6;flex-shrink:0}.phone>.panel-backdrop{position:absolute;inset:0;z-index:40;display:flex;align-items:flex-end;justify-content:center;padding:0 8px max(10px,env(safe-area-inset-bottom))}.phone>.intro-backdrop{align-items:center;padding:14px}.door-wall,.porch-panel,.memory-preview,.butler-dashboard{flex:1 1 auto;min-height:0;overflow-y:auto}.panel{max-height:calc(100% - 18px)}.panel-chat-shell{height:calc(100% - 18px);max-height:660px}@media(max-width:420px){.phone>.panel-backdrop{padding:8px 10px max(8px,env(safe-area-inset-bottom))}.phone>.intro-backdrop{padding:14px}.panel{max-height:calc(100% - 16px)}.panel-chat-shell{height:calc(100% - 16px)}}
