:root{--cream-50: #fffbf4;--cream-100: #fff4e4;--cream-200: #ffe8cc;--cream-300: #f9d8b3;--paper: #fffdf8;--paper-2: #fbf3e6;--peach: #ffb69a;--coral: #ff8f6b;--coral-deep: #ea6c45;--amber: #f5a524;--mint: #8fd7b8;--lilac: #c6b4ff;--sky: #a8d8ff;--rose: #ff9ab8;--ink: #3a2a20;--ink-strong: #241611;--ink-muted: #8c7362;--ink-faint: #bba695;--border: rgba(182, 136, 96, .16);--border-strong: rgba(182, 136, 96, .28);--shadow-xs: 0 1px 0 rgba(255, 255, 255, .95) inset, 0 1px 2px rgba(180, 120, 70, .08);--shadow-sm: 0 1px 0 rgba(255, 255, 255, .9) inset, 0 4px 10px -4px rgba(180, 120, 70, .18), 0 10px 18px -8px rgba(180, 120, 70, .1);--shadow-md: 0 1px 0 rgba(255, 255, 255, .85) inset, 0 8px 18px -8px rgba(180, 120, 70, .28), 0 24px 36px -18px rgba(180, 120, 70, .22);--shadow-lg: 0 1px 0 rgba(255, 255, 255, .9) inset, 0 14px 28px -10px rgba(180, 120, 70, .32), 0 40px 64px -30px rgba(180, 120, 70, .28);--shadow-inset: inset 0 2px 4px rgba(180, 120, 70, .14), inset 0 -1px 0 rgba(255, 255, 255, .6);--glow-coral: 0 0 0 4px rgba(255, 143, 107, .12), 0 12px 28px -6px rgba(255, 143, 107, .35);--r-xs: 8px;--r-sm: 14px;--r-md: 20px;--r-lg: 28px;--r-xl: 36px;--r-pill: 999px;--grad-sky: radial-gradient(120% 80% at 10% 10%, #ffe8cc 0%, transparent 60%), radial-gradient(100% 80% at 90% 5%, #ffd3c2 0%, transparent 55%), radial-gradient(120% 100% at 50% 120%, #ffe2d1 0%, transparent 65%), linear-gradient(180deg, #fff7eb 0%, #ffeeda 100%);--grad-coral: linear-gradient(135deg, #ffb69a 0%, #ff8f6b 60%, #ff7a58 100%);--grad-mint: linear-gradient(135deg, #b6ead2 0%, #8fd7b8 100%);--grad-lilac: linear-gradient(135deg, #dccfff 0%, #c6b4ff 100%);--grad-amber: linear-gradient(135deg, #ffdfa3 0%, #f5a524 100%);--grad-sky-b: linear-gradient(135deg, #d4ecff 0%, #a8d8ff 100%);--grad-rose: linear-gradient(135deg, #ffd1de 0%, #ff9ab8 100%);--font-sans: "SF Pro Text", "PingFang SC", "Noto Sans SC", "Helvetica Neue", system-ui, -apple-system, sans-serif;--font-display: "SF Pro Display", "PingFang SC", "Noto Sans SC", system-ui, sans-serif;--font-mono: "SF Mono", ui-monospace, "JetBrains Mono", monospace;--app-bg: radial-gradient(80% 60% at 10% 0%, #ffe4ce 0%, transparent 60%), radial-gradient(70% 50% at 90% 10%, #ffd6c2 0%, transparent 55%), radial-gradient(100% 80% at 50% 110%, #ffe8d4 0%, transparent 65%), linear-gradient(180deg, #fff8ee 0%, #fdebd4 60%, #ffe3c6 100%)}[data-calm=true] *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.06s!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%;overflow:hidden;background:var(--cream-100)}body{font-family:var(--font-sans);color:var(--ink);background:var(--app-bg);-webkit-font-smoothing:antialiased;letter-spacing:-.005em;overscroll-behavior:none}button{font-family:inherit;cursor:pointer}input,textarea{font-family:inherit}::selection{background:#ff8f6b40}*::-webkit-scrollbar{width:6px;height:6px}*::-webkit-scrollbar-thumb{background:#b688604d;border-radius:6px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-size:12px;font-weight:600;border-radius:var(--r-pill);border:1px solid var(--border);background:var(--paper);color:var(--ink-strong);box-shadow:var(--shadow-xs);transition:transform .12s ease,box-shadow .18s ease,filter .18s ease}.btn:active{transform:scale(.96)}.btn.primary{background:var(--grad-coral);color:#fff;border-color:transparent;box-shadow:var(--glow-coral)}.btn.primary:hover{filter:brightness(1.03)}.btn.ghost{background:transparent;box-shadow:none;border-color:#b6886059}.btn:disabled{opacity:.5;cursor:not-allowed}.tag{display:inline-flex;align-items:center;gap:4px;font-size:10px;padding:3px 8px;border-radius:var(--r-pill);background:#ff8f6b1f;color:var(--coral-deep);font-weight:600;white-space:nowrap}.tag.mint{background:#8fd7b840;color:#2f8f69}.tag.lilac{background:#c6b4ff4d;color:#6e58c9}.tag.amber{background:#f5a5242e;color:#b46e00}.tag.sky{background:#a8d8ff4d;color:#3975ad}.bubble{max-width:80%;padding:12px 14px;font-size:13px;line-height:1.5;border-radius:18px;box-shadow:var(--shadow-sm);position:relative;word-break:break-word}.bubble.ai{align-self:flex-start;background:var(--paper);border:1px solid var(--border);color:var(--ink-strong);border-bottom-left-radius:6px}.bubble.user{align-self:flex-end;background:var(--grad-coral);color:#fff;border-bottom-right-radius:6px;border:none}.bubble.card{max-width:96%;padding:0;overflow:hidden;background:var(--paper);border:1px solid var(--border);border-radius:20px}.bubble .md>*:first-child{margin-top:0}.bubble .md>*:last-child{margin-bottom:0}.bubble .md p{margin:0 0 .5em}.bubble .md ul,.bubble .md ol{margin:.3em 0;padding-left:1.2em}.bubble .md code{font-family:var(--font-mono);font-size:.86em;background:#b6886024;padding:1px 5px;border-radius:6px}.bubble.user .md code{background:#ffffff38}.bubble .md pre{background:#2416110f;padding:10px 12px;border-radius:12px;overflow-x:auto}.bubble .md a{color:var(--coral-deep)}.bubble .md h1,.bubble .md h2,.bubble .md h3{font-size:1.05em;margin:.4em 0 .3em}.mini-card{background:var(--paper);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-sm);padding:12px}.dots{display:inline-flex;gap:4px}.dots .d{width:6px;height:6px;border-radius:50%;background:var(--coral);animation:dotb 1.2s infinite}.dots .d:nth-child(2){background:var(--amber);animation-delay:.15s}.dots .d:nth-child(3){background:var(--mint);animation-delay:.3s}@keyframes dotb{0%,to{opacity:.4;transform:translateY(0)}50%{opacity:1;transform:translateY(-2px)}}.wave{display:flex;align-items:center;gap:3px;height:18px}.wave span{width:2.5px;height:100%;background:var(--coral);border-radius:3px;animation:wv 1.2s ease-in-out infinite;transform-origin:center}.wave span:nth-child(2){animation-delay:.1s}.wave span:nth-child(3){animation-delay:.2s}.wave span:nth-child(4){animation-delay:.3s}.wave span:nth-child(5){animation-delay:.15s}.wave span:nth-child(6){animation-delay:.25s}.wave span:nth-child(7){animation-delay:.05s}@keyframes wv{0%,to{transform:scaleY(.25)}50%{transform:scaleY(1)}}.ring{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;position:relative;background:conic-gradient(var(--coral) 0 72%,rgba(255,143,107,.15) 72% 100%)}.ring:before{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:50%;background:var(--paper)}.ring span{position:relative;font-size:11px;font-weight:700;color:var(--ink-strong)}.ava{width:36px;height:36px;border-radius:50%;display:grid;place-items:center;color:#fff;font-size:13px;font-weight:700;box-shadow:var(--shadow-xs),0 0 0 2px #ffffffb3;flex-shrink:0}@keyframes bubbleIn{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.anim-bubble-in{animation:bubbleIn .42s cubic-bezier(.2,.9,.3,1.2) both}.bg-pattern{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(35% 28% at 20% 18%,rgba(255,255,255,.8) 0%,transparent 70%),radial-gradient(30% 24% at 80% 12%,rgba(255,182,154,.55) 0%,transparent 70%),radial-gradient(40% 30% at 90% 85%,rgba(166,215,184,.35) 0%,transparent 70%),radial-gradient(35% 30% at 10% 75%,rgba(198,180,255,.35) 0%,transparent 70%);pointer-events:none;z-index:0}.scroll-hide{scrollbar-width:none}.scroll-hide::-webkit-scrollbar{display:none}html{-webkit-touch-callout:none}button,[role=button],.clawi,.companion,.cell,.dock,.chatbar,.chat-avatar,.app-tile,.widget,.cardwidget,.chip,.tag{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.chat-btn,.cell{touch-action:none}.bubble,.bubble .md,.voice-convo__bubble,input,textarea,[contenteditable=true]{-webkit-user-select:text;user-select:text;-webkit-touch-callout:default}html[data-hidden=true] *,html[data-hidden=true] *:before,html[data-hidden=true] *:after{animation-play-state:paused!important}html[data-hidden=true] .chatbar,html[data-hidden=true] .chat-panel,html[data-hidden=true] .voice-overlay,html[data-hidden=true] .voice-convo{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.08s!important}}.clawi{display:inline-block;position:relative;line-height:0;filter:drop-shadow(0 10px 12px rgba(180,120,70,.25));-webkit-tap-highlight-color:transparent}.clawi svg{display:block;overflow:visible}@keyframes clawi-float{0%,to{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-8px) rotate(2deg)}}.clawi--float{animation:clawi-float 5.5s ease-in-out infinite}@keyframes clawi-blink{0%,92%,to{transform:scaleY(1)}96%{transform:scaleY(.12)}}.clawi__eyes{transform-box:fill-box;transform-origin:center;animation:clawi-blink 4.8s ease-in-out infinite}.clawi--blink-fast .clawi__eyes{animation-duration:2.6s}.clawi--no-blink .clawi__eyes{animation:none}@keyframes clawi-squish{0%{transform:scale(1)}40%{transform:scale(1.12,.85)}70%{transform:scale(.94,1.08)}to{transform:scale(1)}}.clawi--squish{animation:clawi-squish .45s ease-out}@keyframes clawi-ear-l{0%,to{transform:rotate(0)}50%{transform:rotate(-10deg)}}@keyframes clawi-ear-r{0%,to{transform:rotate(0)}50%{transform:rotate(10deg)}}.clawi--curious .clawi__ear-l{transform-box:fill-box;transform-origin:bottom right;animation:clawi-ear-l 2.4s ease-in-out infinite}.clawi--curious .clawi__ear-r{transform-box:fill-box;transform-origin:bottom left;animation:clawi-ear-r 2.4s ease-in-out infinite}.clawi__zzz{font:700 14px var(--font-display, sans-serif);fill:var(--coral, #ff8f6b);opacity:0;animation:clawi-zzz 3s ease-in-out infinite}@keyframes clawi-zzz{0%{opacity:0;transform:translate(0) scale(.6)}40%{opacity:.9}to{opacity:0;transform:translate(6px,-16px) scale(1)}}.clawi__ripple{fill:none;stroke:var(--coral, #ff8f6b);stroke-width:2;opacity:0;animation:clawi-ripple 1.8s ease-out infinite}.clawi__ripple:nth-of-type(2){animation-delay:.6s}@keyframes clawi-ripple{0%{opacity:.5;transform:scale(.6);transform-origin:center;transform-box:fill-box}to{opacity:0;transform:scale(1.5);transform-origin:center;transform-box:fill-box}}.clawi-trail{position:absolute;width:10px;height:10px;border-radius:50%;background:#ff8f6b59;filter:blur(2px);pointer-events:none;animation:clawi-fade 2.5s ease-out infinite}@keyframes clawi-fade{0%{opacity:0;transform:scale(.4)}40%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(1.4) translateY(14px)}}.device-stage{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:stretch;background:var(--app-bg)}.device{position:relative;width:100%;height:100%;margin:0 auto;background:var(--grad-sky);overflow:hidden;isolation:isolate;--stage-max: 100%;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px);--safe-left: env(safe-area-inset-left, 0px);--safe-right: env(safe-area-inset-right, 0px);--stage-gutter: max(var(--safe-left), calc((100% - var(--stage-max)) / 2))}@media (min-width: 640px){.device{--stage-max: 600px}}@media (min-width: 1024px){.device{--stage-max: 720px}}@media (min-width: 1440px){.device{--stage-max: 800px}}.screen-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5}.gate{display:flex;flex-direction:column;align-items:center;gap:12px;padding:calc(52px + env(safe-area-inset-top,0)) 18px calc(40px + env(safe-area-inset-bottom,0));overflow-y:auto}.gate__title,.gate__card,.gate__foot{width:min(100%,440px)}.gate__pet{align-self:center;margin-top:8px}.gate__title{padding:0 4px;text-align:center}.gate__title h2{margin:0;font-family:var(--font-display);font-size:24px;font-weight:800;letter-spacing:-.02em;color:var(--ink-strong)}.gate__title p{margin:6px 0 0;font-size:13px;line-height:1.5;color:var(--ink-muted)}.gate__card{align-self:stretch;max-width:100%}.gate__card-head{display:flex;align-items:center;gap:8px;background:var(--grad-coral);color:#fff;padding:11px 14px;font-size:12px;font-weight:700}.gate__autofill{margin-left:auto;font-size:10px;font-weight:600;opacity:.85;background:#ffffff38;padding:2px 7px;border-radius:999px}.gate__tabs{display:flex;gap:6px;padding:12px 12px 0}.gate__tab{flex:1;border:1px solid var(--border);background:var(--cream-100);color:var(--ink-muted);font-size:12px;font-weight:600;padding:8px;border-radius:12px;transition:all .16s ease}.gate__tab.is-on{background:var(--paper);color:var(--coral-deep);border-color:var(--coral);box-shadow:var(--shadow-xs)}.gate__form{padding:12px;display:flex;flex-direction:column;gap:12px}.gate__field{display:flex;flex-direction:column;gap:5px}.gate__field-label{font-size:11px;font-weight:700;color:var(--ink-strong)}.gate__field input{border:1px solid var(--border);background:var(--cream-50);border-radius:12px;padding:10px 12px;font-size:13px;color:var(--ink-strong);outline:none;transition:border .16s ease,box-shadow .16s ease}.gate__field input:focus{border-color:var(--coral);box-shadow:0 0 0 3px #ff8f6b24}.gate__field-hint{font-size:10px;color:var(--ink-faint)}.gate__status{font-size:12px;padding:8px 12px;border-radius:10px;font-weight:500}.gate__status--busy{background:#f5a52426;color:#b46e00}.gate__status--ok{background:#8fd7b840;color:#2f8f69}.gate__status--err{background:#ff8f6b29;color:var(--coral-deep)}.gate__actions{padding:0 12px 14px;display:flex;flex-direction:column;gap:8px}.gate__actions .btn{width:100%;justify-content:center;padding:11px;font-size:13px}.gate__foot{text-align:center;font-size:10.5px;color:var(--ink-faint);line-height:1.5;padding:0 16px;margin:4px 0 0}.sheet-scrim{position:absolute;top:0;right:0;bottom:0;left:0;z-index:60;background:#3a2a202e;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.sheet{position:absolute;left:14px;right:14px;bottom:14px;bottom:calc(14px + env(safe-area-inset-bottom,0));z-index:61;background:#fffdf8f7;backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);border:1px solid rgba(255,255,255,.6);border-radius:26px;box-shadow:var(--shadow-lg);padding:16px;max-height:82%;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.sheet__title{font-size:15px;font-weight:800;color:var(--ink-strong);display:flex;align-items:center;justify-content:space-between;gap:8px}.sheet__close{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:var(--paper);color:var(--ink-muted);display:grid;place-items:center}.sheet__field{display:flex;flex-direction:column;gap:5px}.sheet__field>span{font-size:11px;color:var(--ink-muted);font-weight:600}.sheet__field input,.sheet__field textarea{border:1px solid var(--border);background:var(--cream-100);border-radius:12px;padding:9px 11px;font-size:13px;color:var(--ink-strong);outline:none;font-family:inherit}.sheet__field input:focus,.sheet__field textarea:focus{border-color:var(--coral)}.pick-row{display:flex;gap:8px;flex-wrap:wrap}.pick{border:1px solid var(--border);background:var(--paper);border-radius:12px;padding:7px 11px;font-size:12px;color:var(--ink-strong);display:flex;align-items:center;gap:6px}.pick.is-on{border-color:transparent;background:var(--grad-coral);color:#fff;box-shadow:var(--glow-coral)}.emoji-pick{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--paper);font-size:20px;display:grid;place-items:center}.emoji-pick.is-on{border-color:var(--coral);box-shadow:var(--glow-coral)}.mem-row{display:flex;gap:8px;align-items:flex-start;padding:9px 10px;background:var(--cream-100);border:1px solid var(--border);border-radius:12px}.mem-row__text{flex:1;font-size:12.5px;color:var(--ink-strong);line-height:1.45}.mem-row__meta{font-size:9px;color:var(--ink-faint);margin-top:2px}.companion-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:13;pointer-events:none}.companion{position:absolute;pointer-events:auto;display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;padding:0;animation:companion-bob 5s ease-in-out infinite}@keyframes companion-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}[data-calm=true] .companion{animation:none}.companion__ava{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;font-size:21px;box-shadow:var(--shadow-sm),0 0 0 2px #ffffffbf}.companion__ava.is-device{border-radius:14px}.companion__name{font-size:9px;color:var(--ink-strong);font-weight:600;background:#fffdf8d1;border-radius:7px;padding:1px 6px;white-space:nowrap;box-shadow:var(--shadow-xs)}.companion__dot{position:absolute;top:-1px;right:-1px;width:10px;height:10px;border-radius:50%;border:2px solid var(--paper)}.desktop{position:absolute;top:0;right:0;bottom:0;left:0;padding:calc(22px + var(--safe-top, 0px)) max(16px,var(--stage-gutter, 16px)) calc(124px + var(--safe-bottom, 0px));overflow-y:auto;z-index:5}.desktop__date{display:flex;flex-direction:column;gap:2px;padding:6px 6px 14px}.desktop__date .weekday{font-size:13px;color:var(--ink-muted);font-weight:500}.desktop__date .big{font-family:var(--font-display);font-size:30px;font-weight:700;color:var(--ink-strong);letter-spacing:-.02em;line-height:1.05}.desktop__date .hello{font-size:12px;color:var(--coral-deep);margin-top:4px}.grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:74px;gap:12px;touch-action:pan-y}@media (min-width: 560px){.grid{grid-template-columns:repeat(6,1fr);grid-auto-rows:80px}}@media (min-width: 1024px){.grid{grid-template-columns:repeat(8,1fr)}}.grid.is-editing{touch-action:none}.cell{position:relative;border-radius:var(--r-md);user-select:none;-webkit-user-select:none;-webkit-tap-highlight-color:transparent}.cell.size-1x1{grid-column:span 1;grid-row:span 1}.cell.size-2x1{grid-column:span 2;grid-row:span 1}.cell.size-2x2{grid-column:span 2;grid-row:span 2}.cell.size-4x1{grid-column:span 4;grid-row:span 1}.cell.size-4x2{grid-column:span 4;grid-row:span 2}.cell--dragging{z-index:30;pointer-events:none;transform:scale(1.06);filter:drop-shadow(0 18px 24px rgba(180,120,70,.35))}.is-editing .cell:not(.cell--dragging){animation:jiggle .32s ease-in-out infinite}@keyframes jiggle{0%,to{transform:rotate(-.8deg)}50%{transform:rotate(.8deg)}}.cell__remove{position:absolute;top:-6px;left:-6px;width:20px;height:20px;border-radius:50%;background:var(--ink-strong);color:#fff;border:2px solid var(--paper);display:grid;place-items:center;z-index:5;font-size:11px;padding:0}.widget{width:100%;height:100%;background:var(--paper);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);padding:12px;overflow:hidden;position:relative;display:flex;flex-direction:column}.widget__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.w-label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-faint);font-weight:600}.app-tile{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;background:transparent}.app-tile__icon{width:50px;height:50px;border-radius:16px;display:grid;place-items:center;color:#fff;font-size:23px;box-shadow:var(--shadow-md);position:relative;overflow:hidden}.app-tile__icon:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,rgba(255,255,255,.35) 0%,transparent 45%)}.app-tile__label{font-size:10px;color:var(--ink-strong);font-weight:500}.mini-time{font-size:21px;font-weight:700;color:var(--ink-strong);letter-spacing:-.01em}.mini-time small{font-weight:500;font-size:13px;color:var(--ink-muted)}.mini-todos{margin-top:8px;display:flex;flex-direction:column;gap:6px}.mini-todo{display:flex;gap:8px;align-items:center;font-size:11px;color:var(--ink-strong)}.mini-todo .box{width:14px;height:14px;border-radius:4px;border:1.5px solid var(--coral);display:grid;place-items:center;color:#fff;font-size:9px;flex-shrink:0}.mini-todo .box.on{background:var(--coral)}.mini-todo.done span{text-decoration:line-through;color:var(--ink-faint)}.mini-file{display:flex;gap:6px;align-items:center;font-size:11px}.mini-file .ic{width:22px;height:22px;border-radius:6px;display:grid;place-items:center;flex-shrink:0}.keeper{display:flex;align-items:center;gap:12px;height:100%}.keeper__avatar{width:54px;height:54px;border-radius:50%;background:var(--grad-coral);display:grid;place-items:center;box-shadow:var(--shadow-sm);flex-shrink:0}.keeper__role{font-size:11px;color:var(--ink-muted);font-weight:600}.keeper__ask{font-size:14px;font-weight:700;color:var(--ink-strong)}.cardwidget{width:100%;height:100%;background:var(--paper);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);padding:12px;overflow:hidden}.cardwidget__title{font-size:12px;font-weight:700;color:var(--ink-strong);margin-bottom:6px;display:flex;align-items:center;gap:6px}.grid-done{position:absolute;top:calc(16px + env(safe-area-inset-top,0));right:max(16px,var(--stage-gutter, 16px));z-index:40;border:none;background:var(--grad-coral);color:#fff;font-weight:700;font-size:13px;padding:8px 18px;border-radius:var(--r-pill);box-shadow:var(--glow-coral)}.pet-layer{position:absolute;top:0;right:0;bottom:0;left:0;z-index:14;pointer-events:none}.pet-roam{position:absolute;pointer-events:auto;transition:left 2.6s cubic-bezier(.22,1,.36,1),top 2.6s cubic-bezier(.22,1,.36,1);will-change:left,top}.webview{display:flex;flex-direction:column;background:#fffaf2}.webview__bar{display:flex;align-items:center;gap:10px;padding:54px 16px 10px;flex-shrink:0}.webview__bar .back{width:34px;height:34px;border-radius:50%;background:var(--paper);display:grid;place-items:center;box-shadow:var(--shadow-xs);color:var(--ink-strong);border:1px solid var(--border);flex-shrink:0}.webview__title{font-size:15px;font-weight:700;color:var(--ink-strong);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.webview__chip{font-size:9px;color:var(--ink-muted);background:var(--cream-100);border:1px solid var(--border);border-radius:999px;padding:3px 8px;flex-shrink:0}.webview__frame{flex:1;width:100%;border:none;background:#fffaf2}.webview__actions{display:flex;gap:8px;padding:10px 16px calc(110px + env(safe-area-inset-bottom,0));flex-shrink:0}.webview__actions .btn{flex:1;justify-content:center}.dock{position:absolute;left:0;right:0;margin-inline:auto;width:min(calc(100% - 28px),var(--stage-max, 100%));bottom:calc(18px + max(env(safe-area-inset-bottom,0px),var(--kb, 0px)));transition:bottom .22s ease;z-index:25}.dock--detail{bottom:calc(16px + max(env(safe-area-inset-bottom,0px),var(--kb, 0px)))}.chatbar{background:#fffdf8f0;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.6);border-radius:28px;padding:10px 12px;display:flex;align-items:center;gap:9px;box-shadow:0 1px #ffffffe6 inset,0 -1px #b4784614 inset,0 12px 28px -8px #b4784647,0 30px 50px -20px #b4784633}.chat-avatar{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow-sm),0 0 0 2px #ffffffb3;flex-shrink:0;position:relative;border:none;padding:0}.chat-avatar.sm{width:32px;height:32px}.chat-avatar:after{content:"";position:absolute;right:-1px;bottom:-1px;width:11px;height:11px;background:var(--mint);border:2px solid var(--paper);border-radius:50%}.chat-input-wrap{flex:1;min-width:0}.chat-input{width:100%;border:none;background:transparent;color:var(--ink-strong);font-size:13.5px;padding:6px 0;outline:none}.chat-input::placeholder{color:var(--ink-faint)}.chat-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--paper);display:grid;place-items:center;color:var(--ink-muted);box-shadow:var(--shadow-xs);flex-shrink:0;padding:0;transition:transform .12s ease}.chat-btn:active{transform:scale(.92)}.chat-btn.sm{width:32px;height:32px}.chat-btn.primary{background:var(--grad-coral);color:#fff;border-color:transparent;box-shadow:var(--glow-coral),var(--shadow-xs)}.chat-btn.recording{background:var(--grad-coral);color:#fff;transform:scale(1.12);box-shadow:var(--glow-coral)}.chat-scrim{position:absolute;top:0;right:0;bottom:0;left:0;z-index:24;background:#3a2a200a}.chat-panel{position:absolute;left:0;right:0;margin-inline:auto;width:min(calc(100% - 28px),var(--stage-max, 100%));bottom:calc(18px + max(env(safe-area-inset-bottom,0px),var(--kb, 0px)));transition:bottom .22s ease;z-index:26;background:#fffdf8f7;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.6);border-radius:28px;box-shadow:var(--shadow-lg);padding:14px 14px 12px;display:flex;flex-direction:column;max-height:76%}.chat-panel__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.chat-panel__id{display:flex;align-items:center;gap:8px}.chat-panel__name{font-size:13px;font-weight:700;color:var(--ink-strong)}.chat-panel__status{font-size:10px;color:var(--ink-muted)}.chat-panel__tools{display:flex;align-items:center;gap:8px}.session-bar{display:flex;gap:6px;overflow-x:auto;padding:0 2px 8px;margin-bottom:2px;border-bottom:1px solid var(--border)}.session-chip{display:inline-flex;align-items:center;flex-shrink:0;background:var(--cream-100);border:1px solid var(--border);border-radius:var(--r-pill);font-size:11px;font-weight:600;color:var(--ink-muted);overflow:hidden}.session-chip.is-on{background:var(--paper);border-color:var(--coral);color:var(--coral-deep);box-shadow:var(--shadow-xs)}.session-chip__pick{border:none;background:none;color:inherit;font:inherit;padding:6px 10px;max-width:140px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-chip__act{border:none;background:none;color:var(--ink-faint);padding:6px;font-size:11px}.session-chip__act:active{transform:scale(.9)}.session-chip.session-new{background:transparent;border-style:dashed;border-color:var(--border-strong);color:var(--ink-muted);padding:6px 10px}.chat-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding:2px 2px 8px;min-height:80px}.chat-empty{text-align:center;color:var(--ink-muted);font-size:12px;padding:14px 8px;display:flex;flex-direction:column;gap:12px;align-items:center}.chat-inline-bar{margin-top:10px;display:flex;align-items:center;gap:8px;padding:6px;background:var(--cream-100);border-radius:22px;border:1px solid var(--border)}.chat-hint{margin-top:6px;font-size:10px;color:var(--ink-faint);text-align:center}.attach-row{display:flex;gap:6px;flex-wrap:wrap;padding:0 2px 6px}.attach-chip{display:flex;align-items:center;gap:6px;font-size:11px;background:var(--cream-100);border:1px solid var(--border);border-radius:10px;padding:5px 8px;color:var(--ink-strong)}.attach-chip img{width:22px;height:22px;border-radius:5px;object-fit:cover}.msg-attach{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.msg-attach img{max-width:140px;border-radius:12px}.ai-selector{position:absolute;left:0;right:0;margin-inline:auto;width:min(calc(100% - 28px),var(--stage-max, 100%));bottom:calc(90px + env(safe-area-inset-bottom,0));z-index:27;display:flex;flex-direction:column;gap:12px}.ai-selector__hint{text-align:center;font-size:11px;color:var(--ink-muted)}.ai-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.ai-pick{text-align:center;background:transparent;border:none;padding:0}.ai-pick .ava{width:56px;height:56px;margin:0 auto;font-size:24px}.ai-pick.is-on .ava{box-shadow:var(--glow-coral)}.ai-pick__name{margin-top:6px;font-size:10px;font-weight:700;color:var(--ink-strong)}.ai-pick__role{font-size:9px;color:var(--ink-muted)}.ai-pick.is-on .ai-pick__role{color:var(--coral-deep)}.ai-new{display:flex;align-items:center;gap:12px}.ai-new__plus{width:40px;height:40px;border-radius:50%;background:var(--cream-100);border:2px dashed var(--border-strong);display:grid;place-items:center;color:var(--ink-muted);font-size:20px}.voice-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:70;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding-bottom:150px;background:#fff7eb8c;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}.voice-overlay__timer{font-family:var(--font-display);font-size:32px;font-weight:800;color:var(--ink-strong);letter-spacing:-.02em}.voice-overlay__hint{margin-top:8px;font-size:13px;color:var(--ink-muted)}.voice-overlay__hint.cancel{color:var(--coral-deep);font-weight:600}.voice-wave{margin-top:20px;display:flex;gap:4px;align-items:center;height:44px}.voice-wave span{width:3px;background:var(--coral);border-radius:2px;transition:height .08s ease}.voice-actions{margin-top:18px;display:flex;gap:22px;align-items:center}.voice-action{text-align:center}.voice-action__btn{width:48px;height:48px;border-radius:50%;background:var(--paper);border:1px solid var(--border);box-shadow:var(--shadow-sm);display:grid;place-items:center;color:var(--ink-muted);margin:0 auto}.voice-action__btn.big{width:70px;height:70px;background:var(--grad-coral);color:#fff;border:none;box-shadow:var(--glow-coral),var(--shadow-md)}.voice-action__btn.active{background:var(--coral);color:#fff}.voice-action__label{margin-top:4px;font-size:10px;color:var(--ink-muted)}.voice-convo{position:absolute;top:0;right:0;bottom:0;left:0;z-index:72;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:20px;background:radial-gradient(120% 80% at 50% 20%,#fff0e0f5,#fff7eeeb);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.voice-convo__close{position:absolute;top:16px;right:16px;display:flex;align-items:center;gap:5px;border:1px solid var(--border);background:var(--paper);color:var(--ink-muted);border-radius:16px;padding:6px 12px;font-size:12px;box-shadow:var(--shadow-xs)}.voice-convo__pet{filter:drop-shadow(0 14px 26px rgba(180,120,70,.28));transition:transform .3s ease}.voice-convo__pet--thinking{transform:scale(.96)}.voice-convo__pet--speaking{animation:convo-talk .5s ease-in-out infinite alternate}@keyframes convo-talk{0%{transform:translateY(0) scale(1)}to{transform:translateY(-3px) scale(1.03)}}.voice-convo__state{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--ink-strong)}.voice-convo__sub{font-size:11px;color:var(--ink-muted)}.voice-convo__wave{margin-top:4px}.voice-convo__bubble{max-width:80%;font-size:13px;line-height:1.5;border-radius:16px;padding:9px 13px;position:relative}.voice-convo__bubble--user{background:var(--grad-coral);color:#fff;align-self:flex-end}.voice-convo__bubble--ai{background:var(--paper);color:var(--ink-strong);border:1px solid var(--border);align-self:flex-start}.voice-convo__tag{display:block;font-size:9px;opacity:.7;margin-bottom:2px;letter-spacing:.04em}.camera-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:74;background:#1a1310;display:flex;flex-direction:column}.camera-overlay__frame{flex:1;display:grid;place-items:center;overflow:hidden}.camera-overlay__video{width:100%;height:100%;object-fit:cover}.camera-overlay__error{color:#fff;font-size:14px;opacity:.85}.camera-overlay__bar{display:flex;align-items:center;justify-content:space-around;padding:18px 24px calc(24px + env(safe-area-inset-bottom,0));background:#00000059}.camera-overlay__shutter{width:64px;height:64px;border-radius:50%;background:#fff;border:4px solid rgba(255,255,255,.45);box-shadow:0 0 0 2px #ffffff40}.camera-overlay__shutter:active{transform:scale(.92)}.camera-overlay__shutter:disabled{opacity:.4}#root{height:100dvh}.toast-layer{position:absolute;left:0;right:0;bottom:110px;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:80;pointer-events:none;padding:0 20px}.toast{background:#241611e6;color:#fff8ee;font-size:12px;font-weight:500;padding:9px 16px;border-radius:var(--r-pill);box-shadow:var(--shadow-md);max-width:86%;text-align:center}.section-label{font-size:11px;font-weight:700;color:var(--ink-strong);text-transform:uppercase;letter-spacing:.08em}.muted-note{text-align:center;font-size:11px;color:var(--ink-muted)}.chips{display:flex;flex-wrap:wrap;gap:6px}.chip{border:none;background:#ff8f6b1f;color:var(--coral-deep);font-weight:600;font-size:11px;padding:5px 11px;border-radius:var(--r-pill);transition:transform .12s ease,background .18s ease}.chip:active{transform:scale(.94)}.chip.mint{background:#8fd7b840;color:#2f8f69}.chip.lilac{background:#c6b4ff4d;color:#6e58c9}.detail-header{position:absolute;top:0;left:0;right:0;padding:calc(16px + env(safe-area-inset-top,0)) max(18px,var(--stage-gutter, 18px)) 10px;display:flex;align-items:center;gap:10px;z-index:10}.detail-header .back{width:34px;height:34px;border-radius:50%;background:var(--paper);display:grid;place-items:center;box-shadow:var(--shadow-xs);color:var(--ink-strong);border:1px solid var(--border);flex-shrink:0}.detail-header .back:active{transform:scale(.92)}.detail-header h3{margin:0;font-size:17px;font-weight:700;color:var(--ink-strong);letter-spacing:-.01em}.detail-header .sub{font-size:11px;color:var(--ink-muted)}.detail-header .spacer{flex:1}.detail-body{position:absolute;inset:calc(96px + env(safe-area-inset-top,0)) 0 calc(96px + env(safe-area-inset-bottom,0)) 0;padding:4px max(16px,var(--stage-gutter, 16px)) 24px;z-index:5;overflow-y:auto}.stack{display:flex;flex-direction:column;gap:8px}
