:root{color:#edf0f5;background:#0a0f16;font-family:-apple-system,BlinkMacSystemFont,PingFang TC,PingFang SC,Noto Sans TC,Microsoft JhengHei,sans-serif;line-height:1.42}*{box-sizing:border-box}html,body,#root{width:100%;height:100%}body{margin:0;background:#0a0f16}button,input,textarea{font:inherit}button{cursor:pointer}.app-root{position:relative;display:block;height:100vh;overflow:hidden;background:radial-gradient(circle at 50% 18%,rgba(70,91,120,.26),transparent 38%),#0a0f16}.auth-root{display:grid;place-items:center;padding:18px}.auth-panel{display:flex;flex-direction:column;gap:10px;width:min(420px,100%);border:1px solid rgba(185,196,210,.14);border-radius:12px;background:#111720b8;padding:18px;box-shadow:0 18px 48px #00000047,inset 0 1px #ffffff0a;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.auth-heading h1,.auth-panel h1{margin:0;color:#f8fafc;font-size:26px;line-height:1.15}.auth-heading p,.auth-panel p{margin:4px 0 0;color:#e1e7eead;font-size:13px}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px}.auth-tabs button{min-height:34px;border:1px solid rgba(185,196,210,.16);border-radius:999px;background:#1c212ab8;color:#dfe5eb;font-weight:800}.auth-tabs button.active{border-color:#f2c84e5c;color:#f2c84e}.auth-submit{width:100%}.app-nav{position:fixed;top:max(18px,env(safe-area-inset-top));left:24px;right:24px;z-index:20;display:grid;grid-template-columns:64px minmax(260px,680px) auto;align-items:center;justify-content:center;gap:14px;pointer-events:none}.page-tabs,.bubble-tools{display:flex;align-items:center}.nav-circle,.nav-pill,.page-tabs button{border:1px solid rgba(185,196,210,.18);background:#1c212abd;box-shadow:0 12px 34px #00000052,inset 0 1px #ffffff0f;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);pointer-events:auto}.nav-circle{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:999px;color:#f2f5f8}.nav-pill{display:grid;grid-template-columns:minmax(0,1fr);align-items:center;min-width:0;height:64px;border-radius:999px;padding:8px 20px}.nav-title-block{min-width:0}.nav-title-block strong{display:flex;align-items:center;min-width:0;overflow:hidden;color:#f8fafc;font-size:22px;font-weight:900;line-height:1.12;text-overflow:ellipsis;white-space:nowrap}.page-tabs{justify-content:flex-end;gap:10px}.mobile-menu-button,.mobile-menu-popover,.bottom-page-pill{display:none}.page-tabs button{position:relative;display:inline-flex;align-items:center;justify-content:center;width:58px;height:58px;border-radius:999px;color:#eef2f5}.page-tabs button.active{border-color:#f2c84e5c;color:#f2c84e}.card-page,.play-layout{min-height:0}.card-page{height:100vh;overflow:auto;background:linear-gradient(#070b12c7,#070b12e6),radial-gradient(circle at 50% 24%,rgba(86,104,132,.24),transparent 42%),#0a0f16;padding:108px max(5vw,22px) 24px}.form-page .page-panel{max-width:860px;margin:0 auto}.play-layout{display:grid;grid-template-columns:minmax(0,1fr);height:100vh;overflow:hidden}.page-panel,.memory-item{min-width:0;border:1px solid rgba(185,196,210,.14);background:#111720a3;box-shadow:0 18px 48px #00000042,inset 0 1px #ffffff0a;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.page-panel{border-radius:18px;padding:18px}.card-catalog,.chat-catalog{max-width:1120px;margin:0 auto}.page-heading h1,.character-card h2{margin:0;color:#f8fafc;letter-spacing:0}.page-heading h1{font-size:clamp(30px,4vw,54px);line-height:1.2;font-weight:950}.character-card h2{font-size:22px}.page-heading p,.character-card p{margin:4px 0 0;color:#e1e7eead}.split-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.card-form{display:flex;flex-direction:column;gap:10px}.panel-title{display:flex;align-items:center;justify-content:space-between;min-height:32px;color:#d8d0bc;font-size:14px;font-weight:800}.form-actions{display:flex;justify-content:flex-end;padding-top:2px}.character-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:10px;margin-top:14px}.chat-list-page{display:flex;flex-direction:column;gap:8px;margin-top:14px}.chat-list-row{display:grid;grid-template-columns:minmax(0,1fr) 48px;gap:10px;align-items:stretch}.character-card,.list-item,.message,.memory-item{border:1px solid rgba(185,196,210,.13);border-radius:8px;background:#1c212ab8;box-shadow:0 12px 32px #00000038,inset 0 1px #ffffff0a;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.character-card{display:grid;grid-template-rows:minmax(126px,1fr) auto;gap:10px;min-height:204px;padding:14px}.card-actions{display:grid;grid-template-columns:minmax(0,1fr) 42px 42px;gap:10px;align-items:center}.list-item{display:flex;flex-direction:column;gap:4px;width:100%;min-height:72px;padding:12px;color:#f3f6fa;text-align:left}.list-item strong,.list-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.list-item span{color:#e1e7ee9e;font-size:13px}.chat-area{position:relative;display:grid;grid-template-rows:minmax(0,1fr) auto auto;min-width:0;min-height:0;background:linear-gradient(#090d14b8,#090d14db),radial-gradient(circle at 48% 36%,rgba(82,95,114,.3),transparent 42%),#090d14;overflow:hidden}.bubble-tools{width:min(920px,100%);flex-wrap:wrap;gap:4px;margin-top:2px;opacity:.74}.bubble-tools .icon-button{width:auto;min-width:28px;height:28px;padding:0 8px}.bubble-tools .icon-button svg{width:14px;height:14px}.icon-button.labeled{gap:4px;font-size:12px;font-weight:750}.icon-button{display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(185,196,210,.18);border-radius:999px;background:#1c212ab8;color:#dfe5eb;width:34px;height:34px}.icon-button:disabled,.composer button:disabled,.compact:disabled{cursor:not-allowed;opacity:.45}.messages{display:flex;flex-direction:column;gap:16px;min-height:0;overflow:auto;padding:112px max(6vw,28px) 20px}.message-row{display:flex;flex-direction:column;width:min(980px,100%);margin-inline:auto}.message-row.memory{align-items:center;width:min(680px,100%)}.message-row.user .bubble-tools{justify-content:flex-end}.message-row.assistant .bubble-tools{justify-content:flex-start}.message-row.memory .bubble-tools{justify-content:center}.message{width:100%;border:0;background:transparent;padding:0}.message.user{border-left:2px solid rgba(242,200,78,.32);padding-left:12px}.message.memory{border:1px solid rgba(201,176,104,.22);border-radius:18px;background:#13181fa8;padding:10px}.message.memory.collapsed{border-style:dashed}.message-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#d7ad55;font-size:13px;font-weight:800}.message-content{margin:0;color:#f0f4f8e6;white-space:pre-wrap;overflow-wrap:anywhere;font-size:clamp(22px,2.1vw,34px);line-height:1.62;font-weight:520}.message-meta+.message-content{margin-top:8px}.message-content :where(p,div,blockquote,ul,ol),.memory-content :where(p,div,blockquote,ul,ol){margin:0 0 .42em}.message-content :where(p,div,blockquote,ul,ol):last-child,.memory-content :where(p,div,blockquote,ul,ol):last-child{margin-bottom:0}.message-content :where(ul,ol),.memory-content :where(ul,ol){padding-inline-start:1.05em;line-height:1.32}.message-content li+li,.memory-content li+li{margin-top:.06em}.message-content blockquote,.memory-content blockquote{border-left:3px solid rgba(215,173,85,.42);color:#f0f4f8c7;padding-left:.85em}.message-content hr,.memory-content hr{border:0;border-top:1px solid rgba(240,244,248,.16);height:0;margin:.3em 0}.memory-preview{color:#bdb5a4}.memory-toggle{display:inline-flex;align-items:center;gap:4px;border:1px solid #3a403a;border-radius:8px;background:#171a18;color:#d8d0bc;padding:3px 8px;font-size:12px;font-weight:800}.scroll-bottom-button{position:absolute;right:max(26px,6vw);bottom:108px;display:inline-flex;align-items:center;gap:6px;min-height:34px;border:1px solid #4b594f;border-radius:8px;background:#26342c;color:#f3ead0;padding:0 10px;box-shadow:0 8px 24px #00000047;font-size:13px;font-weight:850}.empty-state{margin:auto;color:#a9a39a}.memory-organizing-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;margin:0 max(3vw,20px);border-radius:14px;background:#48566952;border:1px solid rgba(185,196,210,.22);color:#e6ecf3;font-size:14px;font-weight:600}.memory-organizing-spinner{display:inline-block;width:16px;height:16px;border-radius:50%;border:2px solid rgba(232,240,252,.32);border-top-color:#e6ecf3;animation:memory-organizing-spin .8s linear infinite;flex-shrink:0}@keyframes memory-organizing-spin{to{transform:rotate(360deg)}}.composer{display:grid;grid-template-columns:minmax(0,1fr) 64px;gap:8px;align-items:center;border-top:1px solid rgba(185,196,210,.14);background:#0b1017db;padding:12px max(3vw,20px) calc(12px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.composer.is-busy textarea{background:#1b1f26c7;color:#e8f0fc8c;font-style:italic}.composer.is-busy textarea::placeholder{color:#e8f0fcbf;font-style:italic}.composer.is-busy button{background:#4856698c;opacity:1;color:#e6ecf3;cursor:progress}.composer-spinner{animation:memory-organizing-spin .9s linear infinite}.composer textarea{min-height:54px;max-height:140px;border-radius:999px;background:#2b303ad1;padding:14px 20px;resize:none;font-size:20px;font-weight:760}.composer button,.compact{display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:38px;border:0;border-radius:999px;background:#485669db;color:#f8fafc;padding:0 12px;font-weight:800}.card-actions .icon-button,.chat-list-row .icon-button{width:42px;height:42px}.composer button{width:64px;height:64px;min-height:64px;background:#232933db;padding:0}.compact.secondary{border:1px solid #3c443e;background:#202520;color:#d8d4ca}.edit-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;justify-content:flex-end;background:#0000006b}.edit-drawer{display:grid;grid-template-rows:auto minmax(0,1fr) auto;gap:10px;width:min(520px,100%);height:100%;border-left:1px solid #343a35;background:#171a18;padding:14px;box-shadow:-16px 0 32px #00000057}.drawer-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.drawer-heading h2{margin:0;color:#f0e7d2;font-size:20px;letter-spacing:0}.drawer-kicker{color:#cbbd98;font-size:12px;font-weight:850}.drawer-editor{min-height:0;resize:none}.drawer-actions{display:flex;justify-content:flex-end;gap:6px}.memory-drawer{grid-template-rows:auto minmax(0,1fr)}.drawer-memory-list{display:flex;flex-direction:column;gap:6px;min-height:0;overflow:auto}.field{display:flex;flex-direction:column;gap:4px;color:#d8d0bc;font-size:13px;font-weight:800}.form-section-title{margin-top:4px;border-top:1px solid #2b302c;color:#e9d8a6;padding-top:8px;font-size:14px;font-weight:850}.field-help,.field-count{color:#9d978d;font-size:12px;font-weight:600}.field-count{align-self:flex-end}input,textarea{width:100%;border:1px solid #343a35;border-radius:8px;background:#111412;color:#f0eadf;padding:8px}input:focus,textarea:focus{border-color:#6c8f7a;outline:2px solid #21352b}textarea{resize:vertical}.memory-item{display:grid;grid-template-columns:minmax(0,1fr) 34px;gap:6px;align-items:start;color:#ece7dc;padding:8px;white-space:pre-wrap;overflow-wrap:anywhere}.memory-content{margin:0}.hint{color:#a9a39a;font-size:13px}.error{border-top:1px solid #6f3f35;background:#2d1916;color:#f0afa1;padding:8px 16px;font-size:13px}.page-error{grid-column:1 / -1;border:1px solid #6f3f35;border-radius:8px}@media (max-width: 760px){.app-nav-list-page{display:none}.bottom-page-pill{position:fixed;left:50%;bottom:calc(10px + env(safe-area-inset-bottom));z-index:22;display:inline-flex;align-items:center;gap:4px;border:1px solid rgba(185,196,210,.18);border-radius:999px;background:#141922d1;padding:4px;box-shadow:0 14px 38px #0000005c,inset 0 1px #ffffff0f;transform:translate(-50%);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.bottom-page-pill button{display:inline-flex;align-items:center;justify-content:center;gap:4px;min-width:62px;height:34px;border:0;border-radius:999px;background:transparent;color:#eef2f5b8;padding:0 8px;font-size:12px;font-weight:850}.bottom-page-pill button.active{background:#f2c84e24;color:#f2c84e}.app-nav{top:max(8px,env(safe-area-inset-top));left:14px;right:14px;grid-template-columns:42px minmax(0,1fr) auto;gap:8px}.nav-circle,.mobile-menu-button{width:42px;height:42px}.nav-pill{height:42px;padding:5px 12px}.nav-title-block strong{font-size:17px;font-weight:800}.page-tabs{display:none}.mobile-menu-button{display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(185,196,210,.18);border-radius:999px;background:#1c212abd;color:#eef2f5;box-shadow:0 12px 34px #00000052,inset 0 1px #ffffff0f;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);pointer-events:auto}.mobile-menu-popover{position:absolute;top:calc(100% + 6px);right:0;display:flex;flex-direction:column;gap:4px;min-width:156px;border:1px solid rgba(185,196,210,.16);border-radius:16px;background:#111720eb;padding:8px;box-shadow:0 18px 42px #00000061,inset 0 1px #ffffff0d;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);pointer-events:auto}.mobile-menu-popover button{display:inline-flex;align-items:center;gap:8px;min-height:34px;border:0;border-radius:10px;background:transparent;color:#eef2f5;padding:0 8px;font-weight:850;text-align:left}.nav-label{display:none}.card-page{padding-top:16px;padding-bottom:calc(66px + env(safe-area-inset-bottom))}.page-panel{padding:12px}.page-heading h1{font-size:24px}.page-heading p{font-size:13px}.character-grid{grid-template-columns:1fr}.chat-list-row{grid-template-columns:minmax(0,1fr) 42px}.chat-area{min-height:0;height:100vh}.composer{grid-template-columns:minmax(0,1fr) 46px;gap:6px;padding:8px 12px calc(8px + env(safe-area-inset-bottom))}.composer button{width:46px;height:46px;min-height:46px}.composer textarea{min-height:42px;padding:9px 14px;font-size:15px;font-weight:600}.messages{gap:12px;padding:68px 14px 10px}.message-meta{align-items:flex-start;flex-direction:column;gap:6px}.message-content{color:#f0f4f8e0;font-size:17px;line-height:1.58;font-weight:500;letter-spacing:0}.message.assistant{position:relative;overflow:hidden;border:1px solid rgba(238,244,255,.18);border-radius:18px;background:linear-gradient(135deg,#ffffff21,#ffffff09 42%,#ffffff13),#10161f85;padding:10px;box-shadow:0 16px 38px #00000047,inset 0 1px #ffffff47,inset 0 -1px #ffffff14;backdrop-filter:blur(18px) saturate(1.2);-webkit-backdrop-filter:blur(18px) saturate(1.2)}.message.assistant .message-meta+.message-content{margin-top:6px}.bubble-tools{opacity:.62}.scroll-bottom-button{right:14px;bottom:92px}.edit-drawer-backdrop{align-items:flex-end}.edit-drawer{width:100%;height:min(78vh,580px);border-width:1px 0 0;border-radius:8px 8px 0 0;box-shadow:0 -16px 32px #00000057}}@media (min-width: 761px){.app-root{display:grid;grid-template-rows:auto minmax(0,1fr);background:#101211}.app-nav{position:static;display:flex;grid-template-columns:none;justify-content:flex-end;min-height:54px;border-bottom:1px solid #2b302c;background:#171a18;padding:0 14px;pointer-events:auto}.nav-circle,.nav-pill{display:none}.page-tabs button{width:auto;height:34px;border-radius:8px;padding:0 10px;gap:6px}.nav-label{display:inline}.card-page{height:auto;min-height:0;background:#101211;padding:12px}.page-panel,.memory-item{border:1px solid #2b302c;background:#171a18;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.page-panel{border-radius:8px;padding:12px}.form-page .page-panel{max-width:760px}.page-heading h1{color:#f0e7d2;font-size:22px;font-weight:800}.page-heading p,.character-card p{color:#a9a39a}.character-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;margin-top:10px}.chat-list-page{gap:8px;margin-top:10px}.chat-list-row{grid-template-columns:minmax(0,1fr) 38px;gap:8px}.character-card,.list-item,.message,.memory-item{border:1px solid #303830;background:#1e241f;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.character-card{grid-template-rows:minmax(92px,1fr) auto;min-height:164px;padding:10px}.character-card h2{color:#f0e7d2;font-size:17px}.card-actions{grid-template-columns:minmax(0,1fr) 34px 34px;gap:6px}.card-actions .icon-button,.chat-list-row .icon-button{width:34px;height:34px}.list-item{min-height:58px;padding:8px;color:#ebe4d5}.list-item span{color:#a9a39a}.play-layout{height:100%}.chat-area{background:#101211}.messages{gap:12px;padding:14px}.message-row{width:min(820px,100%);margin-inline:0}.message-row.user{align-self:flex-end}.message-row.assistant{align-self:flex-start}.message{border:1px solid #303830;background:#1e241f;padding:10px}.message.user{border-color:#4f7768;border-left:1px solid #4f7768;background:#1b3029;padding-left:10px}.message-content{margin:6px 0 0;color:#ece7dc;font-size:16px;line-height:1.48;font-weight:400}.composer{grid-template-columns:minmax(0,1fr) 58px;gap:8px;border-top:1px solid #2b302c;background:#151816;padding:10px 16px;-webkit-backdrop-filter:none;backdrop-filter:none}.composer textarea{min-height:48px;border-radius:8px;padding:9px 10px;font-size:16px;font-weight:400}.composer button{width:48px;height:48px;min-height:48px}}
