:root{color:#252731;background:#f6f4ef;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#app{width:100%;min-width:320px;min-height:100%;margin:0;overflow-x:hidden}body{min-height:100vh;background:radial-gradient(circle at 18% 8%,rgba(47,107,255,.12),transparent 26%),linear-gradient(135deg,#fbfaf7,#f4f0e9 52%,#eef4f0)}button,input,textarea,select{font:inherit}button{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:40px;border:0;border-radius:12px;padding:10px 14px;color:#30313a;background:#fff;box-shadow:inset 0 0 0 1px #24262f1a;cursor:pointer;white-space:nowrap;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 10px 24px #24262f1a}button:disabled{cursor:not-allowed;opacity:.45}input,textarea,select{width:100%;min-width:0;border:1px solid rgba(36,38,47,.12);border-radius:12px;padding:11px 12px;color:#252731;background:#ffffffeb;outline:none}textarea{resize:vertical}label{display:grid;gap:8px;min-width:0;color:#626675;font-size:13px}h1,h2,h3,h4,p{overflow-wrap:normal;word-break:normal}.primary{color:#fff;background:#2f6bff;box-shadow:0 12px 28px #2f6bff3d}.primary.large{min-height:48px;padding:14px 20px;font-weight:700}.danger{color:#c33434!important}.ghost{background:transparent;box-shadow:none}.product-shell{display:grid;grid-template-columns:260px minmax(0,1fr);width:100%;height:100vh;min-height:100vh;overflow:hidden}.product-shell.chat-mode{display:block;height:100vh;overflow:hidden;background:radial-gradient(circle at 20% 10%,rgba(47,107,255,.2),transparent 30%),linear-gradient(145deg,#191b28,#26343b 55%,#18201f)}.product-shell.workspace-mode{display:block;height:auto;min-height:100vh;overflow-x:hidden;overflow-y:auto}.sidebar{width:260px;min-width:260px;max-width:260px;height:100vh;padding:24px 18px;overflow:hidden;border-right:1px solid rgba(36,38,47,.08);background:#ffffffdb;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;flex-direction:column;gap:24px}.brand{display:flex;align-items:center;gap:12px;min-width:0}.brand-mark,.workspace-avatar,.avatar-ring,.avatar-placeholder{display:grid;place-items:center;flex:0 0 auto;overflow:hidden;color:#fff;background:linear-gradient(135deg,#2f6bff,#1ba784)}.brand-mark{width:42px;height:42px;border-radius:14px;font-weight:800}.brand h1,.brand p,.chat-identity h2,.chat-identity p{margin:0;white-space:nowrap}.brand h1{font-size:18px}.brand p,.sidebar-note,.eyebrow,.card-meta,.mini-companion small{color:#737786;font-size:12px}.nav{display:grid;gap:8px}.nav button{width:100%;justify-content:flex-start;padding:11px 12px;overflow:hidden;background:transparent;box-shadow:none;font-weight:650;text-align:left;white-space:nowrap}.nav button span{flex:0 0 22px;width:22px;text-align:center}.nav button.active{color:#2f6bff;background:#2f6bff1a}.create-sidebar{width:100%}.sidebar-note{margin:auto 0 0;line-height:1.6}.content{min-width:0;width:100%;height:100vh;overflow-x:hidden;overflow-y:auto;padding:0}.app-header{position:sticky;top:0;z-index:15;height:88px;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 40px;border-bottom:1px solid rgba(36,38,47,.08);background:#fbfaf7e6;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.app-header h2,.app-header p{margin:0;white-space:nowrap}.app-header h2{font-size:24px}.home-page,.companions-page,.sync-page,.content>.empty-state{width:min(100%,1400px);margin:0 auto;padding:32px 40px 56px}.workspace-content,.chat-content{max-width:none;padding:0}.menu-toggle,.sidebar-backdrop{display:none}.home-page,.companions-page,.sync-page,.page{display:grid;gap:24px;min-width:0}.hero-panel{display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:36px;align-items:center;min-height:340px;padding:42px;border:1px solid rgba(36,38,47,.08);border-radius:28px;background:#ffffffc7;box-shadow:0 24px 70px #24262f14}.hero-panel h2,.page-header h2,.workspace-title h2{margin:0;max-width:820px;font-size:clamp(34px,3.8vw,56px);line-height:1.08;letter-spacing:0}.hero-panel p,.page-header p,.workspace-title p{max-width:720px;line-height:1.7;color:#626675}.hero-actions,.actions,.backup-actions{display:flex;flex-wrap:wrap;gap:10px;min-width:0}.hero-orbit{aspect-ratio:1;min-width:0;border-radius:30px;background:linear-gradient(145deg,#2f6bff1f,#1ba78429),#fff;display:grid;place-items:center;position:relative}.hero-orbit span{position:absolute;padding:12px 16px;border-radius:999px;background:#fff;box-shadow:0 16px 36px #24262f1f;font-weight:700;white-space:nowrap}.hero-orbit span:nth-child(1){top:20%;left:13%}.hero-orbit span:nth-child(2){right:12%}.hero-orbit span:nth-child(3){bottom:18%}.quick-grid,.conversation-groups,.sync-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.quick-card,.activity-panel,.panel,.empty-state{min-width:0;border:1px solid rgba(36,38,47,.08);border-radius:20px;background:#ffffffd6;box-shadow:0 16px 40px #24262f0f;padding:22px}.quick-card p,.quick-card h3,.activity-panel p,.activity-panel h3{margin:0 0 12px}.muted-line{display:block;max-width:100%;overflow:hidden;color:#7a7f8f;font-size:12px;line-height:1.5;text-overflow:ellipsis;white-space:nowrap}.section-heading,.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;min-width:0}.section-heading h3,.page-header h2{margin:0}.recent-strip,.companion-grid,.character-grid,.reply-grid,.future-grid{display:grid;gap:18px;min-width:0}.companion-grid{grid-template-columns:repeat(auto-fill,minmax(310px,1fr))}.recent-strip,.character-grid,.reply-grid,.future-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.mini-companion,.companion-card{position:relative;min-width:0;border:1px solid rgba(36,38,47,.08);border-radius:24px;background:#ffffffe0;transition:transform .22s ease,box-shadow .22s ease}.mini-companion:hover,.companion-card:hover{transform:translateY(-4px);box-shadow:0 22px 60px #24262f1f}.mini-companion{display:grid;grid-template-columns:86px minmax(0,1fr);gap:16px;padding:14px;overflow:hidden}.mini-companion .actions{grid-column:1 / -1}.mini-cover,.avatar-ring,.workspace-avatar{width:74px;height:74px;border-radius:22px;overflow:hidden}.mini-cover img,.cover img,.avatar-ring img,.workspace-avatar img,.character-card-head img,.chat-identity img,.chat-choice-grid img,.preview-character img{width:100%;height:100%;object-fit:cover}.cover{position:relative;height:170px;overflow:hidden;border-radius:24px 24px 0 0;background:linear-gradient(135deg,#dfe8ff,#dff6ed)}.cover img{filter:saturate(1.1);transform:scale(1.08)}.cover-shade{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.22))}.companion-body{position:relative;display:grid;gap:12px;min-width:0;padding:0 20px 20px}.avatar-ring{margin-top:-34px;border:4px solid #fff;box-shadow:0 12px 28px #24262f29}.companion-body h3,.companion-body p,.mini-companion h4,.mini-companion p{margin:0}.companion-title{max-width:100%;overflow:hidden;color:#20222c;font-size:24px;line-height:1.2;font-weight:800;text-overflow:ellipsis;white-space:nowrap}.companion-body p,.mini-companion p{color:#626675;line-height:1.55}.card-meta{display:flex;justify-content:space-between;gap:12px;white-space:nowrap}.card-menu{position:absolute;top:12px;right:12px;z-index:2}.card-menu>button{width:38px;height:38px;min-height:38px;padding:0;border-radius:999px;background:#fffffff0}.menu-popover{position:absolute;right:0;top:44px;z-index:5;display:none;min-width:170px;padding:8px;border:1px solid rgba(36,38,47,.1);border-radius:16px;background:#fff;box-shadow:0 18px 44px #24262f29}.card-menu:hover .menu-popover:not(.floating-menu-popover),.card-menu:focus-within .menu-popover:not(.floating-menu-popover){display:grid;gap:4px}.floating-menu-popover{position:fixed;right:auto;top:auto;z-index:9999;display:grid;gap:4px;min-width:176px;max-width:calc(100vw - 16px);background:#fff;border-radius:16px;box-shadow:0 22px 60px #1c1f2a38}.menu-popover button{width:100%;justify-content:flex-start;box-shadow:none;background:transparent;text-align:left}.menu-popover hr{width:100%;border:0;border-top:1px solid rgba(36,38,47,.08)}.workspace-page{min-height:100vh;overflow-x:hidden;background:#fbfaf7}.workspace-header{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:20px;align-items:center;padding:24px 40px 18px;border-bottom:1px solid rgba(36,38,47,.08);background:#ffffffe6}.workspace-title{display:flex;align-items:center;gap:16px;min-width:0}.workspace-title h2{font-size:clamp(26px,2.6vw,38px)}.workspace-title p{margin:4px 0 0}.workspace-tabs{display:flex;gap:8px;width:100%;max-width:1400px;margin:0 auto;padding:16px 40px 0;overflow-x:auto;scrollbar-width:thin}.workspace-tabs button{flex:0 0 auto;border-radius:999px;background:transparent;box-shadow:none;font-weight:700}.workspace-tabs button.active{color:#2f6bff;background:#2f6bff1a}.workspace-page>.page{width:min(100%,1400px);margin:0 auto;padding:24px 40px 48px}.character-card,.reply-card{display:grid;gap:14px}.character-card-head{display:grid;grid-template-columns:64px minmax(0,1fr) 40px;gap:12px;align-items:center;position:relative}.character-card-head img,.avatar-placeholder{width:64px;height:64px;border-radius:20px}.character-card h4{margin:0}.avatar-upload{display:grid;gap:12px;padding:14px;border:1px solid rgba(36,38,47,.08);border-radius:16px;background:#f7f9fcc7}.avatar-upload p{margin:0;color:#626675;font-size:13px}.avatar-preview{display:grid;place-items:center;width:96px;height:96px;overflow:hidden;border-radius:26px;color:#fff;background:linear-gradient(135deg,#2f6bff,#1ba784);font-size:32px;font-weight:800}.avatar-preview img{width:100%;height:100%;object-fit:cover}.upload-button{display:inline-flex;align-items:center;justify-content:center;width:auto;min-height:40px;border-radius:12px;padding:10px 14px;color:#30313a;background:#fff;box-shadow:inset 0 0 0 1px #24262f1a;cursor:pointer;font-size:14px;white-space:nowrap}.upload-button input{display:none}.form-error{color:#c33434;font-size:13px}.badge{display:inline-flex;margin-top:6px;padding:3px 8px;border-radius:999px;color:#1f725e;background:#1ba7841f;font-size:12px;font-weight:700;white-space:nowrap}.interaction-layout{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(300px,.75fr);gap:18px}.interaction-main,.wide{grid-column:span 1}.interaction-layout .wide{grid-column:1 / -1}.stacked-row,.rule-row,.three-col{display:grid;gap:10px;min-width:0;padding:12px 0;border-top:1px solid rgba(36,38,47,.08)}.three-col{grid-template-columns:repeat(4,minmax(0,1fr)) auto;align-items:start}.rule-row{grid-template-columns:190px minmax(0,1fr) minmax(0,1.4fr) auto;align-items:start}.preview-character{display:flex;gap:12px;align-items:center;margin:18px 0}.preview-character img{width:58px;height:58px;border-radius:18px}.affinity-label,.status-line{color:#626675;line-height:1.6}.floating-save{justify-self:start}.intro-panel h4,.future-card h4{margin:0 0 8px}.intro-panel p,.future-card p{margin:0;color:#626675}.sync-grid{grid-template-columns:minmax(0,1.1fr) minmax(340px,.8fr)}.backup-actions{display:grid}.hidden-input{display:none}.chat-experience{position:relative;width:100%;height:100vh;min-height:720px;display:grid;place-items:center;overflow:hidden;padding:32px;color:#fff}.chat-back{position:fixed;z-index:4;top:24px;left:24px;color:#ffffffeb;background:#ffffff1f;box-shadow:inset 0 0 0 1px #ffffff2e;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.chat-stage{width:min(1180px,calc(100vw - 64px));height:min(860px,calc(100vh - 64px));min-height:640px;display:grid;grid-template-rows:auto minmax(0,1fr) auto;overflow:hidden;border:1px solid rgba(255,255,255,.14);border-radius:30px;background:#ffffff1a;box-shadow:0 28px 90px #00000047;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.chat-hero{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px;background:#ffffff14}.chat-identity{display:flex;align-items:center;gap:14px;min-width:0}.chat-identity img,.chat-identity .avatar-placeholder{width:58px;height:58px;border-radius:20px}.chat-identity p{color:#ffffffb3}.chat-actions{display:flex;align-items:center;gap:10px;flex:0 0 auto}.chat-actions button,.chat-composer button{box-shadow:none}.affinity-pill{display:grid;grid-template-columns:auto auto;gap:2px 8px;align-items:center;padding:8px 12px;border-radius:16px;background:#ffffff1f}.affinity-pill small{grid-column:1 / -1;color:#ffffffa6;white-space:nowrap}.chat-conversation{display:grid;align-content:start;gap:12px;min-width:0;padding:22px;overflow-x:hidden;overflow-y:auto}.chat-empty{justify-self:center;margin-top:80px;color:#ffffffad}.message-row{display:flex;min-width:0}.message-row.user{justify-content:flex-end}.message-bubble{max-width:min(72%,720px);padding:12px 15px;border-radius:18px;line-height:1.65;color:#252733;background:#fff}.message-row.user .message-bubble{color:#fff;background:#2f6bff}.chat-composer{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;padding:16px;background:#ffffff14}.chat-composer input{border:0;background:#ffffffeb}.chat-chooser{width:min(760px,calc(100vw - 64px));padding:32px;border:1px solid rgba(255,255,255,.16);border-radius:28px;background:#ffffff1c;box-shadow:0 26px 80px #00000038;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.chat-chooser h2,.chat-chooser p{margin-top:0}.chat-choice-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-top:20px}.chat-choice-grid button{display:grid;gap:10px;justify-items:center;color:#fff;background:#ffffff1f;box-shadow:inset 0 0 0 1px #ffffff29}.chat-choice-grid strong,.chat-choice-grid small{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-choice-grid small{color:#ffffffb3;font-size:12px}.chat-choice-grid img{width:74px;height:74px;border-radius:24px}.tutorial-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:grid;place-items:center;padding:20px;overflow:hidden;background:#0c0e14b8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tutorial-spotlight{position:fixed;z-index:81;border-radius:18px;box-shadow:0 0 0 9999px #0c0e149e,0 0 0 4px #2f6bfff2;pointer-events:none;transition:all .25s ease}.tutorial-card{position:relative;z-index:82;width:min(440px,100%);padding:24px;border-radius:24px;background:#fff;box-shadow:0 26px 80px #00000042;animation:rise .28s ease}.tutorial-card h2{margin:16px 0 8px}.tutorial-card p{color:#626675;line-height:1.75;white-space:pre-line}.tutorial-progress{display:flex;align-items:center;justify-content:space-between;color:#737786;font-size:13px}.tutorial-progress div{display:flex;gap:5px}.tutorial-progress i{width:22px;height:4px;border-radius:999px;background:#e0e3ea}.tutorial-progress i.active{background:#2f6bff}.tutorial-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}@keyframes rise{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media(max-width:1279px)and (min-width:901px){.product-shell{grid-template-columns:72px minmax(0,1fr)}.sidebar{width:72px;min-width:72px;max-width:72px;padding:18px 10px;align-items:center}.brand{justify-content:center}.brand>div,.create-sidebar,.sidebar-note,.nav button{font-size:0}.nav button{justify-content:center;width:52px;padding:10px}.nav button span{flex-basis:auto;width:auto;font-size:18px}.home-page,.companions-page,.sync-page,.content>.empty-state{padding-inline:28px}.hero-panel{grid-template-columns:minmax(0,1fr) 260px}}@media(max-width:900px){.product-shell{display:block;height:auto;min-height:100vh;overflow:visible}.content{height:auto;min-height:100vh;overflow:visible}.menu-toggle{position:fixed;z-index:50;top:16px;left:16px;display:inline-flex;width:44px;height:44px;min-height:44px;padding:0}.sidebar{position:fixed;z-index:45;left:0;top:0;width:min(84vw,300px);min-width:0;max-width:300px;transform:translate(-105%);transition:transform .22s ease}.sidebar-open .sidebar{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:40;background:#10121857}.app-header{height:auto;min-height:72px;padding:16px 18px 16px 76px}.app-header .primary{display:none}.home-page,.companions-page,.sync-page,.content>.empty-state{padding:22px 18px 32px}.hero-panel,.quick-grid,.sync-grid,.interaction-layout,.three-col,.rule-row{grid-template-columns:1fr}.hero-panel{padding:26px}.hero-panel h2,.page-header h2,.workspace-title h2{font-size:clamp(28px,9vw,40px)}.hero-orbit{display:none}.section-heading,.page-header,.workspace-header,.chat-hero{flex-direction:column;align-items:flex-start}.workspace-header{display:grid;grid-template-columns:1fr;padding:18px}.workspace-title{align-items:flex-start}.workspace-tabs,.workspace-page>.page{padding-left:18px;padding-right:18px}.chat-experience{min-height:100vh;padding:0}.chat-stage{width:100%;height:100vh;min-height:100vh;border-radius:0}.chat-back{top:12px;left:12px}.chat-hero{display:flex;padding-top:64px}.chat-composer{grid-template-columns:1fr}}
