@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Playfair+Display:wght@600;700&display=swap";:root{--bg-deep:#fff1f7;--bg-soft:#f4ffe9;--text-main:#372234;--text-muted:#372234ad;--accent:#7fbf7b;--accent-strong:#ff8fc7;--danger:#d9466f;--card:#ffffff94;--border:#694f632e}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{background:var(--bg-deep);color:var(--text-main);font-family:Inter,system-ui,sans-serif}button,input{font:inherit}button{-webkit-tap-highlight-color:transparent}input{min-width:0}.page{background:radial-gradient(circle at 18% 16%,#ff8fc761,#0000 32%),radial-gradient(circle at 82% 24%,#aadf8457,#0000 34%),radial-gradient(circle at 50% 92%,#ffd6e88c,#0000 38%),linear-gradient(160deg,#fff1f7 0%,#f7ffe9 54%,#ffe6f1 100%);align-items:flex-end;min-height:100vh;padding:3rem 1.35rem 4rem;display:flex;position:relative;overflow:hidden}.page:after{content:"";pointer-events:none;background-image:linear-gradient(#ffffff06 1px,#0000 1px),linear-gradient(90deg,#ffffff06 1px,#0000 1px);background-size:44px 44px;position:absolute;inset:0;-webkit-mask-image:linear-gradient(#0000,#000 25% 75%,#0000);mask-image:linear-gradient(#0000,#000 25% 75%,#0000)}.page-content{z-index:2;width:100%;max-width:720px;margin:0 auto;position:relative}.ambient{filter:blur(45px);opacity:.45;pointer-events:none;border-radius:999px;position:absolute}.ambient-one{background:#ff8fc76b;width:280px;height:280px;top:8%;left:-90px}.ambient-two{background:#97d67a5c;width:240px;height:240px;bottom:18%;right:-90px}.eyebrow{color:var(--accent);letter-spacing:.16em;text-transform:uppercase;margin:0 0 .85rem;font-size:.8rem;font-weight:700}h1{letter-spacing:-.055em;margin:0 0 1.35rem;font-family:Playfair Display,Georgia,serif;font-size:clamp(3rem,13vw,6.5rem);line-height:.92}.lede{color:var(--text-muted);margin:0 0 2rem;font-size:clamp(1.1rem,4vw,1.45rem);line-height:1.45}.gate{margin-top:2rem}.prompt{margin:0 0 1rem;font-size:clamp(1.1rem,4vw,1.35rem);line-height:1.35}.gate input{border:1px solid var(--border);color:#111827;background:#fffffff2;border-radius:22px;outline:none;width:100%;margin-bottom:.9rem;padding:1.05rem 1.1rem;font-size:1rem}.gate input:focus{border-color:var(--accent);box-shadow:0 0 0 4px #7dd3fc2e}.primary-button{color:#372234;cursor:pointer;background:linear-gradient(135deg,#ff9acb,#9bd783);border:0;border-radius:22px;width:100%;padding:1.05rem 1.15rem;font-size:1.05rem;font-weight:800;box-shadow:0 18px 40px #ff8fc738}.hint-button{border:1px solid var(--border);background:var(--card);width:100%;color:var(--text-main);cursor:pointer;border-radius:18px;margin-top:.85rem;padding:.9rem 1rem}.hint,.error{margin:.9rem 0 0;line-height:1.45}.hint{color:var(--text-muted)}.error{color:var(--danger);font-weight:700}@media (width>=760px){.page{align-items:center;padding:5rem}}.home-grid{gap:1rem;margin-top:2rem;display:grid}.memory-card{border:1px solid var(--border);background:var(--card);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border-radius:26px;padding:1.1rem}.memory-card.locked{opacity:.48}.memory-card-top{justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.8rem;display:flex}.memory-emoji{font-size:2rem}.memory-status{letter-spacing:.12em;text-transform:uppercase;color:#7fbf7b;font-size:.75rem;font-weight:800}.memory-card h2{margin:0 0 .5rem;font-size:1.45rem}.memory-card p{color:var(--text-muted);margin:0 0 1rem;line-height:1.45}.secondary-button{border:1px solid var(--border);width:100%;color:var(--text-main);cursor:pointer;background:#ffffff1a;border-radius:18px;padding:.95rem 1rem;font-weight:800}.secondary-button.disabled{cursor:not-allowed}@media (width>=760px){.home-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.mystery-card .memory-emoji{width:2.2rem;height:2.2rem;color:var(--text-main);background:#ffffff73;border-radius:999px;justify-content:center;align-items:center;font-weight:900;display:inline-flex}.reveal-section{margin-top:2rem}.reveal-image{border:1px solid var(--border);border-radius:26px;width:100%;margin-bottom:1rem;box-shadow:0 20px 50px #0000001f}.reveal-text{margin-bottom:1rem}.warning-box{color:var(--text-main);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#fff9b56b;border:1px solid #ff8fc747;border-radius:20px;margin:3rem 0 1rem;padding:1rem 1.1rem;font-size:.95rem;line-height:1.45}.home-link-button{border:1px solid var(--border);width:100%;color:var(--text-main);cursor:pointer;background:#ffffff5c;border-radius:18px;margin-top:1.25rem;padding:.95rem 1rem;font-weight:800}.unlock-toast{z-index:20;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffc2;border:1px solid #ff8fc757;border-radius:24px;align-items:center;gap:.9rem;padding:1rem 1.1rem;display:flex;position:fixed;top:1rem;left:1rem;right:1rem;box-shadow:0 20px 50px #ff8fc73d}.unlock-toast-emoji{font-size:2rem}.unlock-toast-label{color:var(--text-muted);letter-spacing:.12em;text-transform:uppercase;margin:0;font-size:.78rem;font-weight:800}.unlock-toast-title{color:var(--text-main);margin:.1rem 0 0;font-size:1.1rem;font-weight:900}@media (width>=760px){.unlock-toast{width:min(420px,100vw - 2rem);top:1.5rem;left:50%;right:auto;transform:translate(-50%)}}
