:root{--bg-cream: #f5efe3;--bg-cream-deep: #efe7d4;--bg-mist: #eaf0e6;--surface: #fbf8f1;--surface-raised: #ffffff;--surface-soft: #f0ebdb;--ink-deep: #1f2a20;--ink: #2a3429;--ink-soft: #5d6a5a;--ink-muted: #8a9485;--moss-900: #1f4029;--moss-700: #2e5d3a;--moss-500: #5b8a64;--moss-300: #a9c5a8;--moss-100: #dfead9;--sage-200: #cfdac4;--bark: #6b5a3f;--bloom: #d99a7a;--sun: #e9b760;--shadow-soft: 0 1px 2px rgba(31, 40, 32, .04), 0 8px 24px -12px rgba(31, 40, 32, .12);--shadow-card: 0 1px 2px rgba(31, 40, 32, .05), 0 16px 40px -20px rgba(31, 40, 32, .18);--shadow-modal: 0 30px 80px -30px rgba(31, 40, 32, .35);--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;--radius-pill: 999px;--serif: "Fraunces", "Iowan Old Style", "Palatino", Georgia, serif;--sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--sans);font-size:16px;line-height:1.55;color:var(--ink);background:var(--bg-cream);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-shell{min-height:100vh;position:relative;overflow-x:hidden;background:radial-gradient(900px 600px at 8% -10%,rgba(169,197,168,.55),transparent 70%),radial-gradient(900px 700px at 110% 10%,rgba(233,183,96,.18),transparent 70%),radial-gradient(700px 700px at 50% 110%,rgba(91,138,100,.18),transparent 60%),var(--bg-cream)}.app-shell:before,.app-shell:after{content:"";position:fixed;pointer-events:none;z-index:0;opacity:.55}.app-shell:before{left:-90px;bottom:-60px;width:320px;height:320px;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><g fill='none' stroke='%235b8a64' stroke-width='2' stroke-linecap='round'><path d='M100 180 C 100 130, 60 110, 50 70'/><path d='M100 180 C 100 140, 140 120, 150 80'/><path d='M50 70 q -20 -5 -28 -25 q 18 -4 30 12'/><path d='M50 70 q 20 -8 28 -28 q -16 -2 -28 14'/><path d='M150 80 q 18 -8 26 -28 q -14 -2 -26 14'/><path d='M150 80 q -18 -6 -26 -26 q 14 -2 26 12'/></g></svg>") no-repeat center / contain}.app-shell:after{right:-80px;top:8%;width:260px;height:260px;opacity:.35;transform:rotate(18deg);background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><g fill='none' stroke='%23a9c5a8' stroke-width='2'><path d='M100 20 C 70 60, 70 140, 100 180' stroke-linecap='round'/><path d='M100 60 q 30 -10 50 -30'/><path d='M100 100 q 35 -10 55 -30'/><path d='M100 140 q 30 -10 50 -30'/><path d='M100 80 q -30 -10 -50 -30'/><path d='M100 120 q -35 -10 -55 -30'/></g></svg>") no-repeat center / contain}.app-shell>*{position:relative;z-index:1}.topbar{display:flex;align-items:center;justify-content:space-between;padding:28px max(28px,5vw)}.brand{display:flex;align-items:center;gap:12px;font-family:var(--serif);font-weight:600;font-size:22px;color:var(--moss-900);letter-spacing:.2px}.brand-leaf{width:30px;height:30px;display:grid;place-items:center;background:var(--moss-100);border-radius:50%;color:var(--moss-700)}.brand small{display:block;font-family:var(--sans);font-weight:400;font-size:12px;color:var(--ink-muted);letter-spacing:.4px}.topbar-actions{display:flex;align-items:center;gap:12px;color:var(--ink-soft);font-size:13px}.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-pill);background:var(--surface);border:1px solid rgba(91,138,100,.18);color:var(--moss-700);font-size:12px;font-weight:500}.page{max-width:1180px;margin:0 auto;padding:24px max(20px,5vw) 96px}.upload-hero{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;margin-top:28px}@media (max-width: 880px){.upload-hero{grid-template-columns:1fr}}.eyebrow{display:inline-block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--moss-700);background:var(--moss-100);padding:6px 12px;border-radius:var(--radius-pill);margin-bottom:22px}.headline{font-family:var(--serif);font-weight:500;font-size:clamp(34px,4.6vw,54px);line-height:1.06;color:var(--moss-900);margin:0 0 18px;letter-spacing:-.5px}.headline em{font-style:italic;color:var(--moss-700)}.lede{font-size:17px;color:var(--ink-soft);max-width:52ch;margin:0 0 28px}.dropzone{position:relative;background:var(--surface);border-radius:var(--radius-lg);padding:36px;border:1.5px dashed rgba(91,138,100,.45);box-shadow:var(--shadow-card);transition:border-color .18s ease,transform .18s ease,background .18s ease}.dropzone.is-drag{border-color:var(--moss-700);background:var(--moss-100);transform:translateY(-2px)}.dropzone-inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px}.dropzone-icon{width:72px;height:72px;border-radius:50%;background:var(--moss-100);display:grid;place-items:center;color:var(--moss-700)}.dropzone-title{font-family:var(--serif);font-size:22px;font-weight:500;color:var(--moss-900);margin:0}.dropzone-hint{color:var(--ink-muted);font-size:14px;margin:0}.dropzone input[type=file]{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.dropzone-file{margin-top:6px;font-size:13px;color:var(--moss-700);background:var(--moss-100);padding:6px 12px;border-radius:var(--radius-pill)}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;font-family:var(--sans);font-weight:500;font-size:15px;padding:12px 22px;border-radius:var(--radius-pill);cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:transform .12s ease,box-shadow .18s ease,background .18s ease,color .18s ease}.btn-primary{background:var(--moss-700);color:#fbf8f1;box-shadow:0 8px 22px -10px #2e5d3a99}.btn-primary:hover:not(:disabled){background:var(--moss-900);transform:translateY(-1px)}.btn-primary:disabled{background:var(--ink-muted);cursor:not-allowed;box-shadow:none}.btn-ghost{background:transparent;color:var(--moss-700);border:1px solid rgba(91,138,100,.35)}.btn-ghost:hover:not(:disabled){background:var(--moss-100)}.upload-actions{margin-top:22px;display:flex;gap:12px;flex-wrap:wrap;align-items:center}.error-note{margin-top:14px;background:#f7e6df;color:#7a3a25;padding:10px 14px;border-radius:var(--radius-md);font-size:14px}.help-note{margin-top:14px;color:var(--ink-muted);font-size:13px}.hero-art{position:relative;min-height:360px;display:grid;place-items:center}.hero-art svg{width:100%;max-width:420px;height:auto;filter:drop-shadow(0 18px 30px rgba(46,93,58,.18))}.loading-wrap{min-height:70vh;display:grid;place-items:center}.loading-card{display:flex;flex-direction:column;align-items:center;gap:22px;background:var(--surface);padding:56px 64px;border-radius:var(--radius-lg);box-shadow:var(--shadow-card);text-align:center;max-width:460px}.loading-card h2{font-family:var(--serif);font-weight:500;font-size:26px;color:var(--moss-900);margin:0}.loading-card p{margin:0;color:var(--ink-soft)}.loading-status{font-size:14px;color:var(--moss-700);background:var(--moss-100);padding:6px 14px;border-radius:var(--radius-pill);letter-spacing:.2px}.sprout-anim{width:160px;height:160px}.sprout-anim .pot{fill:#d9c39a;stroke:#b89d6f;stroke-width:2}.sprout-anim .pot-rim{fill:#e8d5ad}.sprout-anim .soil{fill:#6b4d2a}.sprout-anim .stem{stroke:var(--moss-700);stroke-width:3.5;stroke-linecap:round;fill:none;stroke-dasharray:80;stroke-dashoffset:80;animation:grow-stem 3.6s ease-in-out infinite}.sprout-anim .leaf{fill:var(--moss-500);transform-origin:center bottom;opacity:0;animation:pop-leaf 3.6s ease-in-out infinite}.sprout-anim .leaf.leaf-2{animation-delay:.6s;fill:var(--moss-300)}.sprout-anim .leaf.leaf-3{animation-delay:1.1s;fill:var(--moss-700)}.sprout-anim .bloom{fill:var(--bloom);opacity:0;transform-origin:center;animation:bloom-in 3.6s ease-in-out infinite;animation-delay:1.6s}.sprout-anim .sparkle{fill:var(--sun);opacity:0;animation:sparkle 3.6s ease-in-out infinite}.sprout-anim .sparkle.s2{animation-delay:.8s}.sprout-anim .sparkle.s3{animation-delay:1.6s}@keyframes grow-stem{0%,to{stroke-dashoffset:80}35%,85%{stroke-dashoffset:0}}@keyframes pop-leaf{0%,20%{opacity:0;transform:scale(.2) translateY(6px)}45%,85%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.95)}}@keyframes bloom-in{0%,40%{opacity:0;transform:scale(.4)}60%,85%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.9)}}@keyframes sparkle{0%,20%{opacity:0;transform:translateY(4px)}40%,60%{opacity:1;transform:translateY(-4px)}80%,to{opacity:0;transform:translateY(-10px)}}.loading-dots{display:inline-flex;gap:6px}.loading-dots span{width:7px;height:7px;border-radius:50%;background:var(--moss-500);animation:loading-dot 1.2s ease-in-out infinite}.loading-dots span:nth-child(2){animation-delay:.15s}.loading-dots span:nth-child(3){animation-delay:.3s}@keyframes loading-dot{0%,80%,to{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-4px)}}.gallery-header{display:flex;flex-direction:column;gap:8px;margin:8px 0 32px}.gallery-header h1{font-family:var(--serif);font-size:clamp(28px,3.4vw,38px);font-weight:500;margin:0;color:var(--moss-900);letter-spacing:-.3px}.gallery-header p{margin:0;color:var(--ink-soft);max-width:56ch}.gallery-header-row{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;flex-wrap:wrap}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:22px}.strength-card{position:relative;background:var(--surface);border:1px solid rgba(91,138,100,.14);border-radius:var(--radius-lg);padding:24px 22px 22px;text-align:left;cursor:pointer;overflow:hidden;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease;font:inherit;color:inherit;display:flex;flex-direction:column;gap:14px;min-height:240px}.strength-card:before{content:"";position:absolute;inset:-40px -40px auto auto;width:160px;height:160px;background:radial-gradient(closest-side,rgba(169,197,168,.55),transparent 70%);pointer-events:none}.strength-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card);border-color:#2e5d3a59}.strength-card:focus-visible{outline:3px solid var(--moss-500);outline-offset:3px}.strength-motif{width:72px;height:72px;position:relative;z-index:1}.strength-name{font-family:var(--serif);font-weight:500;font-size:22px;color:var(--moss-900);margin:0;letter-spacing:-.2px}.strength-desc{margin:0;font-size:14px;color:var(--ink-soft);flex:1}.strength-footer{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--ink-muted);letter-spacing:.3px}.strength-footer .open-arrow{color:var(--moss-700);font-weight:600;transition:transform .18s ease}.strength-card:hover .open-arrow{transform:translate(3px)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#1f282073;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:grid;place-items:center;padding:24px;z-index:50;animation:fade-in .18s ease-out}.modal{width:min(720px,100%);max-height:min(86vh,820px);background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);display:flex;flex-direction:column;overflow:hidden;animation:pop-in .22s cubic-bezier(.2,.9,.3,1.2)}@keyframes pop-in{0%{transform:translateY(12px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:24px 28px 18px;background:linear-gradient(180deg,#a9c5a859,#a9c5a800);border-bottom:1px solid rgba(91,138,100,.15)}.modal-head-left{display:flex;align-items:center;gap:16px}.modal-motif{width:54px;height:54px}.modal-title{font-family:var(--serif);font-weight:500;font-size:24px;color:var(--moss-900);margin:0 0 2px;letter-spacing:-.2px}.modal-subtitle{margin:0;font-size:13px;color:var(--ink-soft);max-width:48ch}.modal-close{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:var(--ink-soft);width:36px;height:36px;border-radius:50%;display:grid;place-items:center;cursor:pointer;transition:background .16s ease,color .16s ease}.modal-close:hover{background:var(--moss-100);color:var(--moss-900)}.modal-body{padding:22px 28px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.prompt-card{background:var(--moss-100);border-radius:var(--radius-md);padding:14px 16px;font-size:14px;color:var(--ink)}.prompt-card strong{display:block;font-family:var(--serif);font-weight:600;color:var(--moss-900);margin-bottom:4px}.chat-thread{display:flex;flex-direction:column;gap:12px}.chat-bubble{max-width:92%;padding:12px 16px;border-radius:18px;font-size:14.5px;line-height:1.55;white-space:pre-wrap}.chat-bubble.user{align-self:flex-end;background:var(--moss-700);color:#fbf8f1;border-bottom-right-radius:6px}.chat-bubble.model{align-self:flex-start;background:var(--surface-raised);border:1px solid rgba(91,138,100,.2);border-bottom-left-radius:6px;color:var(--ink)}.chat-bubble.thinking{display:inline-flex;align-items:center;gap:8px;font-style:italic;color:var(--ink-muted)}.composer{display:flex;gap:10px;align-items:flex-end;padding:14px 18px 18px;border-top:1px solid rgba(91,138,100,.15);background:var(--surface)}.composer textarea{flex:1;resize:none;min-height:44px;max-height:160px;border:1px solid rgba(91,138,100,.3);background:var(--surface-raised);border-radius:var(--radius-md);padding:12px 14px;font:inherit;color:var(--ink);font-size:14.5px;line-height:1.5;transition:border-color .14s ease,box-shadow .14s ease}.composer textarea:focus{outline:none;border-color:var(--moss-500);box-shadow:0 0 0 4px #5b8a642e}.composer .btn{padding:10px 18px}.auth-page{max-width:520px}.auth-card{background:var(--surface);border:1px solid rgba(91,138,100,.16);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:36px 36px 28px;margin-top:24px}.auth-title{font-family:var(--serif);font-weight:500;font-size:clamp(28px,4vw,36px);color:var(--moss-900);margin:6px 0 8px;letter-spacing:-.3px}.auth-lede{margin:0 0 24px;color:var(--ink-soft)}.auth-form{display:flex;flex-direction:column;gap:16px}.field{display:flex;flex-direction:column;gap:6px}.field span{font-size:13px;font-weight:500;color:var(--ink-soft)}.field input{border:1px solid rgba(91,138,100,.3);background:var(--surface-raised);border-radius:var(--radius-md);padding:12px 14px;font:inherit;font-size:15px;color:var(--ink);transition:border-color .14s ease,box-shadow .14s ease}.field input:focus{outline:none;border-color:var(--moss-500);box-shadow:0 0 0 4px #5b8a642e}.auth-submit{margin-top:4px;justify-content:center}.auth-switch{margin:18px 0 0;font-size:14px;color:var(--ink-soft)}.auth-switch .subtle-link{padding:2px 6px}.auth-note{margin-top:18px}.section-label{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);margin:0 0 10px}.section-label span{color:var(--moss-700)}.journals-section{margin-bottom:4px}.journals-empty{margin:0;font-size:14px;color:var(--ink-muted);background:var(--surface-soft);border-radius:var(--radius-md);padding:14px 16px}.journal-strip{display:flex;gap:12px;overflow-x:auto;padding:4px 2px 12px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.journal-strip::-webkit-scrollbar{height:8px}.journal-strip::-webkit-scrollbar-thumb{background:#5b8a644d;border-radius:var(--radius-pill)}.journal-chip{flex:0 0 auto;width:132px;scroll-snap-align:start;background:var(--surface-raised);border:1px solid rgba(91,138,100,.18);border-radius:var(--radius-md);padding:12px 12px 14px;cursor:pointer;font:inherit;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.journal-chip:hover{transform:translateY(-2px);box-shadow:var(--shadow-soft);border-color:#2e5d3a59}.journal-chip.is-active{border-color:var(--moss-500);box-shadow:0 0 0 3px #5b8a642e}.journal-chip-sticker{width:84px;height:84px;border-radius:var(--radius-md);background:var(--moss-100);display:grid;place-items:center;overflow:hidden}.journal-chip-sticker img{width:100%;height:100%;object-fit:contain}.journal-chip-title{font-family:var(--serif);font-size:14px;font-weight:500;color:var(--moss-900);line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.journal-chip-date{font-size:11px;color:var(--ink-muted)}.journal-viewer{background:var(--surface-soft);border:1px solid rgba(91,138,100,.18);border-radius:var(--radius-md);padding:16px}.journal-viewer-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px}.journal-viewer-title{display:flex;align-items:center;gap:12px}.journal-viewer-sticker{width:56px;height:56px;border-radius:var(--radius-sm);object-fit:contain;background:var(--surface-raised)}.journal-viewer-title strong{display:block;font-family:var(--serif);font-size:17px;color:var(--moss-900)}.journal-viewer-title span{font-size:12px;color:var(--ink-muted)}.chat-thread.readonly .chat-bubble{font-size:13.5px}.journal-mood{display:inline-block;font-size:12px;font-weight:500;color:var(--moss-700);background:var(--moss-100);padding:4px 12px;border-radius:var(--radius-pill);margin-bottom:12px}.journal-photos{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.journal-photos img{width:84px;height:84px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid rgba(91,138,100,.2)}.finish-panel{display:flex;flex-direction:column;gap:20px}.finish-head{display:flex;flex-direction:column;gap:4px}.finish-title{font-family:var(--serif);font-weight:500;font-size:20px;color:var(--moss-900);margin:0}.finish-sub{margin:0;font-size:14px;color:var(--ink-soft)}.finish-field{display:flex;flex-direction:column;gap:10px}.finish-label{font-size:13px;font-weight:600;color:var(--ink-soft)}.finish-label em{font-style:normal;font-weight:400;color:var(--ink-muted)}.mood-chips{display:flex;flex-wrap:wrap;gap:8px}.mood-chip{font:inherit;font-size:13px;display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius-pill);border:1px solid rgba(91,138,100,.3);background:var(--surface-raised);color:var(--ink);cursor:pointer;transition:background .14s ease,border-color .14s ease,transform .12s ease}.mood-chip:hover:not(:disabled){border-color:var(--moss-500)}.mood-chip.is-active{background:var(--moss-700);border-color:var(--moss-700);color:#fbf8f1}.mood-chip:disabled{opacity:.6;cursor:not-allowed}.finish-note{border:1px solid rgba(91,138,100,.3);background:var(--surface-raised);border-radius:var(--radius-md);padding:11px 14px;font:inherit;font-size:14px;color:var(--ink)}.finish-note:focus{outline:none;border-color:var(--moss-500);box-shadow:0 0 0 4px #5b8a642e}.photo-row{display:flex;flex-wrap:wrap;gap:10px}.photo-thumb{position:relative;width:88px;height:88px}.photo-thumb img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-md);border:1px solid rgba(91,138,100,.2)}.photo-remove{position:absolute;top:-7px;right:-7px;width:22px;height:22px;border-radius:50%;border:0;background:var(--ink-deep);color:#fff;font-size:15px;line-height:1;cursor:pointer;display:grid;place-items:center;box-shadow:var(--shadow-soft)}.photo-add{width:88px;height:88px;border-radius:var(--radius-md);border:1.5px dashed rgba(91,138,100,.45);background:var(--surface-soft);color:var(--moss-700);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font:inherit;font-size:12px}.photo-add span:first-child{font-size:20px;line-height:1}.photo-add:hover:not(:disabled){border-color:var(--moss-700);background:var(--moss-100)}.finish-busy{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-style:italic;color:var(--ink-muted)}.finish-actions{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.journal-live{display:flex;flex-direction:column;gap:12px}.composer-actions{display:flex;flex-direction:column;gap:8px}.composer-actions .btn{padding:10px 18px;white-space:nowrap}.subtle-link{background:none;border:0;color:var(--moss-700);font:inherit;font-size:13px;cursor:pointer;padding:6px 10px;border-radius:var(--radius-pill);display:inline-flex;align-items:center;gap:6px}.subtle-link:hover{background:var(--moss-100)}.banner{background:#fbf3df;border:1px solid #ecd9a4;color:#6c531c;padding:12px 16px;border-radius:var(--radius-md);font-size:14px;margin-bottom:20px}.banner code{background:#6c531c1f;padding:1px 6px;border-radius:4px;font-size:12.5px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}}.journal-page{display:flex;flex-direction:column;gap:28px}.journal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;flex-wrap:wrap}.journal-head h1{font-family:var(--serif);font-size:30px;color:var(--ink-deep);margin:0 0 8px}.journal-head p{margin:0;max-width:56ch;color:var(--ink-soft);line-height:1.55}.journal-head-actions{display:flex;flex-direction:column;gap:6px;align-items:flex-end;white-space:nowrap}.composer-card{background:var(--surface);border:1px solid rgba(91,138,100,.18);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);padding:20px;display:flex;flex-direction:column;gap:16px;min-width:0;max-width:100%;overflow:hidden}.composer-focus{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--moss-100);border-radius:var(--radius-pill);align-self:flex-start;font-size:14px;color:var(--moss-900)}.composer-focus-motif{display:inline-flex}.composer-focus-clear{border:none;background:#1f40291a;color:var(--moss-900);border-radius:var(--radius-pill);padding:3px 10px;font-size:12.5px;cursor:pointer}.composer-focus-clear:hover{background:#1f40292e}.writing-field{position:relative}.writing-backdrop,.writing-input{margin:0;width:100%;min-height:320px;box-sizing:border-box;padding:16px 18px;border:1px solid rgba(91,138,100,.3);border-radius:var(--radius-md);font-family:var(--serif);font-size:17px;line-height:1.7;letter-spacing:.1px;white-space:pre-wrap;word-wrap:break-word;overflow-wrap:break-word;-moz-tab-size:2;tab-size:2}.writing-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;color:transparent;background:var(--surface-raised);pointer-events:none;overflow:auto;z-index:0}.writing-input{position:relative;z-index:1;background:transparent;color:var(--ink);caret-color:var(--moss-700);resize:vertical;display:block;overflow:auto;transition:border-color .14s ease,box-shadow .14s ease}.writing-input::placeholder{color:var(--ink-muted)}.writing-input:focus{outline:none;border-color:var(--moss-500);box-shadow:0 0 0 4px #5b8a6429}.hl{color:transparent;border-radius:4px;background:transparent;box-decoration-break:clone;-webkit-box-decoration-break:clone}.hl-pending{background:#e9b76052;box-shadow:0 0 0 1px #d89a7a73}.hl-accepted{background:#5b8a6452;box-shadow:0 0 0 1px #2e5d3a66}.writing-status{min-height:20px;margin-top:8px}.writing-analyzing{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-muted)}.prompt-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px}.prompt-row-label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted);margin-right:2px}.prompt-pill{border:1px dashed rgba(91,138,100,.4);background:var(--surface-soft);color:var(--ink-soft);border-radius:var(--radius-pill);padding:6px 14px;font-size:13.5px;cursor:pointer;transition:background .14s ease,color .14s ease,border-color .14s ease}.prompt-pill:hover{background:var(--moss-100);color:var(--moss-900);border-color:var(--moss-500)}.detections{border-top:1px solid rgba(91,138,100,.16);padding-top:14px}.detections-label{margin:0 0 10px;font-size:13px;font-weight:600;color:var(--ink-soft)}.detection-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.detection{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;background:var(--surface-raised);border:1px solid rgba(233,183,96,.4);border-radius:var(--radius-md)}.detection-main{display:flex;flex-direction:column;gap:3px;min-width:0}.detection-name{font-weight:600;color:var(--moss-900);font-size:14.5px}.detection-reason{font-size:12.5px;color:var(--ink-muted)}.detection-quote{font-size:13px;color:var(--ink-soft);font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detection-actions{display:flex;gap:6px;flex-shrink:0}.detection-accept,.detection-reject{width:30px;height:30px;border-radius:50%;border:none;cursor:pointer;font-size:14px;line-height:1;transition:transform .12s ease,background .12s ease}.detection-accept{background:var(--moss-500);color:#fff}.detection-accept:hover{background:var(--moss-700);transform:scale(1.08)}.detection-reject{background:#1f282014;color:var(--ink-soft)}.detection-reject:hover{background:#1f282029;transform:scale(1.08)}.composer-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;border-top:1px solid rgba(91,138,100,.16);padding-top:16px}.composer-accepted{display:flex;flex-wrap:wrap;align-items:center;gap:8px;min-width:0}.composer-accepted-label{font-size:13px;color:var(--ink-soft)}.composer-accepted-hint{font-size:13px;color:var(--ink-muted)}.accepted-chip{display:inline-flex;align-items:center;gap:6px;background:var(--moss-100);color:var(--moss-900);border-radius:var(--radius-pill);padding:4px 6px 4px 12px;font-size:13px;font-weight:500}.accepted-chip button{border:none;background:#1f40291f;color:var(--moss-900);width:18px;height:18px;border-radius:50%;cursor:pointer;font-size:11px;line-height:1}.accepted-chip button:hover{background:#1f402938}.suggestions{transition:opacity .22s ease,filter .22s ease}.suggestions.is-dimmed{opacity:.45;filter:saturate(.7)}.suggestions-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}.suggestions-hint{font-size:12.5px;color:var(--ink-muted)}.suggestions-scroll{display:flex;gap:14px;overflow-x:auto;padding:4px 2px 12px;scroll-snap-type:x mandatory}.suggestion-card{position:relative;flex:0 0 200px;scroll-snap-align:start;text-align:left;background:var(--surface);border:1px solid rgba(91,138,100,.2);border-radius:var(--radius-md);padding:16px;cursor:pointer;display:flex;flex-direction:column;gap:8px;transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease}.suggestion-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card);border-color:var(--moss-500)}.suggestion-card.is-active{border-color:var(--moss-500);box-shadow:0 0 0 3px #5b8a6433}.suggestion-rank{position:absolute;top:12px;right:14px;font-size:12px;font-weight:700;color:var(--bloom)}.suggestion-motif{display:inline-flex}.suggestion-name{font-family:var(--serif);font-size:18px;color:var(--ink-deep)}.suggestion-desc{font-size:13px;color:var(--ink-soft);line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.reflections-section .section-label{margin-bottom:12px}.reflection-strip{display:flex;gap:14px;overflow-x:auto;padding:4px 2px 12px}.reflection-chip{flex:0 0 150px;text-align:center;background:var(--surface);border:1px solid rgba(91,138,100,.18);border-radius:var(--radius-md);padding:14px 12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:8px;transition:transform .14s ease,box-shadow .14s ease}.reflection-chip:hover{transform:translateY(-3px);box-shadow:var(--shadow-card)}.reflection-chip-sticker{width:72px;height:72px;display:flex;align-items:center;justify-content:center}.reflection-chip-sticker img{width:100%;height:100%;object-fit:contain}.reflection-chip-title{font-size:13.5px;font-weight:600;color:var(--ink-deep);line-height:1.35}.reflection-chip-date{font-size:12px;color:var(--ink-muted)}.reflection-modal .modal-body{display:flex;flex-direction:column;gap:16px}.reflection-sticker{width:64px;height:64px;object-fit:contain}.reflection-tags{display:flex;flex-wrap:wrap;gap:8px}.reflection-tag{display:inline-flex;align-items:center;gap:6px;background:var(--moss-100);color:var(--moss-900);border-radius:var(--radius-pill);padding:4px 12px 4px 8px;font-size:13px;font-weight:500}.reflection-body{font-family:var(--serif);font-size:16px;line-height:1.7;color:var(--ink)}.reflection-body p{margin:0 0 12px}.strength-card{position:relative}.strength-rank{position:absolute;top:12px;left:14px;font-size:12px;font-weight:700;color:var(--bloom)}.gallery-header-actions{display:flex;flex-direction:column;gap:6px;align-items:flex-end;white-space:nowrap}@media (max-width: 640px){.journal-head,.composer-foot{flex-direction:column;align-items:stretch}.journal-head-actions,.gallery-header-actions{align-items:flex-start}}.composer-grid{display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:20px;align-items:start}.composer-main{min-width:0;display:flex;flex-direction:column;gap:14px}.hl-active{background:#e9b76099!important;box-shadow:0 0 0 2px #d89a7ab3!important}.prompt-strip{display:flex;align-items:center;gap:10px;min-width:0}.prompt-strip-label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted);white-space:nowrap;flex-shrink:0}.prompt-strip-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;min-width:0;max-width:100%}.prompt-strip-scroll .prompt-pill{flex-shrink:0;white-space:nowrap}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.prompt-strip-scroll .prompt-pill,.suggestion-feed .feed-item{animation:fade-in var(--fade-ms, 1s) ease both}.prompt-strip-scroll,.suggestion-feed{scrollbar-width:none;-ms-overflow-style:none}.prompt-strip-scroll::-webkit-scrollbar,.suggestion-feed::-webkit-scrollbar{display:none}.composer-accepted-note{font-size:13px;color:var(--moss-700);font-weight:500}.composer-aside{position:sticky;top:16px;background:var(--surface-soft);border:1px solid rgba(91,138,100,.18);border-radius:var(--radius-md);padding:16px;max-height:calc(100vh - 140px);overflow-y:auto}.aside-heading{margin:0 0 4px;font-size:14px;color:var(--ink-deep)}.aside-subhead{margin:0 0 12px;font-size:12px;color:var(--ink-muted);line-height:1.45}.aside-empty{margin:0;font-size:13px;color:var(--ink-muted);line-height:1.5}.strip-block{display:flex;flex-direction:column;gap:8px;min-width:0}.strip-head{display:flex;align-items:center;justify-content:space-between;gap:8px;min-height:24px}.strip-label{font-size:12px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted)}.jump-latest{border:none;background:var(--moss-100);color:var(--moss-900);border-radius:var(--radius-pill);padding:4px 12px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;animation:jump-in .16s ease}.jump-latest:hover{background:var(--moss-300)}@keyframes jump-in{0%{opacity:0;transform:translateY(-2px)}}.suggestion-feed{list-style:none;margin:0;padding:0 0 6px;display:flex;gap:10px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;min-width:0;max-width:100%}.suggestion-feed::-webkit-scrollbar{display:none}.feed-item{flex:0 0 240px;display:flex;flex-direction:column;justify-content:space-between;gap:8px;padding:11px 12px;background:var(--surface-raised);border:1px solid rgba(233,183,96,.45);border-radius:var(--radius-sm);transition:border-color .14s ease,box-shadow .14s ease,transform .14s ease;cursor:default}.feed-item.is-active{border-color:var(--sun);box-shadow:0 0 0 3px #e9b76047}.feed-item.is-accepted{border-color:#5b8a6480;background:var(--moss-100)}.feed-main{display:flex;flex-direction:column;gap:3px;min-width:0}.feed-name{font-weight:600;color:var(--moss-900);font-size:14px;overflow-wrap:anywhere}.feed-reason{font-size:12px;color:var(--ink-muted);overflow-wrap:anywhere}.feed-quote{font-size:12.5px;color:var(--ink-soft);font-style:italic;line-height:1.4;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.feed-actions{display:flex;gap:8px;align-items:center}.feed-accept,.feed-reject{width:28px;height:28px;border-radius:50%;border:none;cursor:pointer;font-size:13px;line-height:1;transition:transform .12s ease,background .12s ease}.feed-accept{background:var(--moss-500);color:#fff}.feed-accept:hover{background:var(--moss-700);transform:scale(1.08)}.feed-reject{background:#1f282014;color:var(--ink-soft)}.feed-reject:hover{background:#1f282029;transform:scale(1.08)}.feed-undo{border:none;background:transparent;color:var(--moss-700);font-size:13px;font-weight:600;cursor:pointer;padding:2px 0}.feed-undo:hover{text-decoration:line-through;color:var(--ink-soft)}.strength-card .strength-buttons{display:flex;gap:8px;margin-top:14px;width:100%}.card-btn{flex:1;border-radius:var(--radius-pill);padding:8px 10px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background .14s ease,border-color .14s ease,color .14s ease}.card-btn-ghost{background:transparent;border-color:#5b8a6459;color:var(--ink-soft)}.card-btn-ghost:hover:not(:disabled){background:var(--moss-100);color:var(--moss-900)}.card-btn-ghost:disabled{opacity:.5;cursor:default}.card-btn-primary{background:var(--moss-700);color:#fff}.card-btn-primary:hover{background:var(--moss-900)}.hl-body{font-family:var(--serif);font-size:16px;line-height:1.7;color:var(--ink);white-space:pre-wrap;word-wrap:break-word}.hl-body-mark{background:#5b8a6447;border-radius:4px;color:inherit;box-decoration-break:clone;-webkit-box-decoration-break:clone}.reflection-cards{display:flex;flex-direction:column;gap:18px}.reflection-card{border:1px solid rgba(91,138,100,.16);border-radius:var(--radius-md);padding:16px;background:var(--surface-raised)}.reflection-card-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}.reflection-card-head strong{display:block;color:var(--ink-deep);font-size:15px}.reflection-card-head span{font-size:12.5px;color:var(--ink-muted)}.reflection-card-sticker{width:44px;height:44px;object-fit:contain}@media (max-width: 860px){.composer-grid{grid-template-columns:1fr}.composer-aside{position:static;max-height:none}}.anim-panel{border-top:1px solid rgba(91,138,100,.16);padding-top:12px;font-size:13px}.anim-panel>summary{cursor:pointer;color:var(--ink-soft);font-weight:600;list-style:none;-webkit-user-select:none;user-select:none}.anim-panel>summary::-webkit-details-marker{display:none}.anim-panel>summary:hover{color:var(--moss-700)}.anim-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px 20px;margin-top:12px;align-items:end}.anim-field{display:flex;flex-direction:column;gap:6px}.anim-field>span{color:var(--ink-soft);display:flex;justify-content:space-between;gap:8px}.anim-field>span b{color:var(--moss-700);font-variant-numeric:tabular-nums}.anim-field input[type=range]{width:100%;accent-color:var(--moss-500)}.anim-field select{padding:6px 8px;border:1px solid rgba(91,138,100,.3);border-radius:var(--radius-sm);background:var(--surface-raised);color:var(--ink);font:inherit}.anim-reset{align-self:end;justify-self:start;border:1px solid rgba(91,138,100,.35);background:transparent;color:var(--ink-soft);border-radius:var(--radius-pill);padding:7px 16px;font-size:12.5px;font-weight:600;cursor:pointer}.anim-reset:hover{background:var(--moss-100);color:var(--moss-900)}.sticker-studio{margin-top:20px;border-top:2px solid rgba(91,138,100,.2);padding-top:18px;display:flex;flex-direction:column;gap:22px;animation:fade-in .4s ease both}.studio-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.studio-title{margin:0 0 4px;font-family:var(--serif);font-size:20px;color:var(--ink-deep)}.studio-sub{margin:0;font-size:13.5px;color:var(--ink-soft);max-width:60ch}.studio-section{display:flex;flex-direction:column;gap:10px}.studio-step{margin:0;font-size:13px;font-weight:700;color:var(--moss-700);letter-spacing:.01em}.studio-empty{margin:0;font-size:13px;color:var(--ink-muted)}.studio-strengths{display:flex;flex-wrap:wrap;gap:8px}.studio-strength{display:inline-flex;align-items:center;gap:8px;padding:7px 14px 7px 10px;border-radius:var(--radius-pill);border:1px solid rgba(91,138,100,.3);background:var(--surface-raised);color:var(--ink);font-size:13.5px;font-weight:500;cursor:pointer;transition:border-color .14s ease,background .14s ease}.studio-strength.is-on{border-color:var(--moss-500);background:var(--moss-100);color:var(--moss-900)}.studio-photos{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.studio-upload{display:inline-flex;align-items:center;justify-content:center;height:64px;padding:0 16px;border-radius:var(--radius-md);border:1.5px dashed rgba(91,138,100,.45);color:var(--moss-700);font-size:13.5px;font-weight:600;cursor:pointer;background:var(--surface)}.studio-upload input{display:none}.studio-thumb{width:64px;height:64px;border-radius:var(--radius-sm);overflow:hidden;border:2px solid transparent;padding:0;cursor:pointer;background:none}.studio-thumb.is-on{border-color:var(--moss-500)}.studio-thumb img{width:100%;height:100%;object-fit:cover;display:block}.studio-crop{display:flex;gap:16px;flex-wrap:wrap;align-items:flex-start}.crop-area{position:relative;display:inline-block;max-width:360px;line-height:0;touch-action:none;cursor:crosshair;border-radius:var(--radius-sm);overflow:hidden;border:1px solid rgba(91,138,100,.25)}.crop-area img{width:100%;height:auto;display:block;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.crop-sel{position:absolute;border:2px solid var(--sun);background:#e9b76038;pointer-events:none}.crop-actions{display:flex;flex-direction:column;gap:8px;max-width:220px}.crop-hint{margin:0;font-size:12.5px;color:var(--ink-muted)}.studio-compose{display:flex;gap:18px;flex-wrap:wrap;align-items:flex-start}.sticker-stage{position:relative;flex-shrink:0;background:repeating-conic-gradient(#efe7d4,#efe7d4 25%,#f7f2e6 0%,#f7f2e6 50%) 50% / 24px 24px;border:1px solid rgba(91,138,100,.3);border-radius:var(--radius-md);overflow:hidden;touch-action:none}.stage-el{position:absolute;cursor:grab;-webkit-user-select:none;user-select:none;-webkit-user-drag:none;filter:drop-shadow(0 2px 4px rgba(31,40,32,.25))}.stage-el.is-selected{outline:2px solid var(--moss-500);outline-offset:1px}.stage-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;text-align:center;padding:24px;color:var(--ink-muted);font-size:13px;pointer-events:none}.stage-controls{display:flex;flex-direction:column;gap:10px;min-width:180px}.stage-size{display:flex;flex-direction:column;gap:6px;font-size:13px;color:var(--ink-soft)}.stage-size input{accent-color:var(--moss-500)}.studio-styles{display:flex;flex-wrap:wrap;gap:10px}.style-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px;width:92px;border-radius:var(--radius-md);border:2px solid transparent;background:var(--surface-raised);cursor:pointer;font-size:12.5px;color:var(--ink-soft)}.style-card.is-on{border-color:var(--moss-500);color:var(--moss-900)}.style-thumb{width:100%;height:64px;border-radius:var(--radius-sm);overflow:hidden;display:block;border:1px solid rgba(91,138,100,.18)}.style-thumb img{width:100%;height:100%;object-fit:cover;display:block}.style-swatch{width:100%;height:100%;display:block}.photo-list{display:flex;flex-direction:column;gap:12px;margin-top:8px}.photo-assets{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.asset{width:88px;padding:0 0 4px;border:1px solid rgba(91,138,100,.25);border-radius:var(--radius-sm);background:var(--surface-raised);cursor:pointer;overflow:hidden;display:flex;flex-direction:column;align-items:center;transition:border-color .14s ease,transform .14s ease}.asset:hover{border-color:var(--moss-500);transform:translateY(-2px)}.asset img{width:88px;height:66px;object-fit:cover;display:block;background:#fff}.asset span{font-size:11.5px;color:var(--ink-soft);padding-top:4px}.asset-note{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-muted)}.studio-prompt{width:100%;border:1px solid rgba(91,138,100,.3);border-radius:var(--radius-md);padding:10px 12px;font:inherit;font-size:14px;resize:vertical;background:var(--surface-raised);color:var(--ink)}.studio-prompt:focus{outline:none;border-color:var(--moss-500);box-shadow:0 0 0 4px #5b8a6429}.studio-generate{flex-direction:row;align-items:center;gap:18px;flex-wrap:wrap}.studio-preview{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--moss-700)}.studio-preview img{width:96px;height:96px;object-fit:contain;border-radius:var(--radius-sm);background:var(--surface-raised);border:1px solid rgba(91,138,100,.2)}@media (max-width: 600px){.studio-head{flex-direction:column}}
