:root{--bg: #0b0b0d;--bg-2: #131319;--ivory: #f5f1ea;--muted: #9a958c;--line: rgba(245, 241, 234, .1);--accent: #c9a96a;--plumbob: #7be07b;--accent-soft: rgba(201, 169, 106, .16);--heart: #d8455f;--glass: rgba(255, 255, 255, .04);--glass-2: rgba(255, 255, 255, .06);--radius: 22px;--ease: cubic-bezier(.22, 1, .36, 1);--serif: "Georgia", "Times New Roman", serif;--sans: -apple-system, BlinkMacSystemFont, "SF Pro Display", "Inter", "Segoe UI", Roboto, Helvetica, Arial, sans-serif}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0}body{background:var(--bg);color:var(--ivory);font-family:var(--sans);overflow-x:hidden;-webkit-font-smoothing:antialiased}.stage{position:relative;min-height:100dvh;display:flex;flex-direction:column;padding:max(24px,env(safe-area-inset-top)) 22px max(28px,env(safe-area-inset-bottom));background:radial-gradient(120% 80% at 50% -10%,rgba(201,169,106,.1),transparent 55%),radial-gradient(100% 60% at 50% 110%,rgba(216,69,95,.08),transparent 60%),var(--bg);overflow:hidden}.stage:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.5;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E")}.center{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:18px}.kicker{font-size:12px;letter-spacing:.38em;text-transform:uppercase;color:var(--accent);font-weight:600}.title{font-size:34px;line-height:1.08;font-weight:700;letter-spacing:-.02em;margin:0}.wordmark{font-size:15px;letter-spacing:.7em;text-transform:uppercase;color:var(--ivory);opacity:.92;font-weight:600;padding-left:.7em}.narrator{font-family:var(--serif);font-size:22px;line-height:1.5;color:var(--ivory);max-width:22ch}.muted{color:var(--muted);font-size:14px;line-height:1.5}.serif{font-family:var(--serif)}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;cursor:pointer;font-family:var(--sans);font-weight:600;font-size:16px;letter-spacing:.01em;padding:17px 26px;border-radius:100px;color:#171310;background:linear-gradient(180deg,#e6cf9c,var(--accent));box-shadow:0 10px 30px #c9a96a47;transition:transform .18s var(--ease),box-shadow .18s var(--ease),opacity .18s var(--ease);width:100%;max-width:340px}.btn:active{transform:scale(.97)}.btn.ghost{background:var(--glass);color:var(--ivory);border:1px solid var(--line);box-shadow:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.btn.pulse{animation:pulse 2.4s var(--ease) infinite}.btn:disabled{opacity:.4;cursor:default}.card{width:100%;border-radius:var(--radius);background:var(--glass);border:1px solid var(--line);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:20px}.mission-card{display:flex;align-items:center;gap:16px;padding:18px;text-align:left;transition:transform .25s var(--ease),border-color .25s var(--ease),opacity .4s var(--ease)}.mission-card.locked{opacity:.42;filter:blur(.3px)}.mission-card.active{border-color:var(--accent);background:linear-gradient(180deg,var(--accent-soft),rgba(255,255,255,.03));box-shadow:0 12px 40px #c9a96a24}.mission-card.done{border-color:#c9a96a4d}.mission-card:active{transform:scale(.985)}.mc-icon{width:52px;height:52px;flex:0 0 52px;border-radius:15px;display:grid;place-items:center;font-size:24px;background:var(--glass-2);border:1px solid var(--line)}.mc-body{flex:1;min-width:0}.mc-label{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}.mc-name{font-size:17px;font-weight:700;letter-spacing:.01em;margin-top:2px}.mc-sub{font-size:12.5px;color:var(--muted);margin-top:3px}.mc-lock{font-size:16px;opacity:.7}.dots{display:flex;gap:8px;align-items:center;justify-content:center}.dot{width:7px;height:7px;border-radius:50%;background:var(--line);transition:all .4s var(--ease)}.dot.on{background:var(--accent);box-shadow:0 0 12px var(--accent);transform:scale(1.15)}.dot.cur{width:20px;border-radius:5px;background:var(--ivory)}.heartwrap{display:flex;align-items:center;gap:12px;width:100%}.heartbar{flex:1;height:9px;border-radius:100px;background:var(--glass-2);overflow:hidden;border:1px solid var(--line)}.heartfill{height:100%;border-radius:100px;background:linear-gradient(90deg,#b8324a,var(--heart),#ff7a91);box-shadow:0 0 16px #d8455f99;transition:width 1s var(--ease)}.heart-emoji{font-size:16px;filter:drop-shadow(0 0 8px rgba(216,69,95,.7))}.heart-pct{font-size:12px;color:var(--muted);min-width:34px;text-align:right}.char{display:flex;flex-direction:column;align-items:center;gap:12px}.char-frame{position:relative;width:168px;height:168px;border-radius:28px;padding:4px;background:linear-gradient(160deg,var(--accent),rgba(201,169,106,.2));box-shadow:0 20px 60px #00000080,0 0 40px #c9a96a2e}.char-frame.small{width:108px;height:108px;border-radius:20px}.char-photo{width:100%;height:100%;border-radius:24px;object-fit:cover;filter:contrast(1.08) saturate(1.05) brightness(1.02)}.char-frame.small .char-photo{border-radius:16px}.char-photo.placeholder{display:grid;place-items:center;background:var(--glass-2);font-size:40px;color:var(--muted)}.plumbob{position:absolute;top:-16px;left:50%;transform:translate(-50%);width:20px;height:30px;filter:drop-shadow(0 0 10px var(--accent));animation:bob 3s ease-in-out infinite}.char-name{font-size:18px;font-weight:700;letter-spacing:.02em}.char-role{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--accent)}.achievement{position:fixed;top:max(18px,env(safe-area-inset-top));left:50%;transform:translate(-50%);z-index:50;display:flex;align-items:center;gap:12px;padding:12px 18px 12px 12px;border-radius:18px;background:#14141adb;border:1px solid var(--accent);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 16px 50px #0009;animation:dropIn .5s var(--ease);max-width:90vw}.ach-ic{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:20px;background:var(--accent-soft)}.ach-k{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent)}.ach-t{font-size:15px;font-weight:700}.xp-pill{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:100px;background:var(--accent-soft);border:1px solid rgba(201,169,106,.3);color:var(--accent);font-weight:700;font-size:15px}.inv{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}.inv-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px;border-radius:16px;background:var(--glass);border:1px solid var(--line);min-width:84px}.inv-ic{font-size:26px}.inv-lb{font-size:11px;color:var(--muted);text-align:center}.postcard{width:100%;border-radius:var(--radius);padding:26px 22px;background:linear-gradient(160deg,#17131b,#0e0e13);border:1px solid var(--accent);box-shadow:0 24px 70px #0009;text-align:center}.letter{white-space:pre-wrap;font-family:var(--serif);font-size:17px;line-height:1.6;text-align:left}.stack{display:flex;flex-direction:column;gap:12px;width:100%;align-items:center}.grow{flex:1}.row{display:flex;gap:10px;width:100%}.topbar{display:flex;flex-direction:column;gap:12px;padding-bottom:8px}.cursor{display:inline-block;width:2px;height:1.05em;background:var(--accent);margin-left:3px;vertical-align:-.15em;animation:blink 1s step-end infinite}.fade-up{animation:fadeUp .6s var(--ease) both}.link-btn{background:none;border:none;color:var(--muted);font-size:12px;text-decoration:underline;cursor:pointer;font-family:var(--sans)}@keyframes fadeUp{0%{opacity:0;transform:translateY(14px);filter:blur(6px)}to{opacity:1;transform:none;filter:none}}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 10px 30px #c9a96a47}50%{transform:scale(1.03);box-shadow:0 14px 44px #c9a96a73}}@keyframes bob{0%,to{transform:translate(-50%) translateY(0) rotate(0)}50%{transform:translate(-50%) translateY(-5px) rotate(8deg)}}@keyframes dropIn{0%{opacity:0;transform:translate(-50%) translateY(-24px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes blink{50%{opacity:0}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glowpulse{0%,to{opacity:.5}50%{opacity:1}}.flash{animation:flash .8s var(--ease)}@keyframes flash{0%{opacity:0;transform:scale(.6)}40%{opacity:1;transform:scale(1.06)}to{transform:scale(1)}}.relbar-label{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}.cipher{font-family:SF Mono,ui-monospace,Menlo,monospace;font-size:26px;letter-spacing:.32em;color:var(--accent);padding:16px 18px;border-radius:16px;background:var(--glass-2);border:1px dashed rgba(201,169,106,.4);text-align:center}.coords{font-family:SF Mono,ui-monospace,Menlo,monospace;font-size:22px;letter-spacing:.06em;color:var(--plumbob);padding:16px 18px;border-radius:16px;background:#7be07b14;border:1px solid rgba(123,224,123,.3);text-align:center;text-shadow:0 0 20px rgba(123,224,123,.4)}.field{width:100%;max-width:340px;font-family:var(--sans);font-size:17px;color:var(--ivory);padding:15px 18px;border-radius:16px;background:var(--glass-2);border:1px solid var(--line);outline:none;text-align:center;transition:border-color .2s var(--ease)}.field:focus{border-color:var(--accent)}.field.shake{animation:shake .4s var(--ease);border-color:var(--heart)}.err{color:var(--heart);font-size:13px}.proof{width:100%;max-width:300px;border-radius:16px;border:1px solid var(--plumbob);box-shadow:0 8px 30px #00000080}.reveal{display:flex;flex-direction:column;align-items:center;gap:12px}.reveal-ic{width:96px;height:96px;border-radius:26px;display:grid;place-items:center;font-size:48px;background:var(--accent-soft);border:1px solid rgba(201,169,106,.4);box-shadow:0 0 40px #c9a96a40}.reveal-lb{font-size:14px;letter-spacing:.06em;color:var(--accent)}.photo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.photo-cell{display:flex;flex-direction:column;gap:4px;align-items:center;text-decoration:none;color:var(--muted);cursor:pointer}.photo-cell img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px;border:1px solid var(--line)}.photo-cell span{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}.gate-clock{font-family:SF Mono,ui-monospace,Menlo,monospace;font-size:52px;font-weight:700;letter-spacing:.04em;color:var(--accent);text-shadow:0 0 30px rgba(201,169,106,.4);margin:6px 0}.countdown{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:4px;padding:8px 14px;border-radius:100px;background:var(--glass-2);border:1px solid var(--line)}.cd-label{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}.cd-clock{font-family:SF Mono,ui-monospace,Menlo,monospace;font-size:17px;font-weight:700;color:var(--accent);letter-spacing:.06em}.countdown.live{color:var(--plumbob);font-weight:700;font-size:13px;letter-spacing:.08em;border-color:#7be07b66}.cd-dot{width:8px;height:8px;border-radius:50%;background:var(--plumbob);box-shadow:0 0 10px var(--plumbob);animation:glowpulse 1.2s ease-in-out infinite}.mc-time{color:var(--accent);font-weight:600}.task-card{width:100%;max-width:340px;padding:16px 18px;border-radius:16px;background:linear-gradient(180deg,var(--accent-soft),rgba(255,255,255,.03));border:1px solid rgba(201,169,106,.4);font-size:15px;line-height:1.5;color:var(--ivory);text-align:center}.couple{display:flex;align-items:center;justify-content:center;gap:6px}.couple-card{transform:scale(.92)}.couple-heart{font-size:22px;filter:drop-shadow(0 0 10px rgba(216,69,95,.7));animation:glowpulse 2s ease-in-out infinite;margin:0 -2px}.slide-in{animation:slideIn .7s var(--ease) both}@keyframes slideIn{0%{opacity:0;transform:translate(40px) scale(.8)}to{opacity:1;transform:translate(0) scale(.92)}}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}@media (prefers-reduced-motion: reduce){*{animation-duration:1ms!important;transition-duration:1ms!important}}
