@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=Manrope:wght@400;500;600&family=JetBrains+Mono:wght@400;500&family=Noto+Serif+SC:wght@400;500;600&family=Noto+Sans+SC:wght@400;500&display=swap";.boot-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:var(--bg-page);color:var(--ink-2);text-align:center}.boot-title{font-family:var(--f-display);font-size:28px;line-height:1.1;color:var(--ink-2)}.boot-subtitle{margin-top:10px;font-family:var(--f-mono);font-size:12px;letter-spacing:.16em;color:var(--ink-3);text-transform:uppercase}.boot-loading{margin-top:18px;font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;color:var(--ink-4);text-transform:uppercase;animation:boot-loading-pulse 2.4s ease-in-out infinite}@keyframes boot-loading-pulse{0%,to{opacity:.28}50%{opacity:.9}}.auth-screen{position:relative;min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg-page);overflow:hidden}.auth-screen:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 12% 5%,color-mix(in oklab,var(--accent-1) 22%,transparent),transparent 55%),radial-gradient(ellipse at 88% 95%,color-mix(in oklab,var(--accent-2) 18%,transparent),transparent 50%);pointer-events:none;opacity:.9}.auth-screen .theme-toggle{position:absolute;top:18px;right:18px;z-index:2}.auth-panel{position:relative;z-index:1;width:min(380px,100%);padding:36px 28px 30px;display:flex;flex-direction:column;align-items:center;text-align:center;color:var(--ink-2)}.auth-logo{width:100px;height:100px;margin-bottom:12px;object-fit:contain}.auth-eyebrow{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--accent-1-deep);text-transform:uppercase;margin:0 0 6px}.theme-dark .auth-eyebrow{color:var(--accent-1)}.auth-panel h1{font-family:var(--f-display);font-weight:500;font-size:44px;line-height:1;margin:0;color:var(--ink-1);letter-spacing:-.01em}.auth-panel .auth-ornament{margin:12px 0 6px;font-size:12px}.auth-panel .auth-en{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--ink-3);text-transform:uppercase;margin:0}.auth-panel .auth-lede{color:var(--ink-3);font-size:13px;margin:22px 0 0;line-height:1.6;max-width:260px}.auth-actions{width:100%;display:grid;gap:12px;margin-top:26px}.auth-google-button{position:relative;min-height:46px;display:flex;align-items:center;justify-content:center;text-align:center}.auth-google-button:before{content:"这里如果没有google登录按钮显示 请用浏览器打开";position:absolute;inset:0;z-index:0;display:grid;place-items:center;padding:0 16px;color:var(--ink-3);font-size:12px;line-height:1.35;pointer-events:none}.auth-google-button>div{position:relative;z-index:1;width:100%!important}.auth-footnote{margin:14px 0 0;display:grid;gap:6px;font-family:var(--f-mono);font-size:9px;letter-spacing:.22em;color:var(--ink-4);text-transform:uppercase}.auth-footnote a{color:var(--accent-2);text-decoration:underline;text-underline-offset:2px}.auth-error{margin-top:14px;color:var(--wax);font-size:13px}.notice{color:var(--ink-3);font-size:12px;margin:0}.profile-setup-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:var(--bg-page);color:var(--ink-2)}.profile-setup-panel{width:min(390px,100%);display:grid;gap:14px;padding:28px;border:1px solid color-mix(in oklab,var(--ink-4) 28%,transparent);border-radius:8px;background:color-mix(in oklab,var(--paper-1) 88%,transparent);box-shadow:0 24px 70px color-mix(in oklab,#000 18%,transparent)}.profile-setup-panel h1{margin:0;font-family:var(--f-display);font-size:34px;font-weight:500;color:var(--ink-1)}.profile-setup-copy{margin:0;color:var(--ink-3);font-size:13px}.profile-setup-form{display:grid;gap:14px}.avatar-row{display:flex;align-items:end;gap:16px}.avatar-picker{width:112px;height:112px;flex:0 0 112px;display:grid;place-items:center;overflow:hidden;border:1px dashed color-mix(in oklab,var(--ink-3) 45%,transparent);border-radius:50%;color:var(--ink-3);background:color-mix(in oklab,var(--paper-2) 65%,transparent)}.avatar-picker img{width:100%;height:100%;object-fit:cover}.avatar-picker .avatar-initial{font-family:var(--f-display);font-size:48px;line-height:1;color:var(--ink-1)}.avatar-picker input{display:none}.avatar-actions{min-width:0;display:flex;flex-wrap:wrap;align-items:center;gap:8px}.compact-button{min-height:38px;padding:0 14px;font-size:12px}.profile-name-field{min-width:0;flex:1;display:grid;gap:6px}.profile-name-field span{font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}.profile-name-field input{min-height:46px;padding:0 12px;border:1px solid color-mix(in oklab,var(--ink-4) 38%,transparent);border-radius:8px;background:var(--paper-1);color:var(--ink-1);outline:none}.app-shell{position:relative;min-height:100vh;padding:18px 16px 96px;background:var(--bg-page);color:var(--ink-2)}.app-shell:before{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;background:radial-gradient(ellipse at 18% 0%,color-mix(in oklab,var(--accent-1) 14%,transparent),transparent 50%),radial-gradient(ellipse at 82% 100%,color-mix(in oklab,var(--accent-2) 12%,transparent),transparent 55%);opacity:.7}.app-shell>*{position:relative;z-index:1}.topbar{max-width:1120px;margin:0 auto 18px;display:flex;align-items:center;justify-content:space-between;gap:16px}.topbar-left{min-width:0;display:inline-flex;align-items:center;gap:10px;border:0;padding:0;background:transparent;color:inherit;text-align:left}.topbar-avatar{width:42px;height:42px;flex:0 0 42px;display:grid;place-items:center;overflow:hidden;border:1px solid var(--ink-5);border-radius:50%;color:var(--bg-page);font-family:var(--f-display);font-size:20px;line-height:1}.topbar-avatar img{width:100%;height:100%;object-fit:cover}.topbar-avatar .avatar-initial{font:inherit;color:inherit;letter-spacing:0}.topbar-avatar.tone-olive{background:var(--accent-1-deep)}.topbar-avatar.tone-sage{background:var(--accent-1)}.topbar-avatar.tone-caramel{background:var(--accent-2-deep)}.topbar-avatar.tone-wax{background:var(--wax)}.topbar-avatar.tone-rose{background:#a86a3a}.topbar-title{min-width:0;display:grid;gap:2px}.topbar .eyebrow{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--ink-3);text-transform:uppercase;margin:0}.topbar-name{margin:0;font-family:var(--f-display);font-weight:500;font-size:24px;line-height:1.05;color:var(--ink-1);max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content-shell .profile-setup-screen{min-height:calc(100vh - 156px);padding:0;background:transparent}.topbar-right{display:flex;align-items:center;gap:8px}.theme-toggle{min-height:38px;display:inline-flex;align-items:center;gap:8px;padding:0 14px;border-radius:999px;border:1px solid var(--ink-5);background:var(--pill-bg);color:var(--ink-2);font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase}.theme-toggle:hover{border-color:var(--ink-4)}.icon-button{width:38px;height:38px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid var(--ink-5);background:var(--pill-bg);color:var(--ink-2)}.icon-button.wide{width:auto;height:46px;padding:0 14px;gap:8px;border-radius:12px;background:transparent;color:var(--ink-2)}.content-shell{max-width:1440px;margin:0 auto}.mobile-pane{position:relative;width:min(520px,100%);min-height:calc(100vh - 160px);margin:0 auto;padding:28px 24px;border:1px solid var(--ink-5);border-radius:12px;background:linear-gradient(180deg,var(--bg-surface) 0%,var(--bg-page) 100%);color:var(--ink-2);box-shadow:var(--shadow-card);overflow:hidden}.mobile-pane>*{position:relative;z-index:1}.pane-heading{margin-bottom:18px}.pane-heading h2{margin:4px 0 0;font-family:var(--f-display);font-weight:500;font-size:28px;line-height:1.1;color:var(--ink-1)}.eyebrow{font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--ink-3);text-transform:uppercase;margin:0}.muted,.notice,.status-text{color:var(--ink-3)}.error-text{color:var(--wax)}.stack-form,.envelope-form{display:grid;gap:14px}.envelope-form{padding:18px;border:1px dashed var(--ink-5);border-radius:12px;background:var(--opt-bg)}textarea,input,select{width:100%;border:1px solid var(--ink-5);border-radius:10px;background:var(--bg-page);color:var(--ink-1);outline:none;padding:12px 14px;font-family:var(--f-body);transition:border-color .15s ease}textarea:focus,select:focus,input[type=text]:focus{border-color:var(--accent-1-deep)}.theme-dark textarea:focus,.theme-dark select:focus{border-color:var(--accent-1)}textarea{min-height:180px;resize:vertical;font-family:var(--f-display);font-size:17px;line-height:1.5}.blessing-submit-button:disabled{opacity:1;background:var(--accent-1-deep);color:var(--bg-page)}.theme-dark .blessing-submit-button:disabled{background:var(--accent-1);color:var(--bg-page)}select,input{min-height:46px}label>span{display:inline-block;margin-bottom:6px;color:var(--ink-3);font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase}.toggle-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.switch-field{position:relative;min-height:48px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px 14px;border:1px solid var(--ink-5);border-radius:12px;background:var(--opt-bg);color:var(--ink-2)}.switch-field>span:first-child{margin:0;font-family:var(--f-body);font-size:13px;letter-spacing:0;text-transform:none;color:var(--ink-1)}.switch-field input{position:absolute;opacity:0;pointer-events:none}.switch-track{width:38px;height:22px;padding:2px;border-radius:999px;background:var(--ink-5);transition:background .16s ease}.switch-thumb{display:block;width:18px;height:18px;border-radius:50%;background:var(--bg-card);transition:transform .16s ease}.switch-field input:checked+.switch-track{background:var(--accent-1-deep)}.theme-dark .switch-field input:checked+.switch-track{background:var(--accent-1)}.switch-field input:checked+.switch-track .switch-thumb{transform:translate(16px)}.primary-button,.secondary-button,.apple-button{min-height:48px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:999px;border:1px solid transparent;font-family:var(--f-body);font-size:14px;font-weight:500;letter-spacing:.02em;transition:opacity .12s ease,transform .12s ease}.primary-button{background:var(--ink-1);color:var(--bg-page)}.primary-button:active,.secondary-button:active{transform:scale(.985)}.primary-button:disabled{cursor:not-allowed;opacity:.4}.secondary-button{background:transparent;color:var(--ink-2);border-color:var(--ink-5)}.secondary-button:disabled{cursor:not-allowed;opacity:.45}.apple-button{background:#050505;color:#fff;border:1px solid rgba(255,255,255,.16)}@keyframes drift2{0%{transform:translate(0) rotate(var(--r, 0deg))}50%{transform:translate(var(--dx, 8px),var(--dy, -12px)) rotate(var(--r, 0deg))}to{transform:translate(0) rotate(var(--r, 0deg))}}.floating-words{position:absolute;inset:0;pointer-events:none;overflow:hidden;opacity:.22}.floating-words span{position:absolute;font-family:var(--f-display);color:var(--ink-2);white-space:nowrap;animation:drift2 var(--dur, 14s) ease-in-out infinite}.polaroid-frame{position:relative;width:min(280px,100%);margin:0 auto;padding:12px 12px 36px;background:#faf2dd;color:#2c1c0d;border-radius:3px;box-shadow:0 18px 30px -10px #0000008c,0 4px 8px #0000004d;transform:rotate(-1.5deg)}.polaroid-frame:before{content:"";position:absolute;top:-10px;left:50%;transform:translate(-50%) rotate(-3deg);width:70px;height:18px;background:color-mix(in oklab,var(--accent-2) 50%,transparent)}.polaroid-frame .upload-dropzone{border-radius:1px}.polaroid-caption{position:absolute;bottom:8px;left:0;right:0;text-align:center;font-family:var(--f-display);font-size:14px;color:#2c1c0d}.upload-dropzone{position:relative;width:100%;aspect-ratio:1;display:grid;place-items:center;overflow:hidden;border:1px dashed rgba(60,40,20,.3);background:var(--accent-2-deep);color:#ffedc8d9;font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer}.upload-dropzone:hover{border-color:#3c281480}.upload-dropzone input,.file-button input{display:none}.upload-dropzone img{width:100%;height:100%;object-fit:cover}.photo-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-top:16px}.photo-strip img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px}.photo-roll{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;margin-top:18px}.photo-roll-tile{position:relative;margin:0;border-radius:6px;overflow:hidden;background:var(--opt-bg)}.photo-roll-tile img{width:100%;aspect-ratio:1;object-fit:cover}.photo-roll-tile figcaption{position:absolute;left:0;right:0;bottom:0;padding:4px 8px;background:linear-gradient(180deg,transparent,rgba(0,0,0,.6));color:#faf2dd;font-size:11px;line-height:1.2}.photo-roll-delete{position:absolute;top:6px;right:6px;width:26px;height:26px;display:grid;place-items:center;border-radius:999px;border:0;background:#0000008c;color:#faf2dd;opacity:0;transition:opacity .12s ease}.photo-roll-anon-toggle{position:absolute;top:6px;left:6px;width:26px;height:26px;display:grid;place-items:center;border-radius:999px;border:0;background:#faf2dde0;color:#2c1c0d;opacity:0;transition:opacity .12s ease,background .12s ease}.photo-roll-anon-toggle.is-anonymous{background:#0009;color:#faf2dd}.photo-roll-tile:hover .photo-roll-delete,.photo-roll-tile:focus-within .photo-roll-delete,.photo-roll-tile:hover .photo-roll-anon-toggle,.photo-roll-tile:focus-within .photo-roll-anon-toggle{opacity:1}.capsule-pane{background:linear-gradient(180deg,var(--bg-card) 0%,var(--bg-card-2) 100%)}.theme-dark .capsule-pane{background:linear-gradient(180deg,var(--bg-surface) 0%,var(--bg-page) 100%)}.capsule-corner{display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--ink-4);text-transform:uppercase;margin-bottom:10px}.capsule-question-pills{margin-bottom:14px;width:100%}.capsule-question-pills,.capsule-reply-pills{display:flex;width:100%}.capsule-question-pills .t-pill,.capsule-reply-pills .t-pill{flex:1 1 0;min-width:0}.sealed-note{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:10px;background:color-mix(in oklab,var(--wax) 14%,transparent);color:var(--wax);font-size:13px}.delivery-stamp{margin:8px 0 0;font-size:9px;color:var(--ink-3);letter-spacing:.2em}.wax-warn{margin:0;text-align:center;font-size:9px;letter-spacing:.18em;color:var(--wax)}.recorder{display:grid;gap:12px;padding:18px 16px;border:1px solid var(--ink-5);border-radius:12px;background:var(--bg-surface)}.recorder-header{display:grid;gap:4px}.recorder-prompt{margin:0;font-size:22px;line-height:1.2;color:var(--ink-1)}.recorder-stage{display:grid;gap:12px;justify-items:center}.tape-reel{position:relative;width:110px;height:110px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--bg-card-2) 0%,var(--bg-page) 90%);border:1px solid var(--ink-4);box-shadow:inset 0 0 14px #0000002e;display:grid;place-items:center}.tape-reel-spin{position:absolute;inset:0;border-radius:50%}@keyframes reel-spin{to{transform:rotate(360deg)}}.tape-reel-spin.spinning{animation:reel-spin 1.6s linear infinite}.tape-spoke{position:absolute;top:50%;left:50%;width:1px;height:40px;background:var(--ink-4);opacity:.4;transform-origin:top center}.tape-hub{position:relative;z-index:1;width:26px;height:26px;border-radius:50%;background:radial-gradient(circle at 35% 30%,var(--accent-2-deep),var(--wax));box-shadow:inset 0 -2px 4px #0006}.waveform{width:100%;display:flex;align-items:center;gap:3px;height:36px;padding:0 6px}.waveform .bar{flex:1;min-height:4px;background:var(--ink-5);border-radius:1px;transition:height .08s linear}.waveform .bar.live{background:var(--accent-1-deep)}.theme-dark .waveform .bar.live{background:var(--accent-1)}.recorder-meta{width:100%;display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;color:var(--ink-3)}.recorder-meta .elapsed{color:var(--ink-2)}.recorder-meta .elapsed.rec{color:var(--wax)}.recorder-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.rec-toggle{background:color-mix(in oklab,var(--wax) 16%,transparent);border:1px solid var(--wax);color:var(--ink-1)}.recorder-playback{width:100%;border-radius:999px;background:var(--bg-page)}.photo-slot{display:flex;align-items:center;gap:8px;padding:10px 12px;border:1px dashed var(--ink-5);border-radius:10px;color:var(--ink-3);font-size:12px;cursor:pointer}.photo-slot input{display:none}.recorder-existing{margin:0;text-align:center;font-size:9px;color:var(--ink-3)}.capsule-sealed{display:grid;gap:14px;padding:18px 16px;border:1px solid var(--ink-5);border-radius:12px;background:var(--bg-surface)}.envelope{position:relative;width:100%;aspect-ratio:5 / 3.2;max-width:320px;margin:0 auto;background:linear-gradient(180deg,var(--bg-card) 0%,var(--bg-card-2) 100%);border-radius:4px;box-shadow:var(--shadow-card)}.envelope-flap{position:absolute;inset:0;clip-path:polygon(0 0,100% 0,50% 60%);background:linear-gradient(180deg,var(--bg-card) 0%,var(--bg-card-2) 100%);filter:brightness(.95);border-radius:4px 4px 0 0}.envelope-stamp{position:absolute;top:12px;right:12px;width:56px;padding:6px 4px;background:var(--bg-page);border:1px dashed var(--accent-2-deep);font-family:var(--f-mono);font-size:8px;letter-spacing:.1em;color:var(--wax);text-align:center;text-transform:uppercase;display:grid;gap:2px}.envelope-to{position:absolute;left:18px;right:18px;bottom:16px;font-family:var(--f-display);font-size:14px;color:var(--ink-2);display:flex;flex-direction:column}.envelope-seal{position:absolute;left:50%;top:56%;width:56px;height:56px;transform:translate(-50%,-50%);font-size:20px}.capsule-sealed-note{margin:0;padding:12px 14px;border-radius:10px;background:var(--opt-bg);font-family:var(--f-display);font-size:16px;color:var(--ink-1);line-height:1.45}.bottom-nav{position:fixed;right:12px;bottom:12px;left:12px;z-index:10;max-width:520px;margin:0 auto;display:grid;grid-template-columns:repeat(5,1fr);gap:4px;padding:8px;border:1px solid var(--ink-5);border-radius:14px;background:color-mix(in oklab,var(--bg-page) 85%,transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 12px 32px #00000040}.bottom-nav button{min-height:48px;display:grid;place-items:center;gap:2px;border:0;border-radius:8px;background:transparent;color:var(--ink-3);font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase}.bottom-nav button.active{background:color-mix(in oklab,var(--accent-1) 22%,transparent);color:var(--ink-1)}.bottom-nav button span{font-family:var(--f-body);font-size:11px;letter-spacing:0;text-transform:none;color:inherit}.landing-pane{position:relative;width:min(520px,100%);margin:0 auto;padding:24px 22px 32px;border:1px solid var(--ink-5);border-radius:12px;background:linear-gradient(180deg,var(--bg-surface) 0%,var(--bg-page) 100%);overflow:hidden}.landing-pane>*{position:relative;z-index:1}.landing-corner{display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;color:var(--ink-4);text-transform:uppercase;padding-bottom:12px}.landing-intro{margin-bottom:22px}.landing-title{margin:8px 0 0;font-size:32px;line-height:1.05}.landing-title .accent-1-deep{color:var(--accent-1-deep)}.theme-dark .landing-title .accent-1-deep{color:var(--accent-1)}.landing-subtitle{margin:8px 0 0;font-family:var(--f-display);font-size:21px;line-height:1.16;color:var(--accent-1-deep)}.theme-dark .landing-subtitle{color:var(--accent-1)}.landing-sub{margin:8px 0 0;font-size:13px;color:var(--ink-3)}.landing-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.landing-tile{position:relative;overflow:hidden;text-align:left;border:1px solid color-mix(in oklab,var(--ink-5) 50%,transparent);border-radius:12px;padding:50px 14px 14px;min-height:144px;display:flex;flex-direction:column;gap:10px;cursor:pointer;color:var(--tile-accent);transition:transform .12s ease,border-color .12s ease}.landing-tile:before{content:"";position:absolute;inset:-6px;z-index:0;background-image:var(--tile-image);background-position:center;background-size:cover;filter:blur(.6px);transform:scale(1.02)}.landing-tile:after{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(180deg,#0003,#000000ad)}.landing-tile>*{position:relative;z-index:1}.theme-light .landing-tile{border-color:#3c281429}.landing-tile:hover{transform:translateY(-1px);border-color:var(--ink-4)}.landing-tile-body{margin-top:auto;text-shadow:0 1px 8px rgba(0,0,0,.35)}.landing-tile-zh{font-family:var(--f-display);font-weight:500;font-size:22px;line-height:1.1;color:currentColor}.landing-tile-en{margin-top:4px;font-family:var(--f-mono);font-size:8px;letter-spacing:.22em;color:color-mix(in oklab,currentColor 82%,#fff 18%);text-transform:uppercase}.landing-tile-sub{margin:8px 0 0;font-size:11px;color:color-mix(in oklab,currentColor 78%,#fff 22%);line-height:1.35}.landing-tile-status{display:flex;align-items:center;gap:6px;font-family:var(--f-mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;text-shadow:0 1px 8px rgba(0,0,0,.35)}.landing-tile-status .dot{width:6px;height:6px;border-radius:50%}.landing-footer{margin:18px 0 0;font-size:9px;letter-spacing:.22em;color:var(--ink-4);text-align:center}.quiz-pane{position:relative;width:min(520px,100%);margin:0 auto;padding:24px 22px 28px;border:1px solid var(--ink-5);border-radius:12px;background:linear-gradient(180deg,var(--bg-surface) 0%,var(--bg-page) 100%);overflow:hidden}.quiz-pane>*{position:relative;z-index:1}.quiz-progress{display:flex;gap:4px;height:2px;margin:8px 0 18px}.quiz-progress-tick{flex:1;background:var(--ink-5);opacity:.5;border-radius:999px}.quiz-progress-tick.on{background:var(--accent-1-deep);opacity:1}.theme-dark .quiz-progress-tick.on{background:var(--accent-1)}.quiz-body{display:flex;flex-direction:column;gap:14px}.quiz-lead{margin:6px 0 0;font-size:13px;color:var(--ink-3);line-height:1.55}.quiz-prompt{margin:4px 0 0;font-size:24px;line-height:1.25;white-space:pre-line}.quiz-subtitle{margin:-6px 0 0;font-family:var(--f-mono);font-size:10px;letter-spacing:.18em;color:var(--ink-3);text-transform:uppercase}.quiz-options{display:flex;flex-direction:column;gap:8px}.quiz-option{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;border:1px solid var(--ink-5);background:transparent;color:var(--ink-2);text-align:left;transition:border-color .15s ease,background .15s ease}.quiz-option:hover{border-color:var(--ink-4)}.quiz-option.on{border-color:var(--accent-1-deep);background:color-mix(in oklab,var(--accent-1) 16%,transparent)}.theme-dark .quiz-option.on{border-color:var(--accent-1)}.quiz-option-tag{width:28px;height:28px;display:grid;place-items:center;border-radius:50%;border:1px solid var(--ink-4);font-family:var(--f-display);font-size:12px;color:var(--ink-3);flex-shrink:0}.quiz-option-tag.on{border-color:var(--accent-1-deep);color:var(--accent-1-deep);background:var(--bg-page)}.theme-dark .quiz-option-tag.on{border-color:var(--accent-1);color:var(--accent-1)}.quiz-option-body{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.quiz-option-label{font-family:var(--f-display);font-size:16px;color:var(--ink-1);line-height:1.2}.quiz-option-check{color:var(--accent-1-deep);flex-shrink:0}.theme-dark .quiz-option-check{color:var(--accent-1)}.quiz-actions{display:flex;gap:10px;margin-top:4px}.quiz-actions .t-btn{flex:1}.quiz-actions.result-actions{display:grid;gap:10px}.result-action-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.result-action-full{width:100%}.quiz-next{flex:1.5!important}.quiz-result-card{padding:18px 20px;border-radius:10px}.quiz-result-card p{margin:0;font-family:var(--f-display);font-size:17px;line-height:1.5;color:var(--ink-1)}.spirit-card{position:relative;padding:28px 24px 24px;border-radius:10px;background:linear-gradient(160deg,var(--spirit-from),var(--spirit-to));color:var(--spirit-ink);box-shadow:0 24px 40px -16px #0000008c,0 8px 16px #00000040;text-align:center;overflow:hidden}.spirit-card-grain{position:absolute;inset:0;pointer-events:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.88  0 0 0 0 0.72  0 0 0 .14 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.6'/></svg>");mix-blend-mode:overlay;opacity:.35}.spirit-card-stamp{position:absolute;top:12px;left:14px;font-family:var(--f-display);font-size:14px;letter-spacing:.32em;color:var(--spirit-ink);opacity:.75}.spirit-image{width:min(460px,98%);height:clamp(240px,31svh,380px);min-height:25svh;margin:8px auto 14px;display:block;object-fit:contain;object-position:center;filter:drop-shadow(0 34px 28px rgba(0,0,0,.26))}.spirit-image.trait-whale{object-fit:cover;object-position:top center;border-radius:8px}.spirit-name{font-family:var(--f-display);font-weight:500;font-size:28px;line-height:1.12;letter-spacing:-.01em}.spirit-sub{margin-top:6px;font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;opacity:.8;text-transform:uppercase}.spirit-line{width:36px;height:1px;margin:18px auto 12px;background:currentColor;opacity:.45}.spirit-quote{margin:0 0 10px;font-family:var(--f-display);font-size:20px;line-height:1.35;color:var(--spirit-ink)}.spirit-body{margin:0;font-family:var(--f-display);font-size:13px;line-height:1.55;color:var(--spirit-ink);opacity:.95;white-space:pre-line}.spirit-short-label{margin:14px 0 4px;font-family:var(--f-display);font-size:15px;line-height:1.4;opacity:.78}.spirit-blessing,.spirit-quote{margin:0;font-family:var(--f-display);font-size:20px;font-weight:700;line-height:1.45;font-style:normal}.spirit-stamp-bottom{margin-top:18px;font-family:var(--f-mono);font-size:9px;letter-spacing:.22em;opacity:.7;text-transform:uppercase}.patronus-share-stage{position:fixed;top:0;left:-99999px;width:1080px;height:1920px;pointer-events:none}.patronus-share-card{position:relative;width:1080px;height:1920px;padding:96px 92px 92px;display:grid;grid-template-rows:auto 720px 1fr auto;overflow:hidden;background:radial-gradient(circle at 50% 31%,rgba(255,255,255,.38),transparent 32%),linear-gradient(160deg,var(--share-from),var(--share-to));color:var(--share-ink);font-family:var(--f-body)}.patronus-share-card>*{position:relative;z-index:1}.patronus-share-grain{position:absolute;inset:0;z-index:0;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence baseFrequency='0.72' numOctaves='3' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.9  0 0 0 0 0.78  0 0 0 .18 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.62'/></svg>");mix-blend-mode:overlay;opacity:.55}.patronus-share-header{display:flex;justify-content:space-between;align-items:start;gap:56px;font-family:var(--f-mono);font-size:18px;letter-spacing:.14em;line-height:1.35;text-transform:uppercase;opacity:.74}.patronus-share-header>div{display:grid;gap:8px}.patronus-share-footer{display:flex;align-items:end;justify-content:space-between;gap:48px}.patronus-share-footer>div:first-child{display:grid;gap:12px;font-family:var(--f-mono);font-size:18px;letter-spacing:.18em;line-height:1.35;text-transform:uppercase;opacity:.78}.patronus-share-image{width:820px;height:720px;margin:48px auto 0;display:block;object-fit:contain;object-position:center;filter:drop-shadow(0 34px 28px rgba(0,0,0,.26))}.patronus-share-content{align-self:center;text-align:center}.patronus-share-title{margin:0 0 12px;font-family:var(--f-mono);font-size:20px;letter-spacing:.16em;text-transform:uppercase;opacity:.78}.patronus-share-owner{margin:0 0 28px;font-family:var(--f-display);font-size:36px;line-height:1.2;opacity:.86}.patronus-share-user{display:inline-block;font-size:46px;font-weight:700}.patronus-share-subtitle{margin:28px 0 0;font-family:var(--f-display);font-size:42px;line-height:1.18}.patronus-share-content h2{margin:28px 0;font-family:var(--f-display);font-size:100px;font-weight:500;line-height:.92}.patronus-share-body{width:min(760px,100%);margin:30px auto 0;font-family:var(--f-display);font-size:34px;line-height:1.34;white-space:pre-line}.patronus-share-short-label,.patronus-share-blessing{width:min(760px,100%);margin:36px auto 0;font-family:var(--f-display);font-size:42px;line-height:1.38;opacity:.86}.patronus-share-quote{width:min(760px,100%);margin:18px auto 0;font-family:var(--f-display);font-size:26px;line-height:1.28;white-space:pre-line}.patronus-share-blessing{width:min(760px,100%);margin:18px auto 0;font-family:var(--f-display);font-size:34px;line-height:1.28}.patronus-share-qr{width:220px;display:grid;gap:12px;justify-items:center;font-family:var(--f-mono);font-size:13px;letter-spacing:.08em;line-height:1.25;text-align:center;opacity:.86}.patronus-share-qr-code{width:158px;height:158px;display:block;object-fit:contain;padding:8px;border-radius:10px;background:#fff}.dashboard-pane{position:relative;padding:26px 28px 36px;border:1px solid var(--ink-5);border-radius:14px;background:linear-gradient(180deg,var(--bg-surface) 0%,var(--bg-page) 100%);overflow:hidden}.dashboard-pane:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse at 12% 5%,color-mix(in oklab,var(--accent-1) 18%,transparent),transparent 55%),radial-gradient(ellipse at 88% 95%,color-mix(in oklab,var(--accent-2) 14%,transparent),transparent 50%);opacity:.7}.dashboard-pane>*{position:relative;z-index:1}.dashboard-header{display:flex;flex-wrap:wrap;gap:18px;align-items:flex-end;justify-content:space-between;padding-bottom:14px}.dashboard-title h2{margin:4px 0 0;font-family:var(--f-display);font-weight:500;font-size:44px;line-height:1;color:var(--ink-1);letter-spacing:-.01em}.dashboard-title h2 .dot{color:var(--accent-1-deep)}.theme-dark .dashboard-title h2 .dot{color:var(--accent-1)}.dashboard-title .t-eyebrow{color:var(--accent-1-deep)}.theme-dark .dashboard-title .t-eyebrow{color:var(--accent-1)}.dashboard-en{margin:6px 0 0;font-family:var(--f-mono);font-size:10px;letter-spacing:.22em;color:var(--ink-3);text-transform:uppercase}.stats-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:20px}.stat-pill{text-align:right}.stat-pill .stat-n{font-family:var(--f-display);font-weight:500;font-size:30px;line-height:1;color:var(--ink-1)}.stat-pill.olive .stat-n{color:var(--accent-1-deep)}.theme-dark .stat-pill.olive .stat-n{color:var(--accent-1)}.stat-pill .stat-label{margin-top:4px;font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;color:var(--ink-3);text-transform:uppercase}.stamp{border:1.5px dashed var(--ink-5);padding:6px 10px;font-family:var(--f-mono);font-size:9px;letter-spacing:.2em;color:var(--ink-2);text-transform:uppercase}.wall-meta{font-family:var(--f-mono);font-size:9px;letter-spacing:.18em;color:var(--ink-4);text-transform:uppercase;padding:4px 0 12px}.wall-canvas{position:relative;isolation:isolate;min-height:680px;margin-top:18px;padding:24px 4px 8px}.wall-twine{position:absolute;z-index:1;top:28px;left:12px;right:12px;height:1px;background:color-mix(in oklab,var(--accent-1) 45%,transparent);opacity:.4}.wall-grid{position:relative;z-index:1;width:100%}.wall-grid>.wall-item{position:absolute;left:var(--wall-x);top:var(--wall-y);opacity:1;transform:translate(-2%) rotate(var(--rotation));transform-origin:center}.wall-grid.wall-grid-entering>.wall-item{animation:wall-item-fade-in .5s ease forwards}.wall-grid.wall-grid-exiting>.wall-item{animation:wall-item-fade-out .5s ease forwards}@keyframes wall-item-fade-in{0%{opacity:0;transform:translate(-2%) rotate(var(--rotation)) scale(.96)}to{opacity:1;transform:translate(-2%) rotate(var(--rotation)) scale(1)}}@keyframes wall-item-fade-out{0%{opacity:1;transform:translate(-2%) rotate(var(--rotation)) scale(1)}to{opacity:0;transform:translate(-2%) rotate(var(--rotation)) scale(.98)}}.wall-grid>.wall-item.scrap{width:fit-content;max-width:min(var(--item-w),calc(100% - 24px))}.wall-grid>.wall-item.scrap-message{width:min(var(--item-w),calc(100% - 24px))}.scrap{position:relative;background:#faf2dd;color:#2c1c0d;padding:12px 12px 14px;border-radius:3px;box-shadow:0 14px 26px -8px #00000073,0 4px 8px #00000040}.scrap-tape{position:absolute;top:-8px;left:50%;transform:translate(-50%) rotate(-3deg);width:56px;height:18px;background:color-mix(in oklab,var(--accent-1) 45%,transparent)}.scrap-photo{display:block;width:auto;height:auto;max-width:100%;max-height:var(--photo-max-h, 300px);object-fit:contain;margin:0 auto;border-radius:1px}.scrap-photo.placeholder{display:grid;place-items:center;width:min(var(--item-w),calc(100vw - 96px));max-width:100%;aspect-ratio:4 / 3;background:repeating-linear-gradient(135deg,rgba(255,237,200,.15) 0 6px,transparent 6px 12px),linear-gradient(135deg,var(--accent-2-deep),var(--accent-1-deep));color:#ffedc8b3;font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;text-align:center;padding:14px}.scrap-caption{width:min(var(--item-w),calc(100vw - 96px));max-width:100%;margin:10px 4px 0;padding-right:44px;text-align:center;font-family:var(--f-display);font-size:14px;line-height:1.2;color:#2c1c0d}.scrap-author-avatar{position:absolute;right:12px;bottom:10px;width:38px;height:38px;display:grid;place-items:center;border:2px solid #faf2dd;border-radius:50%;background:#a3b07a;color:#2c1c0d;box-shadow:0 7px 12px #00000047;overflow:hidden}.scrap-author-avatar img,.scrap-author-avatar .avatar-initial{width:100%;height:100%;display:grid;place-items:center;object-fit:cover;font-family:var(--f-display);font-size:18px}.scrap-message{position:relative;padding:18px 20px 16px;border-radius:4px;background:linear-gradient(180deg,#faf2dd,#ecdfbf);color:#2c1c0d;box-shadow:0 14px 26px -8px #00000073,0 4px 8px #00000040;display:flex;flex-direction:column;gap:8px}.scrap-message.sage{background:linear-gradient(180deg,#d6dcbe,#a3b07a)}.scrap-message.caramel{background:linear-gradient(180deg,#efcfae,#c08550)}.scrap-message.olive-fill{background:#4a5530;color:#faf2dd}.scrap-message.terra-fill{background:#8a4a2a;color:#faf2dd}.scrap-message-meta{display:flex;justify-content:space-between;font-family:var(--f-mono);font-size:8px;letter-spacing:.22em;text-transform:uppercase;color:#00000080}.scrap-message.olive-fill .scrap-message-meta,.scrap-message.terra-fill .scrap-message-meta{color:#ffffff8c}.scrap-message-body{font-family:var(--f-display);font-size:var(--message-size, 18px);line-height:1.4}.scrap-message-from{align-self:flex-end;font-family:var(--f-display);font-size:14px;opacity:.85}.wall-thanks{position:absolute;inset:0;z-index:0;display:flex;align-items:center;justify-content:center;gap:6px;pointer-events:none;text-align:center;font-family:var(--f-display);font-size:clamp(30px,5vw,72px);color:var(--accent-1-deep);opacity:.18}.wall-thanks-logo{display:inline-block;width:100px;height:100px;object-fit:contain}.theme-dark .wall-thanks{color:var(--accent-1)}@media(min-width:760px){.app-shell{padding-bottom:36px}.bottom-nav{top:18px;right:max(18px,calc((100vw - 1120px)/2));bottom:auto;left:auto;width:380px}.topbar{padding-right:396px}.mobile-pane,.landing-pane,.quiz-pane{min-height:auto}}@media(max-width:759px){.dashboard-pane{padding:18px}.dashboard-header{flex-direction:column;align-items:flex-start}.stats-row{align-self:stretch;justify-content:flex-start}.dashboard-title h2{font-size:36px}.wall-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:24px 14px;min-height:auto!important}.wall-grid>.wall-item{position:relative;left:auto;top:auto;transform:rotate(var(--rotation))}.wall-grid>.wall-item.scrap,.wall-grid>.wall-item.scrap-message{width:min(var(--item-w),100%)}.scrap-photo,.scrap-photo.placeholder,.scrap-caption{width:100%;max-width:100%}}:root{--f-display: "Cormorant Garamond", "Noto Serif SC", "Songti SC", serif;--f-body: "Manrope", "Noto Sans SC", "PingFang SC", -apple-system, sans-serif;--f-mono: "JetBrains Mono", ui-monospace, monospace}:root,.theme-dark{--bg-page: #1c130c;--bg-surface: #271810;--bg-card: #34221a;--bg-card-2: #3e2a1f;--ink-1: #faf2dd;--ink-2: #ecddb9;--ink-3: #b3a17a;--ink-4: #7a6b4c;--ink-5: #4a3225;--accent-1: #a3b07a;--accent-1-deep: #6b7a45;--accent-1-light: #c0caa0;--accent-2: #d8a47a;--accent-2-deep: #b07440;--accent-2-light: #ebc4a0;--wax: #b14633;--paper-grain-opacity: .35;--paper-grain-blend: overlay;--shadow-card: 0 1px 0 rgba(255, 255, 255, .06) inset, 0 -1px 0 rgba(0, 0, 0, .15) inset, 0 18px 30px -10px rgba(0, 0, 0, .6), 0 4px 8px rgba(0, 0, 0, .4);--shadow-tile: 0 1px 0 rgba(255, 255, 255, .04) inset, 0 6px 16px rgba(0, 0, 0, .4);--tile-overlay: rgba(255, 255, 255, .025);--opt-bg: rgba(255, 255, 255, .02);--pill-bg: rgba(255, 255, 255, .03);color-scheme:dark}.theme-light{--bg-page: #ede1c4;--bg-surface: #f0e5cb;--bg-card: #faf2dd;--bg-card-2: #ecddb9;--ink-1: #2c1c0d;--ink-2: #4a3220;--ink-3: #7a5e3d;--ink-4: #a8946d;--ink-5: #c9b88a;--accent-1: #6b7a45;--accent-1-deep: #4a5530;--accent-1-light: #a3b07a;--accent-2: #c08550;--accent-2-deep: #8a4a2a;--accent-2-light: #d8a47a;--wax: #8a3a22;--paper-grain-opacity: .55;--paper-grain-blend: multiply;--shadow-card: 0 1px 0 rgba(255, 255, 255, .4) inset, 0 -1px 0 rgba(0, 0, 0, .05) inset, 0 14px 24px -8px rgba(0, 0, 0, .18), 0 4px 8px rgba(0, 0, 0, .1);--shadow-tile: 0 1px 0 rgba(255, 255, 255, .45) inset, 0 4px 10px rgba(60, 40, 20, .15);--tile-overlay: rgba(255, 255, 255, .4);--opt-bg: rgba(0, 0, 0, .015);--pill-bg: rgba(0, 0, 0, .04);color-scheme:light}.t-eyebrow{font-family:var(--f-mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3)}.t-eyebrow.olive{color:var(--accent-1-deep)}.theme-dark .t-eyebrow.olive{color:var(--accent-1)}.t-display{font-family:var(--f-display);font-weight:500;font-style:normal;line-height:1.25;letter-spacing:-.01em;color:var(--ink-1)}.t-mono{font-family:var(--f-mono);letter-spacing:.18em;text-transform:uppercase}.t-paper{background:linear-gradient(180deg,var(--bg-card) 0%,var(--bg-card-2) 100%);color:var(--ink-2);border-radius:4px;box-shadow:var(--shadow-card)}.t-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--f-body);font-size:13px;font-weight:500;letter-spacing:.02em;border-radius:999px;padding:14px 22px;border:1px solid transparent;cursor:pointer;transition:transform .12s ease,opacity .12s ease;color:var(--ink-2);background:transparent}.t-btn:active{transform:scale(.985)}.t-btn:disabled{cursor:not-allowed;opacity:.4}.t-btn-primary{background:var(--ink-1);color:var(--bg-page)}.t-btn-olive{background:var(--accent-1-deep);color:var(--bg-page)}.theme-dark .t-btn-olive{background:var(--accent-1);color:var(--bg-page)}.t-btn-caramel{background:var(--accent-2-deep);color:var(--bg-page)}.theme-dark .t-btn-caramel{background:var(--accent-2);color:var(--bg-page)}.t-btn-ghost{background:transparent;color:var(--ink-2);border:1px solid var(--ink-5)}.t-opt{display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--ink-5);border-radius:12px;background:var(--opt-bg);cursor:pointer;transition:border-color .15s ease,background .15s ease}.t-opt:hover{border-color:var(--ink-4)}.t-opt.on{border-color:var(--accent-1-deep);background:color-mix(in oklab,var(--accent-1) 14%,transparent)}.theme-dark .t-opt.on{border-color:var(--accent-1)}.t-box{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--ink-4);flex-shrink:0;display:grid;place-items:center}.t-opt.on .t-box{border-color:var(--accent-1-deep);background:var(--accent-1-deep)}.theme-dark .t-opt.on .t-box{border-color:var(--accent-1);background:var(--accent-1)}.t-opt.on .t-box:after{content:"";width:10px;height:5px;border-left:2px solid var(--bg-page);border-bottom:2px solid var(--bg-page);transform:rotate(-45deg) translate(1px,-1px)}.t-pill-row{display:inline-flex;gap:4px;padding:3px;background:var(--pill-bg);border-radius:999px;border:1px solid var(--ink-5);flex-wrap:wrap}.t-pill{font-family:var(--f-body);font-size:12px;padding:6px 14px;border-radius:999px;color:var(--ink-3);cursor:pointer;letter-spacing:.02em;border:0;background:transparent}.t-pill.on{background:var(--accent-1-deep);color:var(--bg-page)}.theme-dark .t-pill.on{background:var(--accent-1);color:var(--bg-page)}.t-dotline{height:1px;background-image:radial-gradient(circle,var(--ink-4) .6px,transparent .6px);background-size:6px 1px;opacity:.55}.t-orn{display:inline-flex;align-items:center;gap:10px;color:var(--accent-2-deep);font-family:var(--f-display)}.theme-dark .t-orn{color:var(--accent-2)}.t-orn:before,.t-orn:after{content:"";width:28px;height:1px;background:currentColor;opacity:.5}.t-noise:before{content:"";position:absolute;inset:0;pointer-events:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0.95  0 0 0 0 0.88  0 0 0 0 0.72  0 0 0 .14 0'/></filter><rect width='100%' height='100%' filter='url(%23n)' opacity='.6'/></svg>");mix-blend-mode:var(--paper-grain-blend);opacity:var(--paper-grain-opacity)}.seal{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;font-family:var(--f-display);font-size:22px;color:#ffe1c8eb;box-shadow:inset 0 -3px 6px #00000073,inset 0 2px 4px #ffc8b44d,0 4px 10px #00000073}.theme-light .seal{background:radial-gradient(circle at 35% 30%,#b25738,#8a3a22 45%,#5c2613)}.theme-dark .seal{background:radial-gradient(circle at 35% 30%,#c25940,#9c3e2a 45%,#5c2613)}*{box-sizing:border-box}html,body,#root{width:100%;min-height:100%;margin:0}body{background:var(--bg-page);color:var(--ink-2);font-family:var(--f-body);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background-color .25s ease,color .25s ease}button,textarea,input,select{font:inherit;color:inherit}button{cursor:pointer}img{display:block;max-width:100%}a{color:var(--accent-2)}
