*{box-sizing:border-box;margin:0;padding:0}:root{--serif: "Noto Serif SC", serif;--sans: "Noto Sans SC", -apple-system, system-ui, sans-serif;--hand: "Long Cang", "Noto Serif SC", cursive;--brand: "Cormorant Garamond", "Noto Serif SC", serif;--accent: #e8c07d;--radius: 22px;--bubble-gap: 7px}html,body{height:100%}body{font-family:var(--sans);background:#15121d;-webkit-font-smoothing:antialiased}body.app-light{background:#fdf9f4}.app{position:relative;width:100%;max-width:480px;height:100dvh;margin:0 auto;overflow:hidden;box-shadow:0 0 120px -30px #0009;background:var(--bg-grad)}.stage{position:relative;width:100%;height:100%;overflow:hidden}.theme-dark{--bg-grad: radial-gradient(120% 80% at 75% -10%, #2c2350 0%, transparent 60%), radial-gradient(120% 90% at 10% 108%, #2a1d34 0%, transparent 58%), linear-gradient(180deg, #1a1430 0%, #181228 100%);--accent: #e8c07d;--surface: rgba(255, 255, 255, .045);--surface-2: rgba(255, 255, 255, .075);--surface-solid: #251d3c;--border: rgba(232, 192, 125, .16);--border-soft: rgba(245, 240, 232, .1);--pink: #e89b8b;--pink-2: #f2b5a0;--text: #f5f0e8;--text-dim: rgba(245, 240, 232, .64);--text-faint: rgba(245, 240, 232, .4);--luna-bubble: linear-gradient(165deg, rgba(255, 247, 236, .1), rgba(232, 155, 139, .1));--luna-bubble-border: rgba(245, 240, 232, .14);--user-bubble: linear-gradient(165deg, rgba(232, 192, 125, .22), rgba(232, 192, 125, .12));--user-bubble-border: rgba(232, 192, 125, .3);--glow-a: radial-gradient(closest-side, rgba(232, 192, 125, .22), transparent);--glow-b: radial-gradient(closest-side, rgba(232, 155, 139, .2), transparent);--statusbar: #f5f0e8;--shadow: 0 24px 60px -20px rgba(0, 0, 0, .6);color-scheme:dark}.theme-light{--bg-grad: radial-gradient(120% 80% at 80% -12%, #fae3e0 0%, transparent 58%), radial-gradient(120% 90% at 8% 110%, #ece2f3 0%, transparent 55%), linear-gradient(180deg, #fdf9f4 0%, #fbf3ec 100%);--accent: #d9c867;--surface: #ffffff;--surface-2: #fbf3ec;--surface-solid: #ffffff;--border: rgba(217, 168, 108, .26);--border-soft: rgba(90, 74, 66, .1);--pink: #e8a9a9;--pink-2: #f3c9c9;--text: #5a4a42;--text-dim: rgba(90, 74, 66, .68);--text-faint: rgba(90, 74, 66, .42);--luna-bubble: #ffffff;--luna-bubble-border: rgba(90, 74, 66, .1);--user-bubble: linear-gradient(165deg, #f7d3d3, #f3c9c9);--user-bubble-border: rgba(232, 169, 169, .5);--glow-a: radial-gradient(closest-side, rgba(243, 201, 201, .55), transparent);--glow-b: radial-gradient(closest-side, rgba(205, 184, 224, .45), transparent);--statusbar: #5a4a42;--shadow: 0 24px 60px -22px rgba(150, 110, 90, .35);color-scheme:light}.ws-reconnect{position:absolute;top:0;left:0;right:0;z-index:50;text-align:center;padding:7px 12px;font-size:12px;background:var(--surface-solid);color:var(--text-dim);border-bottom:1px solid var(--border-soft);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.screen-bg{position:absolute;inset:0;background:var(--bg-grad);color:var(--text);font-family:var(--sans)}.glow{position:absolute;pointer-events:none;border-radius:50%}.scrollbody{position:absolute;inset:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.scrollbody::-webkit-scrollbar{width:0}.topgap{height:18px}.nav{position:absolute;bottom:0;left:0;right:0;z-index:30;display:flex;justify-content:space-around;align-items:center;padding:10px 6px 24px;background:linear-gradient(180deg,transparent,var(--bg-1, var(--surface-solid)) 60%);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.nav:before{content:"";position:absolute;inset:0;background:var(--bg-grad);opacity:.85;z-index:-1}.nav-brand{display:none}.nav button{background:none;border:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;color:var(--text-faint);font-family:var(--sans);font-size:10px;transition:color .2s;padding:4px 7px}.nav button.on{color:var(--accent)}.nav button svg{width:22px;height:22px}.app[data-page=chat] .nav{display:none}@media(min-width:900px){body{display:grid;place-items:center}.app{width:min(1040px,100vw);max-width:none;display:flex;flex-direction:row;box-shadow:0 0 120px -40px #00000080}.stage{order:2;flex:1;min-width:0;border-left:1px solid var(--border-soft)}.nav{position:static;order:1;z-index:auto;flex-shrink:0;width:232px;padding:24px 16px;gap:4px;flex-direction:column;justify-content:flex-start;align-items:stretch;background:var(--surface);-webkit-backdrop-filter:none;backdrop-filter:none}.nav:before{display:none}.nav-brand{display:block;font-family:var(--brand);font-size:22px;letter-spacing:.04em;color:var(--text);padding:6px 14px 24px}.nav button{flex-direction:row;justify-content:flex-start;gap:14px;font-size:14.5px;padding:12px 14px;border-radius:14px;transition:all .18s}.nav button svg{width:20px;height:20px}.nav button.on{color:var(--accent);background:var(--surface-2)}.app[data-page=chat] .nav{display:flex}.scrollbody{scrollbar-width:thin;scrollbar-color:var(--border) transparent}.scrollbody::-webkit-scrollbar{width:8px}.scrollbody::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.scrollbody::-webkit-scrollbar-thumb:hover{background:var(--accent)}}.luna-orb{border-radius:50%;position:relative;flex-shrink:0;background:radial-gradient(circle at 34% 30%,#fff7ec 0%,var(--pink-2) 30%,var(--pink) 58%,#b98a9a 100%);box-shadow:0 0 30px -4px #e89b8b8c,inset 0 0 18px #ffffff4d}.theme-dark .luna-orb{box-shadow:0 0 36px -2px #e89b8b80,0 0 0 6px #e8c07d0f}.luna-orb.breathing{animation:breathe 5.5s ease-in-out infinite}@keyframes breathe{0%,to{transform:scale(1)}50%{transform:scale(1.045)}}.pill-chip{font-family:var(--sans);font-size:13px;cursor:pointer;padding:9px 16px;border-radius:999px;transition:border-color .18s ease;background:var(--surface);border:1px solid var(--border-soft);color:var(--text)}.pill-chip:hover{border-color:var(--accent)}.pill-chip.sel{background:var(--user-bubble);border-color:var(--user-bubble-border);color:var(--text)}.theme-dark .pill-chip.sel{color:#fff7ec}.btn-primary{font-family:var(--sans);font-size:15px;font-weight:500;cursor:pointer;padding:14px 26px;border-radius:999px;border:0;color:#2a1f12;background:linear-gradient(165deg,#f3dcae,var(--accent));box-shadow:0 10px 28px -8px #e8c07d80;transition:transform .15s}.theme-light .btn-primary{color:#4a3d2a;background:linear-gradient(165deg,#ecdca0,#d9c867);box-shadow:0 10px 28px -10px #d9c8678c}.btn-primary:hover{transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:default;transform:none}.btn-ghost{font-family:var(--sans);font-size:14px;cursor:pointer;color:var(--text-dim);padding:13px 24px;border-radius:999px;background:transparent;border:1px solid var(--border-soft);transition:all .18s}.btn-ghost:hover{color:var(--text);border-color:var(--accent)}.card{background:var(--surface);border:1px solid var(--border-soft);border-radius:var(--radius);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.theme-light .card{box-shadow:0 8px 24px -16px #966e5a66}.eyebrow{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);font-weight:600;font-family:var(--sans)}.hand{font-family:var(--hand)}.chat-thread{display:flex;flex-direction:column;gap:var(--bubble-gap);min-width:0}.msg-row{display:flex;max-width:100%}.msg-row.luna{justify-content:flex-start}.msg-row.user{justify-content:flex-end}.bubble{max-width:78%;padding:12px 16px;border-radius:20px;font-size:15px;line-height:1.62;white-space:pre-wrap;position:relative;animation:rise-in .5s cubic-bezier(.2,.8,.2,1)}.fade-rise{animation:rise-in .55s cubic-bezier(.2,.8,.2,1)}@keyframes rise-in{0%{transform:translateY(11px);opacity:0}to{transform:none;opacity:1}}.bubble.luna{background:var(--luna-bubble);border:1px solid var(--luna-bubble-border);color:var(--text);border-bottom-left-radius:7px}.theme-dark .bubble.luna{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.theme-light .bubble.luna{box-shadow:0 6px 18px -12px #966e5a73}.bubble.user{background:var(--user-bubble);border:1px solid var(--user-bubble-border);color:var(--text);border-bottom-right-radius:7px}.theme-dark .bubble.user{color:#fff7ec}.bubble.serif{font-family:var(--serif);font-size:15.5px;line-height:1.75}.typing{display:inline-flex;align-items:center;gap:5px;padding:13px 16px;border-radius:20px 20px 20px 7px;background:var(--luna-bubble);border:1px solid var(--luna-bubble-border);animation:rise-in .35s ease}.typing i{width:7px;height:7px;border-radius:50%;background:var(--text-dim);animation:tdot 1.3s infinite ease-in-out}.typing i:nth-child(2){animation-delay:.18s}.typing i:nth-child(3){animation-delay:.36s}@keyframes tdot{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-4px);opacity:1}}.typing-label{font-size:11px;color:var(--text-faint);margin:2px 0 2px 6px;font-family:var(--sans)}.save-insight{display:inline-flex;align-items:center;gap:5px;margin-top:5px;margin-left:4px;font-size:11.5px;color:var(--text-faint);cursor:pointer;font-family:var(--sans);background:none;border:0;transition:color .2s}.save-insight:hover,.save-insight.saved{color:var(--accent)}.composer{position:absolute;bottom:0;left:0;right:0;display:flex;flex-direction:column;gap:8px;padding:10px 16px calc(10px + env(safe-area-inset-bottom));background:var(--surface-solid);border-top:1px solid var(--border-soft)}.composer-row{display:flex;align-items:center;gap:10px}.ritual-chips{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.ritual-chip{font-family:var(--sans);font-size:12.5px;cursor:pointer;padding:6px 14px;border-radius:999px;color:var(--accent);background:transparent;border:1px solid var(--border);display:inline-flex;align-items:center;gap:6px;transition:all .18s}.ritual-chip:hover:not(:disabled){background:var(--surface-2);border-color:var(--accent)}.ritual-chip:disabled{opacity:.45;cursor:default}.ritual-chip em{font-style:normal;font-size:11px;color:var(--text-faint)}.ritual-notice{font-size:12px;color:var(--text-dim);padding:0 2px}.composer .field{flex:1;min-height:42px;border-radius:21px;padding:11px 16px;background:var(--surface-2);border:1px solid var(--border-soft);color:var(--text);font-size:14px;font-family:var(--sans);outline:none}.composer .field::placeholder{color:var(--text-faint)}.composer .send{width:42px;height:42px;border-radius:50%;border:0;cursor:pointer;flex-shrink:0;background:linear-gradient(165deg,#f3dcae,var(--accent));display:grid;place-items:center;color:#2a1f12}.theme-light .composer .send{background:linear-gradient(165deg,#ecdca0,#d9c867);color:#4a3d2a}.toast{position:absolute;bottom:90px;left:50%;transform:translate(-50%);background:var(--surface-solid);color:var(--text);border:1px solid var(--border);padding:10px 18px;border-radius:999px;font-size:13px;z-index:60;box-shadow:var(--shadow);animation:toast-rise .3s ease;white-space:nowrap}@keyframes toast-rise{0%{transform:translate(-50%,9px)}to{transform:translate(-50%)}}.mem-field{display:flex;flex-direction:column;gap:5px}.mem-field .k{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-faint)}.mem-field .v{font-size:15px;color:var(--text);font-family:var(--serif)}.mem-input{font-family:var(--sans);font-size:14px;color:var(--text);background:var(--surface-2);border:1px solid var(--border-soft);border-radius:12px;padding:9px 12px;outline:none;width:100%}.mem-input:focus{border-color:var(--accent)}.row{display:flex;align-items:center}.col{display:flex;flex-direction:column}.wrap{flex-wrap:wrap}
