:root{--bg:oklch(97.1% .012 80);--bg-deep:oklch(94.5% .018 75);--surface:oklch(99.3% .006 80);--surface-2:oklch(96.5% .012 80);--ink:oklch(22.5% .022 55);--ink-soft:oklch(42% .022 60);--ink-muted:oklch(58% .018 65);--ink-faint:oklch(72% .012 70);--line:oklch(89% .012 70);--line-strong:oklch(83% .014 65);--accent:oklch(52% .105 38);--accent-soft:oklch(92% .04 60);--accent-ink:oklch(36% .085 35);--sage:oklch(55% .06 145);--display:"Newsreader", ui-serif, Georgia, serif;--body:"DM Sans", ui-sans-serif, system-ui, -apple-system, sans-serif;--mono:"JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--radius:14px;--radius-s:8px;--radius-l:22px;--shadow-s:0 1px 0 #3c28140a, 0 1px 3px #3c28140d;--shadow-m:0 1px 0 #3c28140a, 0 10px 30px -12px #3c28142e;--shadow-l:0 1px 0 #3c28140d, 0 30px 60px -20px #3c281440;--ease:cubic-bezier(.2,.7,.2,1)}*{box-sizing:border-box}html,body{height:100%;margin:0;padding:0}body{background:var(--bg);color:var(--ink);font-family:var(--body);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;font-size:16px;line-height:1.5}#root{min-height:100vh}.shell{background:radial-gradient(1200px 600px at 80% -10%, oklch(94% .025 65) 0%, transparent 60%), radial-gradient(900px 500px at -10% 110%, oklch(94% .03 50) 0%, transparent 55%), var(--bg);flex-direction:column;min-height:100vh;display:flex}.display{font-family:var(--display);letter-spacing:-.015em;color:var(--ink);font-weight:400;line-height:1.05}.display-i{font-style:italic}.eyebrow{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);font-size:11px;font-weight:500}.lede{font-family:var(--display);color:var(--ink-soft);text-wrap:pretty;font-size:22px;font-weight:300;line-height:1.4}.btn{appearance:none;font:inherit;cursor:pointer;background:var(--ink);color:var(--bg);transition:transform .12s var(--ease), background .15s var(--ease);white-space:nowrap;border:0;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:14px 22px;font-weight:500;text-decoration:none;display:inline-flex}.btn:hover{background:oklch(32% .025 55)}.btn:active{transform:translateY(1px)}.btn--accent{background:var(--accent);color:#fff8ef}.btn--accent:hover{background:var(--accent-ink)}.btn--ghost{color:var(--ink);border:1px solid var(--line-strong);background:0 0}.btn--link{appearance:none;font:inherit;color:var(--accent);cursor:pointer;background:0 0;border:none;padding:0;text-decoration:underline}.btn--ghost:hover{background:var(--surface-2)}.btn--lg{padding:18px 30px;font-size:17px}.btn--sm{padding:9px 16px;font-size:13px}.btn[disabled]{opacity:.4;cursor:not-allowed}.tag{border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);border-radius:999px;align-items:center;gap:6px;padding:5px 10px;font-size:12px;display:inline-flex}.tag--accent{background:var(--accent-soft);color:var(--accent-ink);border-color:#0000}.field{flex-direction:column;gap:7px;display:flex}.field__label{color:var(--ink-soft);font-size:13px;font-weight:500}.field__hint{color:var(--ink-muted);font-size:12px}.field__input,.field__textarea{font:inherit;background:var(--surface);border:1px solid var(--line);color:var(--ink);width:100%;transition:border-color .15s var(--ease), background .15s var(--ease);font-size:16px;font-family:var(--body);border-radius:10px;padding:14px 16px}.field__input:focus,.field__textarea:focus{border-color:var(--accent);background:#fff;outline:none}.field__textarea{font-family:var(--display);resize:vertical;min-height:220px;color:var(--ink);font-size:19px;font-weight:350;line-height:1.55}.field__textarea::placeholder{color:var(--ink-faint);font-style:italic}.field__counter{font-family:var(--mono);color:var(--ink-muted);align-self:flex-end;font-size:11px}.divider-ornament{color:var(--ink-faint);justify-content:center;align-items:center;gap:14px;margin:32px 0;display:flex}.divider-ornament:before,.divider-ornament:after{content:"";background:var(--line);flex:1;max-width:80px;height:1px}.divider-ornament svg{width:18px;height:18px}.placeholder-img{color:var(--ink-soft);background:repeating-linear-gradient(135deg,oklch(88% .025 60) 0 8px,oklch(92% .025 65) 8px 16px);place-items:center;display:grid;position:relative;overflow:hidden}.placeholder-img:after{content:attr(data-label);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);background:#ffffffd9;border-radius:6px;padding:4px 10px;font-size:11px}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .35s var(--ease) both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .25s var(--ease) both}.row{align-items:center;gap:12px;display:flex}.col{flex-direction:column;gap:12px;display:flex}.between{justify-content:space-between}.wrap{flex-wrap:wrap}.flex1{flex:1}.muted{color:var(--ink-muted)}.center-text{text-align:center}.site-nav{justify-content:flex-end;align-items:center;max-width:880px;margin:0 auto;padding:16px 24px 0;display:flex;position:relative}.site-nav__hamburger{appearance:none;border:1px solid var(--line);background:var(--surface);color:var(--ink-soft);cursor:pointer;width:36px;height:36px;transition:color .12s var(--ease), border-color .12s var(--ease), background .12s var(--ease);border-radius:10px;place-items:center;display:grid}.site-nav__hamburger:hover{color:var(--ink);border-color:var(--line-strong);background:var(--surface-2)}.site-nav__dropdown{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-s);box-shadow:var(--shadow-m);z-index:100;min-width:160px;position:absolute;top:calc(100% - 4px);right:24px;overflow:hidden}.site-nav__dropdown-item{color:var(--ink-soft);transition:background .12s var(--ease), color .12s var(--ease);padding:11px 16px;font-size:14px;font-weight:500;text-decoration:none;display:block}.site-nav__dropdown-item:hover{background:var(--surface-2);color:var(--ink)}.site-nav__dropdown-item.active{color:var(--accent)}.landing{flex-direction:column;display:flex}.landing__hero{grid-template-columns:1.15fr .85fr;align-items:center;gap:56px;padding:84px 72px 64px;display:grid;position:relative}.landing__hero-eyebrow{color:var(--ink-muted);align-items:center;gap:12px;margin-bottom:22px;display:inline-flex}.landing__hero h1{font-family:var(--display);letter-spacing:-.02em;color:var(--ink);text-wrap:balance;margin:0 0 24px;font-size:clamp(54px,6vw,88px);font-style:italic;font-weight:400;line-height:.98}.landing__hero h1 em{color:var(--accent);font-style:italic;font-weight:400}.landing__hero p{font-family:var(--display);color:var(--ink-soft);text-wrap:pretty;max-width:44ch;margin:0 0 36px;font-size:21px;font-weight:300;line-height:1.45}.landing__hero-cta{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.landing__hero-cta .meta{color:var(--ink-muted);align-items:center;gap:8px;font-size:13px;display:inline-flex}.landing__portrait{aspect-ratio:4/5;box-shadow:var(--shadow-l);border-radius:4px;position:relative;overflow:hidden;transform:rotate(1.2deg)}.landing__portrait:before{content:"";box-sizing:border-box;z-index:2;pointer-events:none;border:14px solid #fdfaf3;border-bottom-width:70px;border-radius:4px;position:absolute;inset:0;box-shadow:inset 0 0 0 1px #3c28140f}.landing__portrait:after{content:"Resurrection Sunday";font-family:var(--display);color:var(--ink-soft);z-index:3;font-size:16px;font-style:italic;position:absolute;bottom:22px;left:50%;transform:translate(-50%)}.landing__stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:linear-gradient(#0000,oklch(96% .02 65) 50%,#0000);grid-template-columns:repeat(3,1fr);gap:36px;margin:0 72px;padding:28px 36px;display:grid}.landing__stat .num{font-family:var(--display);letter-spacing:-.02em;color:var(--ink);font-size:48px;font-weight:400;line-height:1}.landing__stat .num em{color:var(--accent);font-style:italic}.landing__stat .label{color:var(--ink-muted);margin-top:6px;font-size:13px}.landing__prompts{padding:72px 72px 56px}.landing__prompts-head{justify-content:space-between;align-items:flex-end;margin-bottom:34px;display:flex}.landing__prompts-head h2{font-family:var(--display);letter-spacing:-.015em;max-width:22ch;margin:0;font-size:42px;font-style:italic;font-weight:400;line-height:1.05}.landing__prompts-head p{color:var(--ink-muted);text-align:right;max-width:30ch;margin:0;font-size:14px}.prompt-grid{background:var(--line);border:1px solid var(--line);border-radius:var(--radius);grid-template-columns:repeat(2,1fr);gap:1px;display:grid;overflow:hidden}.prompt-tile{background:var(--surface);cursor:pointer;min-height:132px;transition:background .15s var(--ease);flex-direction:column;gap:10px;padding:26px 28px;display:flex;position:relative}.prompt-tile:hover{background:var(--surface-2)}.prompt-tile__num{font-family:var(--mono);letter-spacing:.1em;color:var(--ink-faint);font-size:11px}.prompt-tile__title{font-family:var(--display);letter-spacing:-.005em;color:var(--ink);font-size:22px;font-style:italic;font-weight:400;line-height:1.18}.prompt-tile__hint{color:var(--ink-muted);margin-top:auto;font-size:13px;line-height:1.45}.landing__footer{border-top:1px solid var(--line);background:repeating-linear-gradient(0deg,#0000 0 30px,oklch(94% .02 60) 30px 31px);justify-content:space-between;align-items:center;padding:56px 72px 84px;display:flex}.landing__footer-text{font-family:var(--display);color:var(--ink);max-width:28ch;font-size:26px;font-style:italic;font-weight:300;line-height:1.3}.landing__footer-text em{color:var(--accent)}@media (width<=600px){.landing__hero{grid-template-columns:1fr;gap:28px;padding:32px 24px 28px}.landing__hero h1{font-size:44px}.landing__hero p{font-size:17px}.landing__hero-cta{flex-direction:column;align-items:stretch}.landing__hero-cta .btn{width:100%}.landing__portrait{max-width:240px;margin:0 auto;transform:rotate(-1.5deg)}.landing__portrait:after{font-size:13px;bottom:18px}.landing__portrait:before{border-width:10px 10px 50px}.landing__stats{grid-template-columns:repeat(3,1fr);gap:12px;margin:0 24px;padding:22px 0}.landing__stat .num{font-size:32px}.landing__stat .label{font-size:12px}.landing__prompts{padding:36px 24px 24px}.landing__prompts-head{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:22px}.landing__prompts-head h2{font-size:30px}.landing__prompts-head p{text-align:left}.prompt-grid{grid-template-columns:1fr}.prompt-tile{min-height:0;padding:20px 22px}.prompt-tile__title{font-size:19px}.landing__footer{flex-direction:column;align-items:flex-start;gap:18px;padding:32px 24px 80px}.landing__footer-text{font-size:21px}}.form{max-width:880px;margin:0 auto;padding:32px 72px 84px}.form__back{appearance:none;font:inherit;color:var(--ink-muted);cursor:pointer;background:0 0;border:0;align-items:center;gap:8px;padding:4px 0;font-size:13px;display:inline-flex}.form__back:hover{color:var(--ink)}.form__progress{align-items:center;gap:14px;margin:28px 0 40px;display:flex}.form__progress-step{font-size:12px;font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);align-items:center;gap:8px;display:inline-flex}.form__progress-step.is-current{color:var(--accent)}.form__progress-step.is-done{color:var(--ink)}.form__progress-step .dot{background:var(--ink-faint);border-radius:50%;width:8px;height:8px}.form__progress-step.is-current .dot{background:var(--accent)}.form__progress-step.is-done .dot{background:var(--ink)}.form__progress-line{background:var(--line);flex:1;max-width:60px;height:1px}.form h1{font-family:var(--display);letter-spacing:-.015em;text-wrap:balance;margin:0 0 14px;font-size:clamp(36px,4vw,52px);font-style:italic;font-weight:400;line-height:1.05}.form>p.lede{margin:0 0 36px}.prompt-list{background:var(--line);border:1px solid var(--line);border-radius:var(--radius);flex-direction:column;gap:1px;display:flex;overflow:hidden}.prompt-list__item{appearance:none;background:var(--surface);text-align:left;font:inherit;cursor:pointer;transition:background .15s var(--ease), padding-left .15s var(--ease);border:0;grid-template-columns:auto 1fr auto;align-items:center;gap:22px;width:100%;padding:22px 26px;display:grid}.prompt-list__item:hover{background:var(--surface-2);padding-left:30px}.prompt-list__item .num{font-family:var(--mono);color:var(--ink-faint);letter-spacing:.08em;width:22px;font-size:11px}.prompt-list__item .title{font-family:var(--display);color:var(--ink);font-size:22px;font-style:italic;font-weight:400;line-height:1.2}.prompt-list__item .hint{color:var(--ink-muted);margin-top:4px;font-size:13px}.prompt-list__item .arr{color:var(--ink-faint);transition:color .15s var(--ease), transform .15s var(--ease)}.prompt-list__item:hover .arr{color:var(--accent);transform:translate(3px)}.prompt-list__item.is-selected{background:var(--accent-soft);padding-left:30px}.prompt-list__item.is-selected .arr{color:var(--accent)}.compose{grid-template-columns:1fr 320px;gap:48px;display:grid}.compose__main{flex-direction:column;gap:28px;display:flex}.compose__side{flex-direction:column;gap:20px;display:flex}.prompt-response-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);flex-direction:column;gap:14px;padding:24px 24px 20px;display:flex}.prompt-response-card--freeform{border-color:var(--line);background:var(--bg-deep)}.prompt-response-card__q{font-family:var(--display);color:var(--ink);letter-spacing:-.01em;font-size:20px;font-style:italic;line-height:1.2}.prompt-response-card__hint{color:var(--ink-muted);margin-top:-6px;font-size:13px;line-height:1.45}.prompt-response-card__photo{align-items:center;display:flex}.prompt-photo-preview{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.prompt-photo-preview__slot{border-radius:var(--radius-s);background:var(--accent-soft);flex-shrink:0;width:80px;height:80px;position:relative;overflow:hidden}.prompt-photo-preview__name{color:var(--ink-muted);word-break:break-all;padding:4px;font-size:10px}.photo-delete-btn{color:#fff;cursor:pointer;z-index:2;background:#000000a6;border:0;border-radius:50%;place-items:center;width:22px;height:22px;padding:0;display:grid;position:absolute;top:5px;right:5px}.photo-delete-btn:hover{background:#000000d9}.upload-spinner{background:#ffffff80;place-items:center;display:grid;position:absolute;inset:0}.upload-spinner:after{content:"";border:2px solid var(--accent);border-top-color:#0000;border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.selected-prompt-card{background:var(--accent-soft);border-radius:var(--radius);padding:22px 24px;position:relative}.selected-prompt-card .label{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent-ink);margin-bottom:8px;font-size:11px}.selected-prompt-card .title{font-family:var(--display);color:var(--accent-ink);margin-bottom:6px;font-size:26px;font-style:italic;line-height:1.2}.selected-prompt-card .hint{color:var(--accent-ink);opacity:.75;font-size:13.5px;line-height:1.5}.selected-prompt-card .change{color:var(--accent-ink);cursor:pointer;font-size:12px;font:inherit;background:#ffffff8c;border:0;border-radius:999px;padding:5px 10px;font-weight:500;position:absolute;top:16px;right:18px}.selected-prompt-card .change:hover{background:#fff}.photo-grid{grid-template-columns:repeat(5,1fr);gap:10px;display:grid}.photo-slot{aspect-ratio:1;background:var(--surface-2);border:1px dashed var(--line-strong);color:var(--ink-muted);cursor:pointer;transition:border-color .15s var(--ease), background .15s var(--ease);font:inherit;text-align:center;appearance:none;border-radius:10px;place-items:center;padding:4px;font-size:11px;display:grid;position:relative;overflow:hidden}.photo-slot--empty{flex-direction:column;gap:4px;display:flex}.photo-slot--empty:hover{border-color:var(--accent);color:var(--accent)}.photo-slot.is-large{aspect-ratio:16/10}.photo-slot--filled{background:var(--accent-soft);cursor:default;border:0}.photo-slot--disabled{opacity:.35;cursor:default;pointer-events:none;border-style:dashed}.photo-slot--uploading{opacity:.7}.photo-slot__inner{position:absolute;inset:0}.photo-slot__remove{color:#fff;cursor:pointer;z-index:2;background:#000000a6;border:0;border-radius:50%;place-items:center;width:24px;height:24px;display:grid;position:absolute;top:6px;right:6px}.side-card{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius);padding:22px}.side-card h4{color:var(--ink);align-items:center;gap:8px;margin:0 0 12px;font-size:13px;font-weight:600;display:flex}.side-card p{color:var(--ink-soft);margin:0 0 8px;font-size:13px;line-height:1.5}.side-card ul{flex-direction:column;gap:7px;margin:0;padding:0;list-style:none;display:flex}.side-card li{color:var(--ink-soft);align-items:flex-start;gap:8px;font-size:13px;line-height:1.4;display:flex}.side-card li svg{color:var(--accent);flex-shrink:0;margin-top:2px}.form__actions{justify-content:space-between;align-items:center;gap:16px;margin-top:28px;display:flex}@media (width<=600px){.site-nav{padding:12px 16px 0}.form{padding:20px 24px 80px}.form h1{font-size:30px}.form>p.lede{font-size:17px}.prompt-list__item{grid-template-columns:auto 1fr;gap:14px;padding:18px}.prompt-list__item .arr{display:none}.prompt-list__item .title{font-size:18px}.prompt-list__item .hint{font-size:12.5px}.prompt-list__item:hover,.prompt-list__item.is-selected{padding-left:18px}.compose{grid-template-columns:1fr;gap:26px}.photo-grid{grid-template-columns:repeat(3,1fr)}.selected-prompt-card .title{font-size:21px}.form__actions .btn{flex:1}.field__textarea{min-height:180px;font-size:17px}}.write-page{max-width:720px;margin:0 auto;padding:clamp(20px,5vw,48px) 24px 80px}.write-page__topline{align-items:center;gap:12px;margin-bottom:22px;display:flex}.letter{background:var(--surface);border-radius:var(--radius-l);box-shadow:var(--shadow-m);overflow:hidden}.letter__head{text-align:center;padding:clamp(28px,5vw,44px) clamp(24px,6vw,56px) 18px}.letter__dateline{font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:16px;font-size:11px}.letter__dear{font-family:var(--display);letter-spacing:-.01em;color:var(--accent);font-size:clamp(40px,8vw,60px);font-style:italic;font-weight:400;line-height:1}.letter__flourish{width:90px;height:14px;color:var(--ink-faint);margin:18px auto 0;display:block}.letter__prompt-strip{background:var(--accent-soft);border-radius:14px;align-items:center;gap:14px;margin:6px clamp(24px,6vw,56px) 0;padding:14px 16px;display:flex}.letter__prompt-lbl{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--accent-ink);opacity:.75;margin-bottom:3px;font-size:10.5px}.letter__prompt-ttl{font-family:var(--display);color:var(--accent-ink);font-size:19px;font-style:italic;line-height:1.25}.letter__shuffle{appearance:none;cursor:pointer;color:var(--accent-ink);font-family:var(--body);white-space:nowrap;transition:background .15s var(--ease);background:#fff9;border:0;border-radius:999px;flex-shrink:0;align-items:center;gap:7px;padding:9px 15px;font-size:12px;font-weight:600;display:inline-flex}.letter__shuffle:hover{background:#fff}.letter__write{padding:22px clamp(24px,6vw,56px) 0}.letter__note{resize:vertical;width:100%;font-family:var(--display);color:var(--ink);background:repeating-linear-gradient(#0000 0 37px,oklch(88% .012 70) 37px 38px) local;border:0;outline:none;min-height:304px;padding:0;font-size:21px;font-weight:350;line-height:38px;display:block}.letter__note::placeholder{color:var(--ink-faint);font-style:italic}.letter__count{text-align:right;font-family:var(--mono);color:var(--ink-muted);padding:8px clamp(24px,6vw,56px) 0;font-size:11px}.letter__photos{border-top:1px solid var(--line);margin:6px clamp(24px,6vw,56px) 0;padding-top:22px}.letter__photos-head{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:12px;display:flex}.letter__photos-head span:first-child{color:var(--ink);font-size:13px;font-weight:500}.letter__photos-head span:last-child{color:var(--ink-muted);font-size:12px}.letter__photo-row{flex-wrap:wrap;gap:10px;display:flex}.letter__slot{background:var(--surface-2);border:1px dashed var(--line);width:84px;height:84px;color:var(--ink-muted);cursor:pointer;appearance:none;transition:border-color .15s var(--ease), color .15s var(--ease);border-radius:12px;place-items:center;display:grid;position:relative;overflow:hidden}.letter__slot--empty:hover{border-color:var(--accent);color:var(--accent)}.letter__slot--filled{cursor:default;border:0}.letter__slot--uploading{opacity:.7}.letter__signoff{border-top:1px solid var(--line);margin:26px clamp(24px,6vw,56px) 0;padding-top:24px}.letter__with-love{font-family:var(--display);color:var(--accent);margin-bottom:16px;font-size:28px;font-style:italic}.letter__signoff-fields{grid-template-columns:1fr 1fr;gap:14px;display:grid}.letter__foot{justify-content:space-between;align-items:center;gap:18px;padding:26px clamp(24px,6vw,56px) 38px;display:flex}.letter__foot-note{color:var(--ink-muted);max-width:34ch;margin:0;font-size:13px;line-height:1.5}.letter--sent{text-align:center;padding:clamp(48px,9vw,80px) clamp(24px,6vw,56px)}.letter__seal{background:var(--accent-soft);width:64px;height:64px;color:var(--accent);border-radius:50%;place-items:center;margin:0 auto 24px;display:grid}.letter--sent h2{font-family:var(--display);margin:0 0 16px;font-size:clamp(34px,6vw,46px);font-style:italic;font-weight:400;line-height:1.05}.letter--sent h2 em{color:var(--accent)}.letter--sent p{color:var(--ink-soft);max-width:44ch;margin:0 auto 28px;font-size:16px;line-height:1.6}.letter__sent-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}@media (width<=560px){.letter__signoff-fields{grid-template-columns:1fr}.letter__foot{flex-direction:column;align-items:stretch}.letter__foot-note{text-align:center;max-width:none}.letter__foot .btn{width:100%}.letter__prompt-strip{flex-direction:column;align-items:flex-start;gap:12px}.letter__prompt-ttl{font-size:16px}.letter__shuffle{align-self:flex-end}.letter__note{font-size:19px}}.deadline-badge{background:var(--surface);border:1px solid var(--line);color:var(--ink-soft);font-variant-numeric:tabular-nums;border-radius:999px;align-items:center;gap:8px;padding:6px 12px 6px 10px;font-size:12.5px;font-weight:500;display:inline-flex}.deadline-badge__dot{background:var(--sage);border-radius:50%;width:7px;height:7px;box-shadow:0 0 0 4px oklch(92% .04 145/.4)}.deadline-badge.is-compact{padding:4px 10px 4px 8px;font-size:12px}.thanks{text-align:center;flex-direction:column;align-items:center;max-width:720px;margin:0 auto;padding:100px 72px;display:flex}.thanks__sparkle{background:var(--accent-soft);width:64px;height:64px;color:var(--accent);border-radius:50%;place-items:center;margin-bottom:28px;display:grid}.thanks h1{font-family:var(--display);letter-spacing:-.015em;text-wrap:balance;margin:0 0 22px;font-size:clamp(46px,5vw,64px);font-style:italic;font-weight:400;line-height:1.05}.thanks h1 em{color:var(--accent)}.thanks p{font-family:var(--display);color:var(--ink-soft);text-wrap:pretty;max-width:50ch;margin:0 0 36px;font-size:21px;font-weight:300;line-height:1.5}.thanks__receipt{background:var(--surface-2);border:1px dashed var(--line-strong);border-radius:var(--radius);text-align:left;grid-template-columns:repeat(3,auto);gap:28px;margin:36px 0 28px;padding:24px 28px;display:grid}.thanks__receipt-item .k{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:4px;font-size:10.5px}.thanks__receipt-item .v{font-family:var(--display);color:var(--ink);font-size:18px;font-style:italic;line-height:1.2}.thanks__actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}@media (width<=600px){.thanks{padding:60px 24px}.thanks__receipt{grid-template-columns:1fr;gap:16px;padding:18px 20px}.thanks p{font-size:17px}}.admin{grid-template-columns:380px 1fr;min-height:760px;display:grid}.admin__sidebar{border-right:1px solid var(--line);background:var(--surface-2);flex-direction:column;display:flex}.admin__sidebar-head{border-bottom:1px solid var(--line);padding:28px 28px 18px}.admin__sidebar-head .eyebrow{margin-bottom:6px}.admin__sidebar-head h2{font-family:var(--display);letter-spacing:-.01em;margin:0 0 14px;font-size:28px;font-style:italic;font-weight:400}.admin__sidebar-head .row{flex-wrap:wrap;gap:6px}.admin__counts{grid-template-columns:repeat(3,1fr);gap:10px;margin-top:18px;display:grid}.admin__counts>div{background:var(--surface);border:1px solid var(--line);border-radius:10px;padding:12px 14px}.admin__counts .num{font-family:var(--display);color:var(--ink);letter-spacing:-.01em;font-size:24px;line-height:1}.admin__counts .label{color:var(--ink-muted);margin-top:4px;font-size:11px}.admin__search{border-bottom:1px solid var(--line);background:var(--surface-2);align-items:center;gap:8px;padding:14px 22px;display:flex}.admin__search input{appearance:none;font:inherit;color:var(--ink);background:0 0;border:0;outline:none;flex:1;font-size:13px}.admin__search input::placeholder{color:var(--ink-muted)}.admin__filter-btn{appearance:none;border:1px solid var(--line);color:var(--ink-muted);font:inherit;cursor:pointer;background:0 0;border-radius:6px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;display:inline-flex}.admin__filter-btn:hover{color:var(--ink);border-color:var(--line-strong)}.admin__list{flex:1;padding:6px 0;overflow:auto}.admin__list-item{appearance:none;font:inherit;text-align:left;cursor:pointer;border:0;border-bottom:1px solid var(--line);width:100%;transition:background .12s var(--ease);background:0 0;grid-template-columns:auto 1fr auto;align-items:flex-start;gap:14px;padding:18px 22px;display:grid}.admin__list-item:hover{background:var(--surface)}.admin__list-item.is-active{background:var(--surface);box-shadow:inset 3px 0 0 var(--accent)}.admin__list-item .avatar{width:36px;height:36px;font-family:var(--display);color:var(--ink);border-radius:50%;flex-shrink:0;place-items:center;font-size:16px;font-style:italic;display:grid}.admin__list-item .who{color:var(--ink);font-size:14px;font-weight:500}.admin__list-item .prompt{color:var(--ink-muted);-webkit-line-clamp:1;-webkit-box-orient:vertical;margin-top:2px;font-size:12px;display:-webkit-box;overflow:hidden}.admin__list-item .preview{color:var(--ink-soft);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:6px;font-size:13px;line-height:1.4;display:-webkit-box;overflow:hidden}.admin__list-item .meta{color:var(--ink-muted);font-size:11px;font-family:var(--mono);letter-spacing:.04em;white-space:nowrap}.admin__detail{padding:40px 56px;overflow:auto}.admin__detail-head{justify-content:space-between;align-items:flex-start;margin-bottom:28px;display:flex}.admin__detail-who{align-items:center;gap:16px;display:flex}.admin__detail-who .avatar{width:56px;height:56px;font-family:var(--display);color:var(--ink);border-radius:50%;place-items:center;font-size:22px;font-style:italic;display:grid}.admin__detail-who .name{font-family:var(--display);letter-spacing:-.005em;font-size:26px;font-weight:400;line-height:1.1}.admin__detail-who .rel{color:var(--ink-muted);margin-top:4px;font-size:13px}.admin__detail-actions{gap:8px;display:flex}.icon-btn{appearance:none;border:1px solid var(--line);color:var(--ink-soft);cursor:pointer;background:0 0;border-radius:999px;place-items:center;width:36px;height:36px;display:grid}.icon-btn:hover{color:var(--ink);border-color:var(--line-strong)}.icon-btn.is-danger:hover{color:oklch(50% .15 25);border-color:oklch(50% .15 25/.3)}.admin__detail-prompt{background:var(--accent-soft);color:var(--accent-ink);font-family:var(--mono);letter-spacing:.08em;text-transform:uppercase;border-radius:999px;align-items:center;gap:8px;margin-bottom:20px;padding:6px 12px;font-size:11px;display:inline-flex}.admin__detail-prompt-title{font-family:var(--display);letter-spacing:-.01em;color:var(--ink);margin:0 0 28px;font-size:32px;font-style:italic;font-weight:400;line-height:1.1}.admin__detail-body{font-family:var(--display);color:var(--ink);text-wrap:pretty;white-space:pre-wrap;margin:0 0 32px;font-size:20px;font-weight:350;line-height:1.6}.admin__detail-photos{grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:32px;display:grid}.admin__detail-photos .ph{aspect-ratio:4/3;border-radius:10px;overflow:hidden}.admin__detail-foot{border-top:1px solid var(--line);color:var(--ink-muted);justify-content:space-between;align-items:center;padding-top:18px;font-size:12.5px;display:flex}.admin__detail-foot .pill{background:var(--surface-2);color:var(--ink-soft);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;display:inline-flex}.export-bar{border-radius:var(--radius);background:var(--ink);color:var(--bg);justify-content:space-between;align-items:center;gap:12px;margin:14px 18px;padding:16px 18px;display:flex}.export-bar .title{font-family:var(--display);color:var(--bg);font-size:16px;font-style:italic}.export-bar .sub{color:oklch(86% .02 70);margin-top:2px;font-size:11.5px}.export-bar .btn{background:var(--accent);color:#fff8ef;padding:10px 14px;font-size:13px}@media (width<=600px){.admin{grid-template-columns:1fr;min-height:0}.admin__sidebar{border-right:0;border-bottom:1px solid var(--line)}.admin__sidebar-head{padding:20px 22px 14px}.admin__sidebar-head h2{font-size:22px}.admin__counts{gap:8px}.admin__counts .num{font-size:20px}.admin__detail{display:none}.admin__list-item{padding:14px 18px}.admin.show-detail .admin__sidebar{display:none}.admin.show-detail .admin__detail{padding:24px 22px;display:block}}.submissions{max-width:800px;margin:0 auto;padding:56px 72px 84px}.submissions__header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:32px;display:flex}.submissions h1{font-family:var(--display);letter-spacing:-.015em;margin:0;font-size:42px;font-style:italic;font-weight:400}.submission-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:12px;padding:24px 28px}.submission-card__prompt{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);margin-bottom:8px;font-size:11px}.submission-card__body{font-family:var(--display);color:var(--ink);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin-bottom:12px;font-size:18px;line-height:1.5;display:-webkit-box;overflow:hidden}.submission-card__foot{color:var(--ink-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;font-size:12px;display:flex}.submission-card__who{align-items:center;gap:8px;display:flex}.submission-card__avatar{background:var(--accent-soft);width:28px;height:28px;font-family:var(--display);border-radius:50%;flex-shrink:0;place-items:center;font-size:13px;font-style:italic;display:grid}.submission-card__meta{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.submission-card__actions{align-items:center;gap:8px;display:flex}@media (width<=600px){.submissions{padding:24px 20px 60px}.submissions h1{font-size:30px}.submission-card{padding:16px 18px}.submission-card__body{font-size:15px}.submission-card__foot{flex-direction:column;align-items:flex-start;gap:10px}.submission-card__actions{width:100%}.submission-card__actions .btn{flex:1;justify-content:center}}.status-pill{font-size:11px;font-family:var(--mono);letter-spacing:.06em;text-transform:uppercase;border-radius:999px;align-items:center;gap:5px;padding:3px 8px;display:inline-flex}.status-pill--draft{background:var(--surface-2);color:var(--ink-muted)}.status-pill--processing{color:oklch(45% .08 70);background:oklch(95% .04 80)}.status-pill--submitted{color:var(--sage);background:oklch(92% .05 145/.4)}.status-pill--locked{color:oklch(45% .05 240);background:oklch(93% .03 240/.4)}.sign-in{max-width:420px;margin:0 auto;padding:80px 24px}.sign-in h1{font-family:var(--display);letter-spacing:-.015em;margin:0 0 8px;font-size:38px;font-style:italic;font-weight:400}.sign-in p{color:var(--ink-soft);margin:0 0 32px;font-size:15px;line-height:1.5}.sign-in__tabs{border-bottom:1px solid var(--line);gap:0;margin-bottom:28px;display:flex}.sign-in__tab{appearance:none;font:inherit;color:var(--ink-muted);cursor:pointer;transition:color .15s var(--ease);background:0 0;border:0;border-bottom:2px solid #0000;margin-bottom:-1px;padding:10px 16px;font-size:13px;font-weight:500}.sign-in__tab.is-active{color:var(--accent);border-bottom-color:var(--accent)}.sign-in__form{flex-direction:column;gap:16px;display:flex}.sign-in__sent{border-radius:var(--radius);text-align:center;background:oklch(95% .04 145/.3);border:1px solid oklch(85% .06 145/.4);padding:20px 22px}.sign-in__sent p{color:var(--ink-soft);margin:0;font-size:14px;line-height:1.6}.prompts-table{border-collapse:collapse;width:100%}.prompts-table th{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);text-align:left;border-bottom:1px solid var(--line);padding:10px 16px;font-size:11px}.prompts-table td{border-bottom:1px solid var(--line);vertical-align:top;padding:14px 16px}.prompts-table tr:hover td{background:var(--surface-2)}.prompt-body-input{font:inherit;font-family:var(--display);width:100%;color:var(--ink);background:0 0;border:1px solid #0000;border-radius:6px;padding:4px 8px;font-size:16px;font-style:italic}.prompt-body-input:focus{border-color:var(--accent);background:var(--surface);outline:none}.prompt-hint-input{font:inherit;width:100%;color:var(--ink-muted);background:0 0;border:1px solid #0000;border-radius:6px;padding:4px 8px;font-size:13px}.prompt-hint-input:focus{border-color:var(--accent);background:var(--surface);outline:none}.toggle{flex-shrink:0;width:36px;height:20px;display:inline-flex;position:relative}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle__track{background:var(--line-strong);cursor:pointer;transition:background .15s var(--ease);border-radius:999px;position:absolute;inset:0}.toggle input:checked+.toggle__track{background:var(--sage)}.toggle__thumb{pointer-events:none;width:14px;height:14px;transition:transform .15s var(--ease);background:#fff;border-radius:50%;position:absolute;top:3px;left:3px}.toggle input:checked~.toggle__thumb{transform:translate(16px)}.prompt-order-input{font:inherit;font-family:var(--mono);width:56px;color:var(--ink-soft);text-align:center;background:0 0;border:1px solid #0000;border-radius:6px;padding:4px 6px;font-size:13px}.prompt-order-input:focus{border-color:var(--accent);background:var(--surface);outline:none}.photo-tint{width:100%;height:100%;display:block}
