@import url("https://fonts.googleapis.com/css2?family=Caveat:wght@500;700&family=Fraunces:opsz,wght@9..144,400;600;700&family=Inter:wght@400;500;600;700&display=swap");:root{--bg-dark:#1a0a0c;--bg-mid:#2d1216;--accent:#c4464e;--accent-soft:#e8888e;--paper:#fef8f0;--paper-warm:#fdf0e0;--paper-deep:#f5e4cf;--ink:#3a1f1c;--ink-soft:#6b413a;--cream:#fff9f2;--gold:#d4a355;--gold-light:#f0d49a;--rose:#c4464e;--radius-lg:24px;--radius-md:16px;--radius-sm:10px;--shadow-card:0 20px 60px rgba(0,0,0,.35);--shadow-soft:0 8px 24px rgba(0,0,0,.15);--transition:0.25s cubic-bezier(0.22,1,0.36,1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{min-height:100%}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-dark);background-image:radial-gradient(ellipse at 20% 0,rgba(196,70,78,.15) 0,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(196,70,78,.1) 0,transparent 50%);color:#faf5ef;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,textarea{font:inherit}.birthday-app{position:relative;min-height:100vh;display:grid;place-items:center;overflow:hidden;padding:32px}.pattern-overlay{position:absolute;inset:0;opacity:.04;background-image:radial-gradient(circle,hsla(0,0%,100%,.6) 1px,transparent 0);background-size:32px 32px;pointer-events:none}.pattern-overlay:after,.pattern-overlay:before{display:none}.glow{position:absolute;width:40vw;height:40vw;border-radius:50%;filter:blur(100px);opacity:.18;pointer-events:none}.glow-left{top:-10%;left:-10%;background:rgba(196,70,78,.6)}.glow-right{right:-10%;bottom:-10%;background:rgba(212,163,85,.4)}.screen-stage{position:relative;width:min(100%,960px)}.experience-card{position:relative;min-height:min(82vh,740px);border-radius:var(--radius-lg);padding:32px;background:hsla(0,0%,100%,.04);border:1px solid hsla(0,0%,100%,.08);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);overflow:hidden;box-shadow:var(--shadow-card)}.experience-card:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,hsla(0,0%,100%,.03),transparent 40%);pointer-events:none}.postcard-stage{display:grid;align-items:center}.postcard-stage.is-opened-stage{align-items:start}.hero-note,.letter-header{position:relative;z-index:1}.eyebrow{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.2em;color:var(--accent-soft);margin-bottom:12px}.hero-note h1,.letter-header h2{font-family:Fraunces,serif;font-size:clamp(2rem,5.5vw,3rem);line-height:1.05;color:#fff;margin-bottom:14px;font-weight:600}.cake-subline,.hero-copy{font-size:.92rem;line-height:1.7;color:rgba(255,248,240,.6)}.flip-scene{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;width:100%;min-height:100%;justify-content:center}.flip-scene.is-opened{justify-content:flex-start}.card-open-scene{position:relative;width:min(100%,420px);padding-top:10px}.card-open-scene.is-opened{padding-top:0}.card-cover-wrapper{position:relative;z-index:2;will-change:transform,opacity;transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.card-cover-wrapper.is-detached{position:absolute;top:10px;left:0;right:0}.card-cover-wrapper:after{content:"";position:absolute;left:18px;right:18px;bottom:-24px;height:28px;border-radius:999px;background:rgba(10,4,4,.28);filter:blur(14px);z-index:-1;opacity:1;transition:opacity .35s ease}.card-open-scene.is-opened .card-cover-wrapper:after{opacity:.24}.card-3d{position:relative;width:100%;aspect-ratio:3/4.2;border-radius:var(--radius-lg);border:none;padding:24px 22px;display:flex;flex-direction:column;align-items:center;text-align:center}.card-front{background:#fff;box-shadow:0 24px 60px rgba(0,0,0,.5),0 0 80px hsla(0,0%,100%,.06);overflow:hidden;transition:box-shadow .4s ease}.card-front:hover{box-shadow:0 28px 70px rgba(0,0,0,.55),0 0 90px hsla(0,0%,100%,.08)}.card-badge{position:absolute;top:16px;right:16px;padding:6px 14px;border-radius:999px;background:hsla(0,0%,100%,.85);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--accent);font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase}.card-cover-art{flex:1 1;display:grid;place-items:center;width:100%;margin:16px 0;border-radius:var(--radius-md);background:linear-gradient(160deg,var(--accent) 0,#8b2830 100%);overflow:hidden;position:relative}.card-panda{width:65%;height:auto;filter:drop-shadow(0 8px 16px rgba(0,0,0,.2));position:relative;z-index:1}.card-eyebrow{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.2em;color:var(--accent);margin-bottom:6px}.card-title{font-family:Fraunces,serif;font-size:clamp(1.6rem,4vw,2.2rem);color:var(--ink);font-weight:600;line-height:1.1;margin-bottom:8px}.card-subtitle{font-size:.82rem;color:var(--ink-soft);opacity:.7}.card-tap-hint{margin-top:8px}.tap-icon{display:inline-block;font-size:1.2rem;color:var(--accent);opacity:.5;animation:tap-pulse 2s ease-in-out infinite}@keyframes tap-pulse{0%,to{opacity:.3;transform:translate(0)}50%{opacity:.7;transform:translate(3px,-3px)}}.card-inside-content{position:relative;z-index:1;margin-top:0;display:flex;flex-direction:column;align-items:center;width:100%;max-width:520px;margin-left:auto;margin-right:auto;overflow:hidden;will-change:transform,opacity;transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.card-inside-paper{width:100%;background:var(--paper);border-radius:var(--radius-lg);padding:64px 28px 36px;box-shadow:var(--shadow-card);min-height:560px;position:relative}.card-inside-paper:before{content:"";position:absolute;inset:14px;border-radius:18px;border:1px solid rgba(58,31,28,.06);pointer-events:none}.inside-panda-area{display:flex;justify-content:center;margin-bottom:20px}.inside-panda-small{width:80px;height:auto;filter:drop-shadow(0 4px 8px rgba(0,0,0,.12))}.letter-eyebrow{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;color:var(--accent);margin-bottom:10px}.letter-title{font-family:Fraunces,serif;font-size:clamp(1.4rem,3.5vw,2rem);color:var(--ink);font-weight:600;line-height:1.1;margin-bottom:12px}.letter-date-row{display:flex;margin-bottom:16px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);opacity:.5}.mic-button,.open-button{width:min(100%,380px);border:none;border-radius:999px;margin:24px auto 0;padding:16px 20px;background:var(--accent);color:#fff;box-shadow:0 8px 24px rgba(196,70,78,.3);cursor:pointer;display:block;transition:var(--transition)}.mic-button:hover,.open-button:hover{background:#d45058;box-shadow:0 12px 32px rgba(196,70,78,.4);transform:translateY(-1px)}.mic-button,.open-button span{display:block;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.18em;opacity:.8}.open-button strong{display:block;margin-top:2px;font-size:.95rem;font-weight:600;opacity:1}.back-link,.secondary-link{border:none;background:transparent;color:rgba(255,248,240,.5);cursor:pointer;transition:color var(--transition)}.back-link:hover,.secondary-link:hover{color:rgba(255,248,240,.85)}.back-link{margin-bottom:16px;font-size:.78rem;font-weight:500;text-transform:uppercase;letter-spacing:.14em}.secondary-link{margin:18px auto 0;display:block;text-decoration:underline;text-underline-offset:4px;-webkit-text-decoration-color:rgba(255,248,240,.25);text-decoration-color:rgba(255,248,240,.25);font-size:.88rem}.cake-stage,.letter-stage{position:relative;z-index:1}.opened-postcard{position:relative;display:grid;grid-template-columns:1.1fr .9fr;margin-top:12px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);width:min(100%,860px);margin-left:auto;margin-right:auto}.postcard-spine{position:absolute;top:0;bottom:0;left:50%;width:1px;transform:translateX(-50%);background:rgba(0,0,0,.06);z-index:2}.postcard-spine-opened{z-index:3}.cake-panel,.letter-card,.note-paper{position:relative;background:var(--paper);color:var(--ink);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft)}.letter-card{padding:28px}.postcard-half{min-height:100%;border-radius:0;box-shadow:none;padding:32px}.postcard-half-accent{background:var(--paper-warm);border-left:1px solid rgba(0,0,0,.06)}.letter-header .eyebrow{color:var(--accent)}.letter-header h2{color:var(--ink);font-size:clamp(1.5rem,3.5vw,2.2rem)}.letter-card-top{display:flex;justify-content:space-between;gap:12px;margin-bottom:18px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-soft);opacity:.6}.letter-body{display:grid;grid-gap:14px;gap:14px;margin-top:20px}.handwritten-note p,.handwritten-note span,.letter-body p,.letter-body strong{font-family:Caveat,cursive}.letter-body p{font-size:clamp(1.6rem,2vw,2.2rem);line-height:1.1;color:var(--ink)}.letter-body strong{margin-top:6px;font-size:1.9rem;color:var(--accent)}.typewriter-line{min-height:1.25em}.typewriter-cursor{display:inline-block;margin-left:3px;color:var(--accent);animation:cursor-blink .95s steps(1) infinite}.mini-cover-art{position:relative;min-height:200px;margin-bottom:18px;border-radius:var(--radius-md);background:linear-gradient(160deg,var(--accent) 0,#8b2830 100%);overflow:hidden;display:grid;place-items:end center;padding:18px}.mini-cover-art p{position:relative;z-index:1;font-family:Fraunces,serif;color:#fff;font-size:1rem;font-weight:600}.mini-cover-heart,.mini-cover-heart:after,.mini-cover-heart:before{position:absolute;background:rgba(255,250,242,.15);border-radius:50%}.mini-cover-heart{width:72px;height:72px;border-radius:16px;transform:rotate(-45deg)}.mini-cover-heart:after,.mini-cover-heart:before{content:"";width:72px;height:72px}.mini-cover-heart:before{top:-34px;left:0}.mini-cover-heart:after{top:0;left:34px}.memory-list{display:grid;grid-gap:10px;gap:10px;margin-top:18px}.memory-pill{padding:14px 16px;border-radius:var(--radius-sm);line-height:1.55;font-size:.88rem}.memory-pill,.memory-pill-paper{background:rgba(0,0,0,.03);color:var(--ink-soft)}.memory-pill-paper{border:none}.cake-header{text-align:center}.cake-header h2{color:#fff;font-size:clamp(1.5rem,4vw,2.2rem)}.cake-header .eyebrow{color:var(--gold)}.cake-panel{margin-top:28px;padding:40px 28px 28px;width:min(100%,680px);margin-left:auto;margin-right:auto}.cake-panel-postcard{border:1px solid rgba(0,0,0,.04)}.cake-wrap{display:flex;flex-direction:column;align-items:center}.cake-figure-button{width:min(100%,520px);margin:0 auto;padding:0;border:none;background:transparent;cursor:default}.cake-figure-button.is-clickable{cursor:pointer}.cake-figure-stack{position:relative;width:100%;aspect-ratio:1/1}.cake-figure-image{position:absolute;inset:0;display:block;width:100%;height:100%;object-fit:contain;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none;filter:drop-shadow(0 18px 28px rgba(0,0,0,.12));pointer-events:none}.candles-row{display:flex;align-items:flex-end;gap:10px;z-index:2}.candle{position:relative;display:flex;flex-direction:column;align-items:center;border:none;background:transparent;padding:0}.candle-flame{position:relative;width:12px;height:20px;margin-bottom:-2px;border-radius:50% 50% 40% 40%;background:linear-gradient(180deg,#fff8c4,#ffb840 50%,#ff6b3d);box-shadow:0 0 18px rgba(255,138,61,.8),0 0 40px rgba(255,138,61,.3);transform-origin:bottom center;animation:flame-outer .7s ease-in-out infinite}.candle-flame-core{left:50%;top:5px;width:4px;height:8px;transform:translateX(-50%);background:#fff;animation:flame-inner .55s ease-in-out infinite}.candle-flame-core,.candle-smoke{position:absolute;border-radius:999px}.candle-smoke{top:-8px;width:6px;height:18px;background:hsla(0,0%,47%,.35);filter:blur(4px)}.candle-wick{width:1.5px;height:7px;background:var(--ink-soft);border-radius:999px}.candle-body{width:14px;height:40px;border-radius:4px 4px 2px 2px;box-shadow:inset -2px 0 0 hsla(0,0%,100%,.2)}.candle.is-out .candle-body{opacity:.45}.cake-top{position:relative;width:min(42vw,170px);height:66px;margin-top:-2px;border-radius:20px 20px 10px 10px;background:linear-gradient(180deg,#f4b870,#e89840);box-shadow:inset 0 -8px 0 rgba(200,120,30,.25)}.cake-bottom{position:relative;width:min(64vw,260px);height:108px;margin-top:-6px;border-radius:28px 28px 22px 22px;background:linear-gradient(180deg,#f5c378,#e09540);box-shadow:inset 0 -14px 0 rgba(190,110,30,.2),0 16px 28px rgba(0,0,0,.1);display:grid;place-items:center}.cake-bottom span{font-family:Fraunces,serif;font-size:clamp(1.4rem,4.5vw,2rem);color:#7a2028;font-weight:600}.icing-drips{position:absolute;inset:0}.icing-drips:after,.icing-drips:before{content:"";position:absolute;left:0;right:0;height:30px;background:radial-gradient(circle at 10% 0,var(--cream) 0 22px,transparent 23px),radial-gradient(circle at 28% 0,var(--cream) 0 20px,transparent 21px),radial-gradient(circle at 46% 0,var(--cream) 0 24px,transparent 25px),radial-gradient(circle at 65% 0,var(--cream) 0 18px,transparent 19px),radial-gradient(circle at 82% 0,var(--cream) 0 22px,transparent 23px)}.icing-drips-top:before{top:-6px}.icing-drips-bottom:before{top:-10px}.cake-plate{width:min(72vw,290px);height:14px;margin-top:-1px;border-radius:999px;background:linear-gradient(180deg,#e8ddd0,#c8bfb2);box-shadow:0 10px 24px rgba(0,0,0,.08)}.status-text{margin-top:20px;text-align:center;font-size:.88rem;color:rgba(255,248,240,.5)}.final-message{margin-top:24px;padding:22px;border-radius:var(--radius-md);background:hsla(0,0%,100%,.06);border:1px solid hsla(0,0%,100%,.08);text-align:center}.final-message p{line-height:1.65;color:rgba(255,248,240,.85);font-size:.95rem}.floating-hearts{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1}.floating-heart{top:0;color:rgba(255,214,224,.9);transform:translateZ(0);-webkit-backface-visibility:hidden;backface-visibility:hidden}.absolute,.floating-heart{position:absolute}.text-primary{color:rgba(255,214,224,.9)}.floating-heart-icon{display:block;filter:drop-shadow(0 2px 6px rgba(0,0,0,.12));-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-user-drag:none;pointer-events:none}@keyframes flame-outer{0%,to{transform:scaleX(1) scaleY(1) rotate(-2deg)}35%{transform:scaleX(.9) scaleY(1.12) rotate(2deg)}65%{transform:scaleX(1.1) scaleY(.93) rotate(-1deg)}}@keyframes flame-inner{0%,to{transform:translateX(-50%) scaleY(1)}50%{transform:translateX(-50%) scaleY(1.2)}}@keyframes cursor-blink{0%,49%{opacity:1}50%,to{opacity:0}}@media (max-width:640px){.birthday-app{padding:0}.screen-stage{width:100%}.experience-card{border-radius:var(--radius-lg) var(--radius-lg) 0 0;min-height:100vh;padding:20px}.card-open-scene{width:min(100%,320px)}.card-inside-paper{padding:56px 20px 28px;min-height:auto}.cake-panel,.mic-button,.open-button{width:100%}.letter-title{font-size:clamp(1.2rem,5vw,1.6rem)}.letter-body p{font-size:1.35rem;line-height:1.12}.inside-left-art{min-height:150px}}