@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@300;400;500;600;700&family=Playfair+Display:wght@400;500;600;700&display=swap";:root{font-family:Cormorant Garamond,serif;color:#3b2f2f;background-color:#f8f2ec;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--bg: #f8f2ec;--bg-soft: #f1e6dc;--bg-deep: #ead7c7;--paper: #fff7ef;--ink: #3b2f2f;--muted: #7a6b66;--accent: #2a4b8d;--accent-soft: #4667ad;--rose: #d98986;--rose-soft: #f2c9c3;--gold: #e0b07a;--shadow: 0 20px 50px rgba(67, 43, 35, .15);--radius: 22px}*{box-sizing:border-box;margin:0;padding:0}body{min-height:100vh;background:radial-gradient(circle at top,#fff4e8,#f6efe9 35%,#f1e3d7)}p{font-size:1.05rem;line-height:1.6;color:var(--muted)}h3{font-family:Playfair Display,serif;color:var(--accent);margin:12px 0 6px}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{font-family:inherit}#root{min-height:100vh}.app{min-height:100vh;position:relative;display:flex;flex-direction:column;overflow:hidden}.floating-hearts{position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5}.floating-heart{position:absolute;color:#d989868c;animation:floatUp var(--duration) ease-in-out infinite;font-size:var(--size);left:var(--left);bottom:-10%;animation-delay:var(--delay)}@keyframes floatUp{0%{transform:translateY(0) scale(.9);opacity:0}20%{opacity:.8}to{transform:translateY(-120vh) scale(1.2);opacity:0}}.navbar{position:sticky;top:0;z-index:5;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#f8f2ecd9;border-bottom:1px solid rgba(122,107,102,.15)}.nav-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:18px 24px}.brand{font-family:Playfair Display,serif;font-size:1.4rem;letter-spacing:.02em;color:var(--accent)}.nav-links{display:flex;gap:18px;flex-wrap:wrap;justify-content:center}.nav-link{font-size:1rem;color:var(--muted);padding:6px 12px;border-radius:999px;transition:all .3s ease}.nav-link.active,.nav-link:hover{color:var(--accent);background:#4667ad1f}.main{flex:1;position:relative;z-index:1}.section{max-width:1200px;margin:0 auto;padding:80px 24px}.page-header{text-align:center;margin-bottom:40px}.page-title{font-family:Playfair Display,serif;font-size:clamp(2.2rem,3.5vw,3.2rem);color:var(--accent);margin-bottom:12px}.page-subtitle{font-size:1.2rem;color:var(--muted);max-width:700px;margin:0 auto}.passcode-page{min-height:70vh;display:grid;place-items:center}.passcode-card{max-width:560px;width:100%;background:linear-gradient(150deg,#fff7eff2,#d6dff266);border-radius:26px;padding:40px;border:1px solid rgba(122,107,102,.2);box-shadow:var(--shadow);text-align:center}.passcode-kicker{text-transform:uppercase;letter-spacing:.3em;font-size:.75rem;color:var(--accent)}.passcode-title{font-family:Playfair Display,serif;font-size:clamp(2rem,3vw,2.6rem);margin:14px 0 10px;color:var(--accent)}.passcode-subtitle{font-size:1.1rem;color:var(--muted);margin-bottom:24px}.passcode-form{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;margin-bottom:12px}.passcode-input{border:1px solid rgba(122,107,102,.25);border-radius:999px;padding:12px 16px;font-size:1rem;background:#ffffffe6}.passcode-error{color:#b44f4b;margin-top:8px}.passcode-hint{margin-top:16px;font-size:.9rem;color:#7a6b66b3}.hero{border-radius:var(--radius);padding:80px;position:relative;overflow:hidden;background-size:cover;background-position:center;color:#fff;box-shadow:var(--shadow)}.hero:after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,#2a4b8dc7,#d9898666)}.hero-content{position:relative;z-index:1;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(240px,.8fr);gap:26px;align-items:center}.hero-copy{display:grid;gap:18px}.hero-kicker{text-transform:uppercase;letter-spacing:.25em;font-size:.85rem;color:#ffffffbf}.hero-lead{font-size:1.15rem;color:#ffffffe6;max-width:520px}.hero h1{font-family:Playfair Display,serif;font-size:clamp(2.6rem,4.5vw,4rem);line-height:1.1}.hero p{font-size:1.3rem;max-width:600px;color:#ffffffeb}.badge-row{display:flex;flex-wrap:wrap;gap:12px}.name-badge{padding:8px 16px;border-radius:999px;background:#ffffff2e;border:1px solid rgba(255,255,255,.3);font-size:1rem;letter-spacing:.02em}.countdown{display:grid;grid-template-columns:repeat(2,minmax(90px,1fr));gap:12px}.countdown-shell{background:#ffffff2e;padding:18px;border-radius:18px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.2);box-shadow:0 20px 40px #2223}.countdown-title{text-transform:uppercase;letter-spacing:.24em;font-size:.75rem;color:#fffc;margin-bottom:12px}.countdown-card{text-align:center;background:#ffffff1f;border-radius:14px;padding:10px 8px}.countdown-value{font-family:Playfair Display,serif;font-size:2rem}.countdown-label{text-transform:uppercase;font-size:.8rem;letter-spacing:.2em}.home-lower{margin-top:42px;display:grid;gap:28px}.home-highlight{background:linear-gradient(120deg,#fff7eff2,#f2c9c359);border-radius:24px;padding:30px;border:1px solid rgba(122,107,102,.18);box-shadow:var(--shadow);display:grid;grid-template-columns:minmax(0,1.2fr) minmax(200px,.8fr);gap:18px;align-items:center}.home-kicker{text-transform:uppercase;letter-spacing:.24em;font-size:.75rem;color:var(--accent)}.home-highlight h2{font-family:Playfair Display,serif;font-size:clamp(1.6rem,2.4vw,2.2rem);margin:8px 0 10px;color:var(--accent)}.home-lead{color:var(--muted);font-size:1.1rem}.home-quote{background:#2a4b8d14;border-radius:18px;padding:20px;display:grid;gap:6px;text-align:center;color:var(--accent);font-family:Playfair Display,serif}.home-quote span{font-size:2rem}.home-quote p{color:var(--accent);font-size:1.1rem}.home-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}.home-tile{background:var(--paper);padding:20px;border-radius:20px;border:1px solid rgba(122,107,102,.2);box-shadow:var(--shadow);display:grid;gap:10px;position:relative;overflow:hidden;transition:transform .3s ease}.home-tile:after{content:"";position:absolute;inset:0;background:linear-gradient(140deg,#2a4b8d14,#d9898614);opacity:0;transition:opacity .3s ease}.home-tile:hover{transform:translateY(-6px)}.home-tile:hover:after{opacity:1}.tile-arrow{font-size:1.2rem;color:var(--accent)}.tile-1{background:linear-gradient(160deg,#fff7ef,#f2c9c3)}.tile-2{background:linear-gradient(160deg,#fff7ef,#d6dff2)}.tile-3{background:linear-gradient(160deg,#fff7ef,#f1e3d7)}.tile-4{background:linear-gradient(160deg,#fff7ef,#ead7c7)}.tile-5{background:linear-gradient(160deg,#fff7ef,#f0d4c7)}.tile-6{background:linear-gradient(160deg,#fff7ef,#dbe5f7)}.letter{background:var(--paper);border-radius:var(--radius);padding:50px;box-shadow:var(--shadow);border:1px solid rgba(122,107,102,.15)}.letter p{font-size:1.2rem;margin-bottom:18px;color:var(--ink)}.signature{margin-top:30px;max-width:220px}.timeline{position:relative;overflow-x:auto;padding-bottom:10px;scroll-snap-type:x mandatory}.timeline-horizontal::-webkit-scrollbar{height:8px}.timeline-horizontal::-webkit-scrollbar-thumb{background:#2a4b8d40;border-radius:999px}.timeline-track{display:flex;gap:22px;position:relative;padding:18px 40px 26px;min-width:max-content}.timeline-track:before{content:"";position:absolute;left:10px;right:120px;top:28px;height:2px;background:linear-gradient(90deg,#2a4b8d80,#d9898680)}.timeline-item{display:grid;gap:10px;align-items:start;background:var(--paper);border-radius:20px;padding:30px 22px 22px;border:1px solid rgba(122,107,102,.18);box-shadow:var(--shadow);position:relative;min-width:220px;max-width:250px;scroll-snap-align:start}.timeline-item:before{content:"";position:absolute;left:22px;top:18px;width:14px;height:14px;border-radius:999px;background:#fff7ef;border:3px solid rgba(42,75,141,.6);box-shadow:0 6px 14px #2a4b8d33}.timeline-forever{min-width:140px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;color:var(--accent)}.forever-mark{font-size:2rem;font-family:Playfair Display,serif}.forever-text{letter-spacing:.2em;text-transform:uppercase;font-size:.75rem;color:var(--muted)}.timeline-date{color:var(--accent);font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:.85rem}.timeline-title{font-family:Playfair Display,serif;font-size:1.6rem;margin:10px 0}.reasons-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}.flip-card{perspective:1200px}.flip-inner{position:relative;height:240px;transform-style:preserve-3d;transition:transform .6s ease}.flip-card:hover .flip-inner{transform:rotateY(180deg)}.flip-face{position:absolute;inset:0;backface-visibility:hidden;border-radius:18px;padding:20px;display:flex;flex-direction:column;justify-content:center;text-align:center;border:1px solid rgba(122,107,102,.18);box-shadow:var(--shadow)}.flip-front{background:var(--paper);font-family:Playfair Display,serif;font-size:1.3rem}.flip-back{background:linear-gradient(140deg,#2a4b8de6,#d98986d9);color:#fff;transform:rotateY(180deg);font-size:1.05rem}.memories-board{background:linear-gradient(120deg,#e8c8a1,#ddb07b);border-radius:var(--radius);padding:40px;box-shadow:var(--shadow);position:relative}.memories-grid{column-count:4;column-gap:28px;padding:8px 0}.memory-card{background:#fffef8;padding:16px;border-radius:12px;box-shadow:0 18px 35px #462e2133;transform:rotate(var(--angle));position:relative;border:1px solid rgba(122,107,102,.2);width:auto;max-width:220px;display:inline-block;margin:0 0 28px;break-inside:avoid}.memory-card img{width:100%;height:auto}.memory-card:before{content:"";position:absolute;top:-10px;left:50%;transform:translate(-50%);width:18px;height:18px;background:radial-gradient(circle at 30% 30%,#fff,#c43b3b);border-radius:50%;box-shadow:0 6px 12px #00000026}.memory-note{margin-top:12px;font-style:italic;color:var(--muted)}.gallery-grid{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}.gallery-item{position:relative;overflow:hidden;border-radius:18px;border:1px solid rgba(122,107,102,.2);box-shadow:var(--shadow);cursor:pointer;width:auto;max-width:260px}.gallery-item img{width:100%;max-width:260px;height:auto;object-fit:contain;transition:transform .4s ease}.gallery-item:hover img{transform:scale(1.05)}.lightbox{position:fixed;inset:0;background:#100c0bbf;display:flex;align-items:center;justify-content:center;z-index:10;padding:24px}.lightbox-card{background:var(--paper);padding:24px;border-radius:20px;max-width:720px;width:100%}.game-board{display:flex;flex-direction:column;gap:14px;padding:22px;background:linear-gradient(140deg,#f1e6dce6,#ead7c7b3);border-radius:24px;border:1px solid rgba(122,107,102,.18);box-shadow:var(--shadow)}.game-row{display:flex;justify-content:center;gap:14px}.game-card{perspective:800px;border:none;background:transparent;padding:0;cursor:pointer;border-radius:18px;width:110px;height:110px}.game-inner{position:relative;height:110px;width:110px;transform-style:preserve-3d;transition:transform .5s ease;border-radius:18px}.game-card.is-flipped .game-inner{transform:rotateY(180deg)}.game-face{position:absolute;inset:0;backface-visibility:hidden;border-radius:16px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(122,107,102,.2)}.game-front{background:radial-gradient(circle at top,#fff6,#d9898699),linear-gradient(150deg,#2a4b8de6,#d98986d9);color:#fff;font-size:1.6rem}.game-back{background:#fff;transform:rotateY(180deg)}.game-back img{width:100%;height:100%;object-fit:cover;border-radius:16px}.game-shell{display:grid;grid-template-columns:minmax(220px,260px) 1fr;gap:24px;align-items:start}.game-panel{background:var(--paper);border-radius:20px;padding:20px;border:1px solid rgba(122,107,102,.2);box-shadow:var(--shadow);display:grid;gap:16px}.game-badge{display:inline-flex;align-items:center;gap:8px;background:#2a4b8d1f;color:var(--accent);padding:8px 14px;border-radius:999px;font-size:.9rem}.game-note{color:var(--muted);font-size:.98rem}.game-stats{display:flex;justify-content:space-between;align-items:center;margin:24px 0;flex-wrap:wrap;gap:12px}.btn{background:var(--accent);color:#fff;border:none;padding:10px 18px;border-radius:999px;font-size:.95rem;cursor:pointer;transition:transform .3s ease}.btn:hover{transform:translateY(-2px)}.video-reveal{margin-top:30px;background:var(--paper);padding:24px;border-radius:18px;box-shadow:var(--shadow)}.video-player{width:min(100%,420px);aspect-ratio:9 / 16;display:block;margin:16px auto 0;border-radius:16px;background:#0f0f0f;object-fit:contain}.confetti{position:relative;height:80px;overflow:hidden;margin-bottom:12px}.confetti span{position:absolute;width:8px;height:18px;background:var(--rose);top:-10px;animation:fall 2.4s infinite ease-in}@keyframes fall{0%{transform:translateY(-20px) rotate(0);opacity:0}20%{opacity:1}to{transform:translateY(120px) rotate(180deg);opacity:0}}.footer{background:#f8f2ece6;padding:30px 24px 40px;text-align:center;border-top:1px solid rgba(122,107,102,.18);z-index:1}.footer p{color:var(--muted)}.easter-egg{position:absolute;font-size:.75rem;color:#2a4b8d40;letter-spacing:.08em;text-transform:lowercase;pointer-events:none;-webkit-user-select:none;user-select:none}.egg-1{top:18px;right:24px}.egg-2{bottom:18px;left:24px}.egg-3{top:24px;left:18px}.egg-4{bottom:20px;right:18px}@media(max-width:900px){.hero{padding:50px 30px}.hero-content,.home-highlight{grid-template-columns:1fr}.timeline-item,.timeline-item:nth-child(2n){grid-template-columns:1fr}.game-shell{grid-template-columns:1fr}.memories-grid{column-count:3}}@media(max-width:640px){.memories-grid{column-count:2}}@media(max-width:640px){.nav-inner{flex-direction:column;gap:10px}.hero{padding:40px 24px}.letter{padding:30px}.passcode-form{grid-template-columns:1fr}}
