@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=DM+Sans:wght@300;400;500&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--cream:#faf6f1;--parchment:#f0e8dc;--rose:#8b3a52;--rose-light:#c4768a;--rose-pale:#f4e4e9;--gold:#c4913a;--gold-light:#f0d9b5;--charcoal:#2c2320;--muted:#7a6b65;--white:#fff;--bubble-user:#8b3a52;--bubble-ai:#fff}body{background:var(--cream)}.app-wrap{font-family:DM Sans,sans-serif;color:var(--charcoal);background:var(--cream)}.app-wrap,.welcome{min-height:100vh;display:flex;flex-direction:column;align-items:center}.welcome{justify-content:center;padding:2rem;text-align:center;position:relative;overflow:hidden}.welcome:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 70% 50% at 30% 20%,rgba(196,145,58,.12) 0,transparent 60%),radial-gradient(ellipse 60% 60% at 70% 80%,rgba(139,58,82,.1) 0,transparent 60%);pointer-events:none}.welcome-inner{max-width:580px;position:relative;z-index:1;animation:fadeUp .8s ease both}.logo-tag{display:inline-block;background:var(--gold-light);color:var(--gold);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;font-weight:500;padding:.35rem .9rem;border-radius:100px;margin-bottom:1.8rem}.welcome h1{font-family:Cormorant Garamond,serif;font-size:clamp(2.4rem,6vw,3.6rem);font-weight:300;line-height:1.15;color:var(--charcoal);margin-bottom:1rem}.welcome h1 em{font-style:italic;color:var(--rose)}.welcome p{font-size:1.05rem;line-height:1.7;color:var(--muted);margin-bottom:2.5rem;font-weight:300}.welcome-steps{display:flex;gap:1.2rem;justify-content:center;margin-bottom:2.8rem;flex-wrap:wrap}.step-pill{background:var(--white);border:1px solid var(--parchment);border-radius:12px;padding:.8rem 1.2rem;text-align:left;min-width:150px;box-shadow:0 2px 8px rgba(44,35,32,.06)}.step-num{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:.3rem}.step-label{font-family:Cormorant Garamond,serif;font-size:1rem;color:var(--charcoal)}.btn-primary{background:var(--rose);color:var(--white);border:none;border-radius:100px;padding:1rem 2.8rem;font-family:DM Sans,sans-serif;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 20px rgba(139,58,82,.25)}.btn-primary:hover{background:#74304a;transform:translateY(-1px);box-shadow:0 6px 24px rgba(139,58,82,.35)}.btn-primary:active{transform:translateY(0)}.welcome-note{margin-top:1.6rem;font-size:.82rem;color:var(--muted)}.progress-wrap{position:-webkit-sticky;position:sticky;top:0;z-index:10;background:var(--cream);padding:1rem 0 .8rem;border-bottom:1px solid var(--parchment)}.progress-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.55rem}.progress-label{font-family:Cormorant Garamond,serif;font-size:1.2rem;font-weight:400;color:var(--charcoal)}.progress-meta{font-size:.75rem;color:var(--muted);letter-spacing:.03em}.progress-fill,.progress-track{display:none}.progress-steps{display:flex;gap:4px;margin-top:.55rem}.progress-step-dot{flex:1 1;height:4px;border-radius:100px;background:var(--parchment);transition:background .4s}.progress-step-dot.done{background:var(--rose-light)}.progress-step-dot.active{background:var(--rose)}.chat-wrap{width:100%;max-width:720px;min-height:100vh;display:flex;flex-direction:column;padding:0 1rem}.messages-area{flex:1 1;overflow-y:auto;padding:1.8rem 0 1rem;display:flex;flex-direction:column;gap:1.2rem;scrollbar-width:thin;scrollbar-color:var(--parchment) transparent}.msg-row{display:flex;animation:fadeUp .3s ease both}.msg-row.user{justify-content:flex-end}.msg-row.assistant{justify-content:flex-start}.msg-bubble{max-width:72%;padding:.9rem 1.2rem;border-radius:18px;line-height:1.65;font-size:.95rem}.msg-row.user .msg-bubble{background:var(--bubble-user);color:var(--white);border-bottom-right-radius:4px}.msg-row.assistant .msg-bubble{background:var(--bubble-ai);color:var(--charcoal);border:1px solid var(--parchment);border-bottom-left-radius:4px;box-shadow:0 2px 8px rgba(44,35,32,.06)}.typing-dots{display:flex;gap:5px;align-items:center;padding:.6rem .2rem}.typing-dots span{width:7px;height:7px;border-radius:50%;background:var(--rose-light);animation:bounce 1.2s ease infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}.input-area{padding:1rem 0 1.5rem;border-top:1px solid var(--parchment)}.input-row{display:flex;gap:.7rem;align-items:flex-end;background:var(--white);border:1.5px solid var(--parchment);border-radius:16px;padding:.6rem .6rem .6rem 1rem;transition:border-color .2s,box-shadow .2s}.input-row:focus-within{border-color:var(--rose-light);box-shadow:0 0 0 3px rgba(139,58,82,.08)}.chat-textarea{flex:1 1;border:none;outline:none;background:transparent;font-family:DM Sans,sans-serif;font-size:.95rem;color:var(--charcoal);resize:none;line-height:1.5;max-height:120px;min-height:24px}.chat-textarea::placeholder{color:var(--muted)}.send-btn{background:var(--rose);color:#fff;border:none;border-radius:10px;width:38px;height:38px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;flex-shrink:0}.send-btn:hover:not(:disabled){background:#74304a}.send-btn:disabled{opacity:.4;cursor:default}.context-screen{width:100%;max-width:620px;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:3rem 1.5rem;animation:fadeUp .5s ease both}.context-header{text-align:center;margin-bottom:2rem}.context-title{font-family:Cormorant Garamond,serif;font-size:clamp(1.8rem,4vw,2.4rem);font-weight:300;color:var(--charcoal);margin-bottom:.5rem}.context-title em{font-style:italic;color:var(--rose)}.context-sub{font-size:.9rem;color:var(--muted);line-height:1.6}.context-examples{display:flex;gap:.6rem;flex-wrap:wrap;justify-content:center;margin:1.2rem 0 1.8rem}.context-tag{background:var(--parchment);color:var(--muted);font-size:.75rem;padding:.3rem .8rem;border-radius:100px;border:1px solid var(--gold-light)}.context-textarea{width:100%;min-height:160px;border:1.5px solid var(--parchment);border-radius:14px;padding:1rem;font-family:DM Sans,sans-serif;font-size:.92rem;color:var(--charcoal);background:var(--white);resize:vertical;outline:none;line-height:1.6;transition:border-color .2s,box-shadow .2s;margin-bottom:1.2rem}.context-textarea:focus{border-color:var(--rose-light);box-shadow:0 0 0 3px rgba(139,58,82,.08)}.context-textarea::placeholder{color:var(--muted)}.context-actions{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}.btn-secondary{background:transparent;color:var(--muted);border:1.5px solid var(--parchment);border-radius:100px;padding:.85rem 2rem;font-family:DM Sans,sans-serif;font-size:.92rem;cursor:pointer;transition:border-color .2s,color .2s}.btn-secondary:hover{border-color:var(--rose-light);color:var(--charcoal)}.generating-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;padding:2rem;text-align:center}.gen-spinner{width:52px;height:52px;border:3px solid var(--parchment);border-top-color:var(--rose);border-radius:50%;animation:spin .9s linear infinite}.gen-title{font-family:Cormorant Garamond,serif;font-size:1.8rem;font-weight:300;color:var(--charcoal)}.gen-sub{font-size:.9rem;color:var(--muted)}.profile-screen{width:100%;max-width:680px;padding:2.5rem 1.5rem 4rem;animation:fadeUp .6s ease both}.profile-header{text-align:center;margin-bottom:2.5rem}.profile-badge{display:inline-block;background:#edf7f1;color:#3a8a5a;font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;font-weight:500;padding:.3rem .9rem;border-radius:100px;margin-bottom:1rem}.profile-title{font-family:Cormorant Garamond,serif;font-size:clamp(1.9rem,5vw,2.8rem);font-weight:300;line-height:1.2;color:var(--charcoal);margin-bottom:.5rem}.profile-title em{font-style:italic;color:var(--rose)}.profile-sub{font-size:.9rem;color:var(--muted)}.profile-card{background:var(--white);border:1px solid var(--parchment);border-radius:20px;padding:2.2rem;margin-bottom:1.2rem;box-shadow:0 4px 24px rgba(44,35,32,.06);position:relative}.profile-card-label{font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:500;margin-bottom:1rem}.profile-text{font-family:Cormorant Garamond,serif;font-size:1.18rem;line-height:1.8;color:var(--charcoal)}.copy-btn{position:absolute;top:1.2rem;right:1.2rem;background:var(--parchment);color:var(--muted);border:none;border-radius:8px;padding:.4rem .8rem;font-family:DM Sans,sans-serif;font-size:.75rem;cursor:pointer;transition:background .2s,color .2s}.copy-btn:hover{background:var(--gold-light);color:var(--charcoal)}.copy-btn.copied{background:#edf7f1;color:#3a8a5a}.profile-note{background:linear-gradient(135deg,#fbf0f3,#fdf6ee);border:1px solid #eacdd5;border-radius:16px;padding:1.8rem;margin-bottom:1.2rem;text-align:center}.profile-note-head{font-family:Cormorant Garamond,serif;font-size:1.3rem;font-weight:400;color:var(--charcoal);margin-bottom:.6rem}.profile-note p{font-size:.9rem;color:var(--muted);line-height:1.65;margin-bottom:1.4rem}.btn-cta{display:inline-block;background:var(--rose);color:var(--white);text-decoration:none;border-radius:100px;padding:.85rem 2.2rem;font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:500;transition:background .2s,box-shadow .2s;box-shadow:0 4px 16px rgba(139,58,82,.22)}.btn-cta:hover{background:#74304a;box-shadow:0 6px 20px rgba(139,58,82,.32)}.restart-link{text-align:center;margin-top:1.5rem}.restart-link button{background:none;border:none;color:var(--muted);font-family:DM Sans,sans-serif;font-size:.85rem;cursor:pointer;text-decoration:underline;text-underline-offset:3px}.restart-link button:hover{color:var(--charcoal)}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-6px)}}@keyframes spin{to{transform:rotate(1turn)}}