@import "https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Lato:wght@300;400;700&display=swap";*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0}#root{min-height:100svh}*,:before,:after{box-sizing:border-box;margin:0;padding:0}.navbar{z-index:100;justify-content:space-between;align-items:center;padding:18px 40px;transition:background .3s,-webkit-backdrop-filter .3s,backdrop-filter .3s,box-shadow .3s;display:flex;position:fixed;top:0;left:0;right:0}.navbar--scrolled{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);background:#1a0010d9;box-shadow:0 2px 20px #0006}.navbar-brand{color:#ffb3c8;letter-spacing:1px;font-family:Playfair Display,serif;font-size:1.1rem}.navbar-links{gap:28px;display:flex}.nav-link{letter-spacing:2px;text-transform:uppercase;color:#f0d0da;font-family:Lato,sans-serif;font-size:.85rem;text-decoration:none;transition:color .2s}.nav-link:hover{color:#ff6b9d}.hero-section{background:linear-gradient(135deg,#1a0010 0%,#3d0028 45%,#6b1a3a 100%);justify-content:center;align-items:center;min-height:100svh;padding:100px 24px 60px;display:flex;position:relative;overflow:hidden}.hearts-bg{pointer-events:none;z-index:0;position:absolute;inset:0}.floating-heart{color:#ff6b9d;animation:linear infinite floatUp;position:absolute;bottom:-40px}@keyframes floatUp{0%{opacity:inherit;transform:translateY(0)scale(1)}50%{transform:translateY(-45vh)scale(1.1)}to{opacity:0;transform:translateY(-105vh)scale(.8)}}.hero-content{z-index:1;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);text-align:center;background:#ffffff0f;border:1px solid #ffb4b433;border-radius:24px;width:100%;max-width:680px;padding:56px 52px;position:relative;box-shadow:0 20px 60px #00000080}.date-label{letter-spacing:4px;text-transform:uppercase;color:#ffb3c8;margin-bottom:18px;font-family:Lato,sans-serif;font-size:.9rem;font-weight:300}.names{color:#fff5f7;margin-bottom:10px;font-family:Playfair Display,serif;font-size:clamp(2.4rem,6vw,3.6rem);font-weight:700;line-height:1.2}.heart-symbol{color:#ff6b9d;animation:1.4s ease-in-out infinite pulse;display:inline-block}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.18)}}.tagline{color:#f0b8c8;margin-bottom:40px;font-family:Playfair Display,serif;font-size:1.05rem;font-style:italic}.counter-grid{flex-wrap:wrap;justify-content:center;align-items:center;margin-bottom:40px;display:flex}.counter-item-wrapper{align-items:center;display:flex}.counter-item{background:#ff6b9d1f;border:1px solid #ff6b9d4d;border-radius:14px;flex-direction:column;align-items:center;min-width:88px;padding:18px 22px;transition:background .3s;display:flex}.counter-item:hover{background:#ff6b9d38}.counter-number{color:#fff;margin-bottom:6px;font-family:Playfair Display,serif;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700;line-height:1}.counter-label{letter-spacing:2px;text-transform:uppercase;color:#ffb3c8;font-size:.68rem;font-weight:300}.colon{color:#ff6b9d;margin-bottom:20px;padding:0 10px;font-family:Playfair Display,serif;font-size:2rem}.message{color:#f0d0da;margin-bottom:32px;font-family:Playfair Display,serif;font-size:1rem;font-style:italic;line-height:1.8}.badge{color:#fff;letter-spacing:1px;background:linear-gradient(90deg,#c2185b,#e91e63,#c2185b) 0 0/200% 100%;border-radius:50px;margin-bottom:36px;padding:10px 28px;font-size:.9rem;animation:3s linear infinite shimmer;display:inline-block;box-shadow:0 4px 20px #e91e6366}@keyframes shimmer{0%{background-position:0 0}to{background-position:200% 0}}.scroll-down{color:#f0b8c8;letter-spacing:2px;text-transform:uppercase;flex-direction:column;align-items:center;gap:6px;margin-top:4px;font-family:Lato,sans-serif;font-size:.8rem;text-decoration:none;transition:color .2s;display:flex}.scroll-down:hover{color:#ff6b9d}.scroll-arrow{font-size:1.4rem;animation:1.8s ease-in-out infinite bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(6px)}}.section{padding:100px 24px;font-family:Lato,sans-serif}.section-inner{max-width:1100px;margin:0 auto}.section-header{text-align:center;margin-bottom:60px}.section-icon{margin-bottom:14px;font-size:2.4rem;display:block}.section-title{margin-bottom:10px;font-family:Playfair Display,serif;font-size:clamp(1.8rem,4vw,2.6rem);font-weight:700}.section-subtitle{opacity:.75;font-family:Playfair Display,serif;font-size:1rem;font-style:italic}.gallery-section{color:#f5e6eb;background:linear-gradient(#2a0018 0%,#1a0010 100%)}.photo-grid{grid-template-rows:repeat(3,clamp(170px,18vw,250px));grid-template-columns:minmax(170px,.82fr) minmax(360px,1.8fr) minmax(170px,.82fr);grid-template-areas:"side-1 featured side-2""side-3 featured side-4""side-5 featured side-6";align-items:stretch;gap:16px;display:grid}.photo-card{cursor:pointer;background:#ff6b9d14;border:1px solid #ff6b9d33;border-radius:16px;min-height:0;transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden}.photo-card.side-1{grid-area:side-1}.photo-card.side-2{grid-area:side-2}.photo-card.side-3{grid-area:side-3}.photo-card.side-4{grid-area:side-4}.photo-card.side-5{grid-area:side-5}.photo-card.side-6{grid-area:side-6}.photo-card.featured{grid-area:featured}.photo-card:hover{transform:translateY(-4px)scale(1.02);box-shadow:0 16px 40px #e91e6359}.photo-img{object-fit:cover;width:100%;height:100%;display:block}.photo-placeholder{background:#ff6b9d0d;flex-direction:column;justify-content:center;align-items:center;gap:6px;width:100%;height:100%;display:flex}.placeholder-icon{font-size:2.2rem}.placeholder-text{color:#ffb3c8;font-size:.9rem;font-weight:400}.placeholder-hint{color:#ffb3c880;overflow-wrap:anywhere;max-width:90%;font-size:.7rem}.photo-overlay{opacity:0;background:linear-gradient(#0000 50%,#1a0010d9 100%);align-items:flex-end;padding:14px 16px;transition:opacity .3s;display:flex;position:absolute;inset:0}.photo-card:hover .photo-overlay{opacity:1}.photo-caption{color:#fff;font-family:Playfair Display,serif;font-size:.9rem;font-style:italic}.gallery-note{color:#f5e6ebb8;text-align:center;max-width:720px;margin:22px auto 0;font-family:Playfair Display,serif;font-size:.92rem;font-style:italic;line-height:1.7}.letter-section{color:#f5e6eb;background:linear-gradient(#1a0010 0%,#0d000a 100%)}.letter-inner{max-width:860px}.letter-paper{background:#ffffff0f;border:1px solid #ffb3c83d;border-radius:18px;padding:clamp(28px,5vw,54px);position:relative;overflow:hidden;box-shadow:0 18px 48px #00000057}.letter-paper:before{content:"";pointer-events:none;border-top:3px solid #ff6b9d6b;position:absolute;inset:0}.letter-paper p{color:#f3d7df;margin-bottom:22px;font-family:Playfair Display,serif;font-size:clamp(1.02rem,2vw,1.22rem);line-height:1.9;position:relative}.letter-greeting{color:#fff5f7;margin-bottom:18px!important;font-size:clamp(1.3rem,3vw,1.75rem)!important}.letter-signature{text-align:right;font-style:italic;color:#ffb3c8!important;margin:30px 0 0!important}.video-section{color:#f5e6eb;background:linear-gradient(#1a0010 0%,#0d000a 100%)}.video-grid{grid-template-columns:repeat(3,1fr);gap:20px;display:grid}.video-card{aspect-ratio:16/9;cursor:pointer;background:#ff6b9d14;border:1px solid #ff6b9d33;border-radius:16px;transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden}.video-card:hover{transform:translateY(-4px)scale(1.02);box-shadow:0 16px 40px #e91e6359}.video-thumb{object-fit:cover;width:100%;height:100%;display:block}.video-placeholder{flex-direction:column;justify-content:center;align-items:center;gap:6px;width:100%;height:100%;display:flex}.video-overlay{background:linear-gradient(#0000 0%,#0d000a4d 50%,#0d000ad9 100%);flex-direction:column;justify-content:center;align-items:center;gap:10px;transition:background .3s;display:flex;position:absolute;inset:0}.video-card:hover .video-overlay{background:linear-gradient(#e91e6340 0%,#0d000ae6 100%)}.play-btn{color:#fff;background:#ff6b9de6;border-radius:50%;justify-content:center;align-items:center;width:52px;height:52px;font-size:1.2rem;transition:transform .2s,background .2s;display:flex;box-shadow:0 4px 16px #e91e6380}.video-card:hover .play-btn{background:#e91e63;transform:scale(1.12)}.video-title{color:#fff;font-family:Playfair Display,serif;font-size:.88rem;font-style:italic}.lightbox-overlay{z-index:200;background:#000000eb;justify-content:center;align-items:center;padding:24px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.lightbox-close{color:#fff;cursor:pointer;z-index:201;background:#ff6b9d33;border:1px solid #ff6b9d66;border-radius:50%;width:44px;height:44px;font-size:1.1rem;transition:background .2s;position:fixed;top:20px;right:24px}.lightbox-close:hover{background:#e91e6399}.lightbox-content{flex-direction:column;align-items:center;gap:16px;max-width:90vw;max-height:85vh;display:flex}.lightbox-img{object-fit:contain;border-radius:12px;max-width:100%;max-height:75vh}.lightbox-placeholder{background:#ff6b9d1a;border:1px dashed #ff6b9d4d;border-radius:12px;justify-content:center;align-items:center;width:340px;height:260px;font-size:4rem;display:flex}.lightbox-content .photo-placeholder{border-radius:12px;width:min(70vw,420px);height:min(70vh,520px)}.lightbox-caption{color:#f0d0da;text-align:center;font-family:Playfair Display,serif;font-size:1rem;font-style:italic}.video-player-wrap{width:min(860px,90vw)}.yt-player,.local-video{aspect-ratio:16/9;background:#000;border:none;border-radius:12px;width:100%}@media (width<=768px){.navbar{padding:14px 20px}.navbar-links{gap:16px}.hero-content{padding:40px 24px}.photo-grid{grid-template-rows:auto;grid-template-columns:repeat(2,minmax(0,1fr));grid-template-areas:"featured featured""side-1 side-2""side-3 side-4""side-5 side-6"}.photo-card{aspect-ratio:3/4}.photo-card.featured{aspect-ratio:4/5}.photo-card.landscape{aspect-ratio:16/10}.video-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=500px){.counter-item{min-width:68px;padding:14px 12px}.colon{padding:0 6px;font-size:1.4rem}.photo-grid{grid-template-columns:1fr;grid-template-areas:"featured""side-1""side-2""side-3""side-4""side-5""side-6"}.video-grid{grid-template-columns:1fr}.navbar-links{display:none}}.quiz-section{color:#f5e6eb;background:linear-gradient(#0d000a 0%,#1a0010 100%)}.quiz-wrap{max-width:600px;margin:0 auto}.quiz-meta{letter-spacing:1px;color:#ffb3c8;justify-content:space-between;align-items:center;margin-bottom:10px;font-family:Lato,sans-serif;font-size:.8rem;display:flex}.quiz-back-btn{color:#ffb3c8;cursor:pointer;background:0 0;border:1px solid #ff6b9d4d;border-radius:8px;padding:5px 12px;font-family:Lato,sans-serif;font-size:.8rem;transition:background .2s,color .2s}.quiz-back-btn:hover:not(:disabled){color:#ff6b9d;background:#ff6b9d1f}.quiz-back-btn:disabled{opacity:.25;cursor:default}.quiz-progress{background:#ff6b9d26;border-radius:2px;height:4px;margin-bottom:28px;overflow:hidden}.quiz-progress-bar{background:linear-gradient(90deg,#c2185b,#ff6b9d);border-radius:2px;height:100%;transition:width .5s}.q-card{background:#ffffff0d;border:1px solid #ff6b9d33;border-radius:20px;padding:36px 32px}.q-text{color:#fff5f7;text-align:center;margin-bottom:28px;font-family:Playfair Display,serif;font-size:1.25rem;line-height:1.5}.q-options{flex-direction:column;gap:12px;margin-bottom:24px;display:flex}.q-option{color:#f0d0da;cursor:pointer;text-align:left;background:#ff6b9d12;border:1px solid #ff6b9d33;border-radius:12px;align-items:center;gap:14px;padding:14px 18px;font-family:Lato,sans-serif;font-size:.95rem;transition:background .2s,border-color .2s;display:flex}.q-option:hover:not(:disabled){background:#ff6b9d26;border-color:#ff6b9d80}.q-option.selected{background:#ff6b9d33;border-color:#ff6b9d}.q-option.correct{color:#a5d6a7;background:#4caf5033;border-color:#4caf50}.q-option.wrong{color:#ef9a9a;background:#f4433626;border-color:#f44336}.q-label{color:#ff6b9d;text-transform:uppercase;background:#ff6b9d33;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.75rem;font-weight:700;display:flex}.q-input{color:#fff5f7;background:#ff6b9d12;border:1px solid #ff6b9d4d;border-radius:12px;outline:none;width:100%;margin-bottom:16px;padding:14px 18px;font-family:Lato,sans-serif;font-size:1rem;transition:border-color .2s}.q-input:focus{border-color:#ff6b9d}.q-input::placeholder{color:#f0d0da66}.q-input:disabled{opacity:.6}.q-input-row{align-items:center;gap:10px;margin-bottom:0;display:flex}.q-input-row .q-input{margin-bottom:0}.q-tick-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#c2185b,#e91e63);border:none;border-radius:50%;flex-shrink:0;width:48px;height:48px;font-size:1.2rem;transition:transform .2s,opacity .2s;box-shadow:0 4px 14px #e91e6366}.q-tick-btn:hover:not(:disabled){transform:scale(1.1)}.q-tick-btn:disabled{opacity:.4;cursor:not-allowed}.q-confirm-btn{color:#fff;letter-spacing:1px;cursor:pointer;background:linear-gradient(135deg,#c2185b,#e91e63);border:none;border-radius:12px;width:100%;padding:14px;font-family:Lato,sans-serif;font-size:.9rem;transition:opacity .2s,transform .2s;box-shadow:0 4px 16px #e91e6359}.q-confirm-btn:hover:not(:disabled){transform:translateY(-1px)}.q-confirm-btn:disabled{opacity:.4;cursor:not-allowed}.q-feedback{text-align:center;margin-top:12px;font-family:Lato,sans-serif;font-size:.9rem}.correct-text{color:#a5d6a7}.wrong-text{color:#ef9a9a}.modal-overlay{z-index:300;background:#000000e0;justify-content:center;align-items:center;padding:24px;animation:.25s fadeIn;display:flex;position:fixed;inset:0}.modal-box{text-align:center;background:linear-gradient(135deg,#2a0018,#3d0028);border:1px solid #ff6b9d59;border-radius:24px;width:100%;max-width:480px;padding:44px 36px;box-shadow:0 20px 60px #0009}.modal-heart{color:#ff6b9d;margin-bottom:20px;font-size:2.4rem;animation:1.4s ease-in-out infinite pulse}.modal-message{color:#f0d0da;margin-bottom:28px;font-family:Lato,Arial,sans-serif;font-size:1.05rem;font-weight:400;line-height:1.85}.modal-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#c2185b,#e91e63);border:none;border-radius:50px;padding:12px 32px;font-family:Lato,sans-serif;font-size:.9rem;transition:transform .2s;box-shadow:0 4px 16px #e91e6366}.modal-btn:hover{transform:scale(1.05)}.modal-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.modal-btn-secondary{color:#ffb3c8;box-shadow:none;background:#ff6b9d1a;border:1px solid #ff6b9d59}.contract-card{padding:28px}.contract-pdf-wrap{border:1px solid #ff6b9d33;border-radius:12px;width:100%;height:420px;margin-bottom:24px;overflow:hidden}.contract-pdf{background:#fff;border:none;width:100%;height:100%}.sig-wrap{flex-direction:column;gap:12px;display:flex}.sig-label{letter-spacing:2px;text-transform:uppercase;color:#ffb3c8;font-family:Lato,sans-serif;font-size:.8rem}.sig-canvas{cursor:crosshair;background:#ff6b9d0d;border:1px dashed #ff6b9d59;border-radius:12px;width:100%!important;height:130px!important}.sig-actions{gap:12px;display:flex}.sig-clear-btn{color:#ffb3c8;cursor:pointer;background:#ff6b9d1a;border:1px solid #ff6b9d40;border-radius:12px;flex:1;padding:12px;font-family:Lato,sans-serif;font-size:.85rem;transition:background .2s}.sig-clear-btn:hover{background:#ff6b9d33}.sig-sign-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#c2185b,#e91e63);border:none;border-radius:12px;flex:2;padding:12px;font-family:Lato,sans-serif;font-size:.85rem;transition:opacity .2s,transform .2s;box-shadow:0 4px 16px #e91e6359}.sig-sign-btn:hover:not(:disabled){transform:translateY(-1px)}.sig-sign-btn:disabled{opacity:.5;cursor:not-allowed}.contract-done{text-align:center;padding:52px 32px}.contract-done-icon{margin-bottom:16px;font-size:3rem}.contract-done-title{color:#fff5f7;margin-bottom:14px;font-family:Playfair Display,serif;font-size:1.8rem}.contract-done-text{color:#f0d0da;margin-bottom:28px;font-family:Playfair Display,serif;font-size:1rem;font-style:italic;line-height:1.7}.contract-download-btn{color:#fff;letter-spacing:1px;cursor:pointer;background:linear-gradient(135deg,#c2185b,#e91e63);border:none;border-radius:50px;padding:14px 32px;font-family:Lato,sans-serif;font-size:.9rem;transition:transform .2s;box-shadow:0 4px 18px #e91e6366}.contract-download-btn:hover{transform:scale(1.05)}@media (width<=500px){.q-card{padding:24px 18px}.contract-pdf-wrap{height:300px}}.summary-card{text-align:center;padding:36px 32px}.summary-heart{color:#ff6b9d;margin-bottom:14px;font-size:2.4rem;animation:1.4s ease-in-out infinite pulse}.summary-title{color:#fff5f7;margin-bottom:6px;font-family:Playfair Display,serif;font-size:1.6rem;font-weight:700}.summary-subtitle{color:#ffb3c8;letter-spacing:1px;margin-bottom:28px;font-family:Lato,sans-serif;font-size:.85rem}.summary-list{text-align:left;flex-direction:column;gap:14px;margin-bottom:32px;display:flex}.summary-item{background:#ff6b9d12;border:1px solid #ff6b9d2e;border-radius:12px;padding:14px 18px}.summary-question{color:#ffb3c8;letter-spacing:.5px;margin-bottom:5px;font-family:Lato,sans-serif;font-size:.8rem}.summary-answer{color:#fff5f7;font-family:Lato,sans-serif;font-size:.97rem;font-weight:400;line-height:1.5}.music-btn{color:#fff;cursor:pointer;z-index:200;background:linear-gradient(135deg,#c2185b,#e91e63);border:none;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.4rem;transition:transform .2s,box-shadow .2s;display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 20px #e91e6380}.music-btn:hover{transform:scale(1.12);box-shadow:0 6px 26px #e91e6399}.music-btn.playing{animation:1.8s ease-in-out infinite musicPulse}@keyframes musicPulse{0%,to{box-shadow:0 4px 20px #e91e6380}50%{box-shadow:0 4px 32px #e91e63d9}}
