*{box-sizing:border-box;margin:0;padding:0}body{background:#020208;font-family:Poppins,sans-serif;min-height:100vh;overflow-x:hidden}body.anniversary-mode{background:#080411}body.anniversary-mode:before{animation:anniversary-glow 8s ease-in-out infinite alternate;background:radial-gradient(circle at 20% 20%,#ff69b438,#0000 50%),radial-gradient(circle at 80% 30%,#ffd7002e,#0000 55%),radial-gradient(circle at 50% 80%,#ba55d32e,#0000 55%);content:"";inset:0;pointer-events:none;position:fixed;z-index:1}@keyframes anniversary-glow{0%{opacity:.55}to{opacity:.9}}.App{isolation:isolate;min-height:100vh;position:relative;z-index:2}:root{--primary-pink:#ff69b4;--soft-pink:#ffb6c1;--lavender:#e6e6fa;--deep-purple:#639;--warm-white:#fef7f0;--gold:gold;--rose-gold:#e8b4b8}.romantic-title{display:block;font-family:Dancing Script,cursive;font-weight:600;line-height:1.2}.section-title{color:#ff69b4;display:block;font-size:2.8rem;font-weight:700;line-height:1.2;margin-bottom:32px;text-shadow:0 0 30px #ff69b466}@media (max-width:768px){.section-title{font-size:2rem}}.elegant-text{color:#fef7f0;color:var(--warm-white);font-family:Poppins,sans-serif;font-weight:300;line-height:1.6}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}@keyframes sparkle{0%,to{opacity:0;transform:scale(0)}50%{opacity:1;transform:scale(1)}}@keyframes heartbeat{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.floating{animation:float 3s ease-in-out infinite}.sparkle{animation:sparkle 2s ease-in-out infinite}.heartbeat{animation:heartbeat 1.5s ease-in-out infinite}.glass{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:20px;box-shadow:0 8px 32px 0 #1f26875e}.romantic-button{background:linear-gradient(45deg,#ff69b4,#ffb6c1);background:linear-gradient(45deg,var(--primary-pink),var(--soft-pink));border:none;border-radius:25px;box-shadow:0 4px 15px #ff69b44d;color:#fff;cursor:pointer;font-weight:500;padding:12px 30px;transition:all .3s ease}.romantic-button:hover{box-shadow:0 6px 20px #ff69b466;transform:translateY(-2px)}.romantic-input{background:#ffffffe6;border:2px solid #0000;border-radius:15px;font-size:16px;outline:none;padding:15px 20px;transition:all .3s ease;width:100%}.romantic-input:focus{border-color:#ff69b4;border-color:var(--primary-pink);box-shadow:0 0 20px #ff69b44d}@media (max-width:768px){.romantic-title{font-size:2rem}.elegant-text{font-size:.9rem}}.floating-elements{height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:1}.floating-heart{filter:drop-shadow(0 0 10px rgba(255,105,180,.5));font-size:2rem}.floating-heart,.floating-sparkle{position:absolute;-webkit-user-select:none;user-select:none}.floating-sparkle{filter:drop-shadow(0 0 8px rgba(255,215,0,.7));font-size:1.5rem}.particles{height:100%;position:absolute;width:100%}.particle{background:radial-gradient(circle,#fffc 0,#0000 70%);border-radius:50%;filter:blur(.5px);height:3px;position:absolute;width:3px}.floating-elements:before{display:none}.landing-page{align-items:center;background:#0000;display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative;z-index:2}.landing-content{max-width:500px;padding:20px;position:relative;text-align:center;z-index:10}.main-title{-webkit-text-fill-color:#0000;animation:gradient-shift 3s ease-in-out infinite;background:linear-gradient(45deg,#ff69b4,gold,#ff69b4);-webkit-background-clip:text;background-clip:text;background-size:200% 200%;font-size:4rem;margin-bottom:20px}@keyframes gradient-shift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.typing-text{font-size:1.2rem;margin-bottom:40px;min-height:30px}.cursor{animation:blink 1s infinite}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.login-section{margin-top:30px;padding:40px}.login-form{display:flex;flex-direction:column;gap:20px}.input-group{position:relative}.enter-button{font-size:1.1rem;margin-top:10px;padding:15px 40px}.loading-text{align-items:center;display:flex;gap:10px}.loading-text:after{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:#fff;content:"";height:20px;width:20px}.error-message{background:#ff00001a;border:1px solid #f003;border-radius:10px;color:#ffcccb;font-size:.9rem;padding:10px;text-align:center}.hint-text{color:#ffffffb3;font-size:.85rem;font-style:italic;margin-top:20px}@media (max-width:768px){.main-title{font-size:2.5rem}.landing-content{max-width:90%}.login-section{padding:30px 20px}.typing-text{font-size:1rem}}.main-navigation{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffff12;border-bottom:1px solid #ffffff26;box-shadow:0 4px 20px #00000026;left:0;padding:14px 24px;position:fixed;right:0;top:0;z-index:100}.nav-container{align-items:center;display:flex;gap:8px;margin:0 auto;max-width:1200px;width:100%}.nav-logo{cursor:pointer;flex-shrink:0;margin-right:6px}.logo-text{color:var(--warm-white);font-family:Dancing Script,cursive;font-size:1.25rem;font-weight:600;text-shadow:2px 2px 4px #0000004d;white-space:nowrap}.nav-items{flex:1 1;flex-wrap:nowrap;gap:2px;overflow:visible}.nav-item,.nav-items{align-items:center;display:flex}.nav-item{background:#0000;border:none;border-radius:20px;color:#ffffffbf;cursor:pointer;flex-shrink:0;font-family:Poppins,sans-serif;font-size:.83rem;font-weight:400;gap:5px;padding:9px 12px;text-decoration:none;transition:all .22s ease;white-space:nowrap}.nav-item:hover{background:#ffffff1a;color:#fff}.nav-item.active{background:linear-gradient(45deg,var(--primary-pink),var(--soft-pink));box-shadow:0 3px 12px #ff69b459;color:#fff}.nav-icon{font-size:1rem;line-height:1}.nav-label{font-family:Poppins,sans-serif}.nav-more-wrap{position:relative}.nav-more-btn{align-items:center;display:flex;gap:5px}.nav-more-arrow{display:inline-block;font-size:.7rem;opacity:.7}.nav-dropdown{background:#0f0a1eeb!important;border:1px solid #ffffff26!important;border-radius:14px;box-shadow:0 12px 40px #00000080;display:flex;flex-direction:column;gap:2px;min-width:190px;padding:6px;position:absolute;right:0;top:calc(100% + 10px);z-index:200}.nav-dropdown-item{align-items:center;border-radius:10px;color:#ffffffbf;display:flex;font-family:Poppins,sans-serif;font-size:.87rem;gap:10px;padding:9px 14px;text-decoration:none;transition:all .18s}.nav-dropdown-item:hover{background:#ffffff14;color:#fff}.nav-dropdown-item.active{background:linear-gradient(45deg,#ff69b44d,#ffb6c133);color:var(--primary-pink)}.surprise-button{align-items:center;background:linear-gradient(45deg,var(--gold),#ffed4e);border:none;border-radius:50%;box-shadow:0 3px 12px #ffd7004d;cursor:pointer;display:flex;flex-shrink:0;font-size:1rem;height:36px;justify-content:center;margin-left:4px;transition:all .3s ease;width:36px}.surprise-button:hover{box-shadow:0 5px 18px #ffd70073}@media (max-width:900px){.nav-label,.nav-more-arrow{display:none}.nav-item{padding:8px 10px}.logo-text{font-size:1.1rem}}@media (max-width:600px){.main-navigation{padding:8px 10px}.nav-container{gap:3px}.nav-item{padding:7px 8px}.nav-icon{font-size:1.05rem}.logo-text{display:none}.surprise-button{font-size:.9rem;height:32px;width:32px}.nav-dropdown{right:-10px}}.mb-page{margin:0 auto;max-width:1100px;padding:40px 24px 80px;text-align:center}.mb-subtitle{color:#fff9;font-size:1rem;font-style:italic;margin-bottom:48px;margin-top:4px}.mb-loading{align-items:center;color:#fff9;display:flex;flex-direction:column;font-size:3rem;gap:16px;height:400px;justify-content:center}.mb-loading p{font-size:1rem;font-style:italic}.mb-grid{grid-gap:32px 24px;display:grid;gap:32px 24px;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));justify-items:center}.mb-card{background:#fdf6ee;border-radius:4px;box-shadow:0 4px 16px #00000073,0 1px 3px #0000004d;cursor:pointer;padding:10px 10px 44px;position:relative;transform:rotate(var(--tilt));transition:box-shadow .25s;width:200px}.mb-card:hover{box-shadow:0 12px 40px #0009,0 2px 6px #0000004d}.mb-photo{aspect-ratio:1/1;background:#e8ddd0;border-radius:2px;overflow:hidden;position:relative;width:100%}.mb-img{display:block;height:100%;object-fit:cover;width:100%}.mb-emoji-fill{font-size:3rem;height:100%;width:100%}.mb-caption-strip,.mb-emoji-fill{align-items:center;display:flex;justify-content:center}.mb-caption-strip{bottom:0;flex-direction:column;gap:1px;height:44px;left:0;padding:0 8px;position:absolute;right:0}.mb-card-title{color:#3a2a1a;font-family:Dancing Script,cursive;font-size:.95rem;font-weight:600;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mb-card-date{color:#8a7060;font-size:.65rem;letter-spacing:.3px}.mb-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#000000d9;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:600}.mb-lightbox{border-radius:24px;display:flex;flex-direction:column;max-width:520px;overflow:hidden;position:relative;width:100%}.mb-lb-img{background:#0a0a0a;display:block;max-height:360px;object-fit:contain;width:100%}.mb-lb-emoji{align-items:center;display:flex;font-size:5rem;height:260px;justify-content:center;width:100%}.mb-lb-body{padding:24px 28px 28px;text-align:center}.mb-lb-title{color:#ff69b4;font-family:Dancing Script,cursive;font-size:2rem;margin-bottom:10px}.mb-lb-caption{color:#ffffffd9;font-size:1rem;font-style:italic;line-height:1.7;margin-bottom:10px}.mb-lb-date{color:#ffffff73;font-size:.8rem;letter-spacing:.3px}.mb-lb-close{align-items:center;background:#00000080;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.85rem;height:32px;justify-content:center;position:absolute;right:14px;top:12px;transition:background .2s;width:32px}.mb-lb-close:hover{background:#ff69b480}@media (max-width:600px){.mb-grid{gap:24px 16px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.mb-card{padding:8px 8px 38px;width:150px}.mb-card-title{font-size:.85rem}}.messaging-container{margin:0 auto;max-width:800px;padding:40px 20px 20px}.name-row{align-items:center;display:flex;gap:12px;margin-bottom:16px}.sender-input{max-width:220px}.status-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.status-dot.connected{background:#4ade80;box-shadow:0 0 6px #4ade80}.status-dot.disconnected{background:#f87171}.chat-container{border-radius:20px;display:flex;flex-direction:column;height:62vh;min-height:420px;overflow:hidden}.messages-area{display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto;padding:20px 16px}.messages-area::-webkit-scrollbar{width:5px}.messages-area::-webkit-scrollbar-thumb{background:var(--primary-pink);border-radius:3px}.message{display:flex;max-width:72%}.own-message{align-self:flex-end;flex-direction:row-reverse}.other-message{align-self:flex-start}.message-bubble{background:#ffffffeb;border-radius:18px;box-shadow:0 3px 12px #0000001a;color:#333;max-width:100%;padding:10px 14px}.own-message .message-bubble{background:linear-gradient(135deg,#ff69b4,#e879a0);color:#fff}.message-header{display:flex;font-size:.75rem;gap:12px;justify-content:space-between;margin-bottom:4px}.sender-name{color:var(--deep-purple);font-weight:600}.own-message .sender-name{color:#ffffffe6}.message-time{opacity:.6}.own-message .message-time{color:#ffffffb3}.message-content{font-size:.95rem;line-height:1.45;word-break:break-word}.msg-image{cursor:pointer;max-height:200px;max-width:240px;object-fit:cover}.msg-image,.msg-video{border-radius:12px;display:block}.msg-video{max-width:260px}.msg-audio{display:flex;flex-direction:column;font-size:.85rem;gap:6px}.msg-audio audio{height:32px;width:200px}.msg-file{color:inherit;font-size:.9rem;text-decoration:underline;word-break:break-all}.preview-bar{align-items:center;border-radius:14px;display:flex;flex-wrap:wrap;gap:14px;margin:0 16px 8px;padding:12px 16px}.preview-content{flex:1 1}.preview-img{border-radius:10px;max-height:100px;max-width:160px;object-fit:cover}.preview-audio{height:32px;width:200px}.preview-file{color:#ffffffd9;font-size:.9rem}.preview-actions{gap:8px}.cancel-btn,.preview-actions{align-items:center;display:flex}.cancel-btn{background:#ffffff26;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:.85rem;height:30px;justify-content:center;transition:background .2s;width:30px}.cancel-btn:hover{background:#ffffff40}.message-form{border-top:1px solid #ffffff1a;padding:12px 16px 14px}.input-row{gap:8px}.icon-btn,.input-row{align-items:center;display:flex}.icon-btn{background:#ffffff1f;border:none;border-radius:50%;cursor:pointer;flex-shrink:0;font-size:1.1rem;height:40px;justify-content:center;transition:background .2s;width:40px}.icon-btn:hover{background:#ffffff38}.icon-btn.recording{animation:pulse-red .8s ease-in-out infinite;background:#ff3c3c59}.message-input{flex:1 1}.send-btn{flex-shrink:0;font-size:1.1rem;padding:10px 18px}.send-btn:disabled{cursor:not-allowed;opacity:.4}@media (max-width:600px){.messaging-container{padding:20px 10px}.chat-container{height:70vh}.message{max-width:88%}.msg-image{max-width:180px}}.poetry-container{margin:0 auto;max-width:1200px;padding:40px 20px}.poetry-loading{align-items:center;color:var(--warm-white);display:flex;flex-direction:column;height:400px;justify-content:center}.loading-quill{font-size:3rem;margin-bottom:20px}.poetry-content{margin-top:40px}.poems-grid{grid-gap:30px;display:grid;gap:30px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.poem-card{border-radius:20px;cursor:pointer;min-height:200px;overflow:hidden;padding:30px;position:relative;transition:all .3s ease}.poem-card:before{background:linear-gradient(45deg,var(--primary-pink),var(--gold));content:"";height:4px;left:0;position:absolute;right:0;top:0}.poem-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:20px}.poem-title{color:var(--primary-pink);font-family:Playfair Display,serif;font-size:1.6rem;font-weight:700;letter-spacing:.02em;margin:0}.poem-date{color:#ffffffb3;font-size:.85rem;font-weight:300}.poem-preview{color:var(--warm-white);line-height:1.6}.preview-line{font-family:Playfair Display,serif;font-size:.95rem;font-style:normal;margin:0 0 8px;opacity:.9}.read-more{color:var(--soft-pink);font-size:.9rem;font-weight:500;margin-top:15px;opacity:.8}.poem-decoration{bottom:20px;font-size:1.5rem;opacity:.6;position:absolute;right:20px}.poem-modal-overlay{align-items:center;background:#000c;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.poem-modal{border-radius:25px;max-height:80vh;max-width:600px;overflow-y:auto;padding:40px;position:relative;width:100%}.modal-header{align-items:center;border-bottom:2px solid #ff69b44d;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.modal-title{color:var(--primary-pink);font-family:Playfair Display,serif;font-size:2.2rem;font-weight:800;letter-spacing:.01em;margin:0}.close-button{align-items:center;background:none;border:none;border-radius:50%;color:#ffffffb3;cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;padding:5px;transition:all .3s ease;width:40px}.close-button:hover{background:#ffffff1a;color:#fff}.modal-content{color:var(--warm-white)}.poem-full-text{line-height:1.8;margin-bottom:30px}.poem-line{font-family:Playfair Display,serif;font-size:1.05rem;font-style:normal;line-height:1.9;margin:0 0 12px}.poem-line:empty{margin-bottom:20px}.poem-footer{align-items:center;border-top:1px solid #fff3;display:flex;justify-content:space-between;padding-top:20px}.poem-date-full{color:#ffffffb3;font-size:.9rem;font-style:italic}.heart-signature{font-size:1.5rem}@media (max-width:768px){.poetry-container{padding:20px 10px}.poems-grid{gap:20px;grid-template-columns:1fr}.poem-card{min-height:150px;padding:20px}.poem-title{font-size:1.5rem}.poem-modal{margin:10px;padding:30px 20px}.modal-title{font-size:2rem}.poem-line{font-size:1rem}.poem-header{align-items:flex-start;flex-direction:column;gap:10px}}.minigame-container{margin:0 auto;max-width:700px;padding:40px 20px;text-align:center}.minigame-header{margin-bottom:30px}.minigame-title{color:#ff69b4;display:block;font-family:Dancing Script,cursive;font-size:3rem;font-weight:700;margin-bottom:10px;text-shadow:0 0 30px #ff69b466}.minigame-subtitle{color:#fffc;font-size:1rem;margin-bottom:10px}.minigame-moves{background:#ffffff26;border:1px solid #ffd7004d;border-radius:20px;color:gold;display:inline-block;font-size:.95rem;font-weight:500;padding:6px 18px}.card-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr);justify-items:center}.card-tile{aspect-ratio:1;cursor:pointer;max-width:120px;perspective:600px;width:100%}.card-inner{border-radius:14px;height:100%;min-height:90px;position:relative;transform-style:preserve-3d;transition:transform .5s ease;width:100%}.card-tile.flipped .card-inner,.card-tile.matched .card-inner{transform:rotateY(180deg)}.card-back,.card-front{align-items:center;backface-visibility:hidden;border-radius:14px;box-shadow:0 4px 15px #0003;display:flex;font-size:2rem;height:100%;justify-content:center;position:absolute;width:100%}.card-front{background:linear-gradient(135deg,#c471ed,#f64f59);border:2px solid #ffffff4d}.card-back{background:linear-gradient(135deg,#fff0f5,#ffe4f0);border:2px solid #ff69b466;transform:rotateY(180deg)}.card-tile.matched .card-back{background:linear-gradient(135deg,gold,#ffed4e);border-color:#ffd70099;box-shadow:0 0 20px #ffd70066}.win-screen{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:25px;display:flex;justify-content:center;min-height:400px;overflow:hidden;padding:60px 40px;position:relative}.confetti-hearts{height:100%;left:0;overflow:hidden;pointer-events:none;position:absolute;top:0;width:100%}.confetti-heart{font-size:1.5rem;position:absolute;top:0}.win-content{position:relative;text-align:center;z-index:2}.win-title{color:#ff69b4;display:block;font-family:Dancing Script,cursive;font-size:3.5rem;font-weight:700;margin-bottom:20px;text-shadow:0 0 30px #ff69b466}.win-message{color:#ffffffe6;font-size:1.2rem;font-style:italic;line-height:1.6;margin:0 auto 20px;max-width:400px}.win-moves{color:#ffd700e6;font-size:.95rem;margin-bottom:30px}.replay-btn{background:linear-gradient(45deg,#ff69b4,#ffb6c1);border:none;border-radius:25px;box-shadow:0 4px 20px #ff69b466;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:500;padding:14px 35px;transition:all .3s ease}.replay-btn:hover{box-shadow:0 6px 25px #ff69b480}@media (max-width:600px){.card-grid{gap:10px}.card-back,.card-front{font-size:1.5rem}.minigame-title{font-size:2.2rem}.win-title{font-size:2.5rem}.win-message{font-size:1rem}.win-screen{padding:40px 20px}}.timeline-page{margin:0 auto;max-width:900px;padding:40px 20px 60px;text-align:center}.timeline-heading{color:#ff69b4;display:block;font-family:Playfair Display,serif;font-size:3rem;font-weight:800;letter-spacing:.02em;margin-bottom:8px;text-shadow:0 0 30px #ff69b466}.timeline-subtitle{color:#ffffffb3;font-size:1rem;font-style:italic;margin-bottom:50px}.timeline{display:flex;flex-direction:column;gap:40px;position:relative}.timeline-line{background:linear-gradient(180deg,#ff69b4,#c471ed,gold);border-radius:3px;bottom:0;left:50%;position:absolute;top:0;transform:translateX(-50%);width:3px}.timeline-item{align-items:center;display:flex;position:relative;width:100%}.timeline-item.left{justify-content:flex-start;padding-right:calc(50% + 30px)}.timeline-item.right{justify-content:flex-end;padding-left:calc(50% + 30px)}.timeline-card{border-radius:20px;max-width:340px;padding:24px 28px;position:relative;text-align:left;width:100%}.timeline-emoji{font-size:2rem;margin-bottom:8px}.timeline-date{color:gold;font-size:.8rem;font-weight:500;letter-spacing:.5px;margin-bottom:6px}.timeline-title{color:#ff69b4;font-family:Playfair Display,serif;font-size:1.4rem;font-weight:700;letter-spacing:.01em;margin:0 0 8px}.timeline-desc{color:#ffffffd9;font-size:.95rem;line-height:1.6;margin:0}.timeline-img-wrap{border-radius:12px;margin-bottom:14px;max-height:180px;overflow:hidden;width:100%}.timeline-img{border-radius:12px;display:block;height:180px;object-fit:cover;width:100%}.timeline-dot{background:linear-gradient(135deg,#ff69b4,gold);border:3px solid #fff6;border-radius:50%;box-shadow:0 0 12px #ff69b499;height:18px;left:50%;position:absolute;transform:translateX(-50%);width:18px;z-index:2}@media (max-width:700px){.timeline-line{left:20px}.timeline-item.left,.timeline-item.right{justify-content:flex-start;padding-left:50px;padding-right:0}.timeline-dot{left:20px}.timeline-card{max-width:100%}.timeline-heading{font-size:2.2rem}}.tl-edit-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:8px;cursor:pointer;font-size:.85rem;opacity:0;padding:4px 8px;position:absolute;right:10px;top:10px;transition:opacity .2s}.timeline-card:hover .tl-edit-btn{opacity:1}.tl-edit-overlay{align-items:center;background:#000000bf;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:500}.tl-edit-modal{border-radius:24px;max-width:480px;padding:32px 28px;width:100%}.tl-edit-title{color:#ff69b4;font-family:Dancing Script,cursive;font-size:1.8rem;margin-bottom:20px;text-align:center}.tl-edit-form{display:flex;flex-direction:column;gap:14px}.tl-edit-row{align-items:flex-end;display:flex;gap:12px}.tl-edit-group{display:flex;flex-direction:column;gap:5px}.tl-edit-group label{color:#fff9;font-size:.78rem;letter-spacing:.5px;text-transform:uppercase}.tl-edit-input{background:#ffffff14;border:1px solid #ffffff26;border-radius:10px;color:#fff;font-family:Poppins,sans-serif;font-size:.95rem;outline:none;padding:10px 14px;transition:border-color .2s;width:100%}.tl-edit-input:focus{border-color:#ff69b480}.tl-edit-textarea{background:#ffffff14;border:1px solid #ffffff26;border-radius:10px;color:#fff;font-family:Poppins,sans-serif;font-size:.95rem;outline:none;padding:10px 14px;resize:vertical;transition:border-color .2s;width:100%}.tl-edit-textarea:focus{border-color:#ff69b480}.tl-edit-img-row{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.tl-upload-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:10px;color:#fff;cursor:pointer;font-family:Poppins,sans-serif;font-size:.85rem;padding:8px 14px;transition:background .2s}.tl-upload-btn:hover{background:#ffffff2e}.tl-upload-btn:disabled{cursor:not-allowed;opacity:.5}.tl-edit-thumb{border-radius:8px;height:48px;object-fit:cover;width:48px}.tl-remove-btn{background:#ff505033;border:1px solid #ff50504d;border-radius:8px;color:#ff6b6b;cursor:pointer;font-size:.8rem;padding:4px 8px}.tl-edit-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}.tl-cancel-btn{background:#ffffff14;border:1px solid #ffffff26;border-radius:20px;color:#ffffffb3;padding:10px 22px}.tl-cancel-btn,.tl-save-btn{cursor:pointer;font-family:Poppins,sans-serif;font-size:.9rem}.tl-save-btn{background:linear-gradient(45deg,#ff69b4,#ffb6c1);border:none;border-radius:20px;box-shadow:0 4px 14px #ff69b459;color:#fff;font-weight:600;padding:10px 26px;transition:opacity .2s}.tl-save-btn:disabled{cursor:not-allowed;opacity:.6}.tl-page{margin:0 auto;max-width:900px;padding:40px 20px 80px;text-align:center}.tl-loading{align-items:center;display:flex;font-size:3rem;height:300px;justify-content:center}.tl-heading{color:#ff69b4;display:block;font-family:Dancing Script,cursive;font-size:3rem;font-weight:700;margin-bottom:8px;text-shadow:0 0 30px #ff69b466}.tl-subtitle{color:#ffffffb3;font-size:1rem;font-style:italic}.tl-section,.tl-subtitle{margin-bottom:40px}.tl-section-title{color:#ffb6c1;font-family:Dancing Script,cursive;font-size:1.8rem;margin-bottom:20px;text-align:left}.tl-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.tl-card{border-radius:20px;cursor:pointer;padding:28px 22px;position:relative;text-align:center;transition:all .3s}.tl-card.locked{cursor:default;filter:grayscale(.3);opacity:.7}.tl-card-icon{font-size:2.5rem;margin-bottom:12px}.tl-card-title{color:#ff69b4;font-family:Dancing Script,cursive;font-size:1.3rem;margin-bottom:8px}.tl-card-date{color:#fff9;font-size:.8rem;margin-bottom:8px}.tl-countdown{color:gold;font-size:.85rem;font-weight:500}.tl-badge{background:linear-gradient(45deg,#ff69b4,#c471ed);border-radius:12px;color:#fff;display:inline-block;font-size:.75rem;margin-top:8px;padding:3px 10px}.tl-badge.locked-badge{background:#ffffff26}.tl-read-more{color:#ffffff80;font-size:.8rem;font-style:italic;margin-top:10px}.tl-overlay{align-items:center;background:#000c;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.tl-modal{border-radius:25px;max-width:520px;padding:50px 40px;text-align:center;width:100%}.tl-modal-icon{font-size:3rem;margin-bottom:15px}.tl-modal-title{color:#ff69b4;font-family:Dancing Script,cursive;font-size:2rem;margin-bottom:8px}.tl-modal-date{color:#fff9;font-size:.85rem;margin-bottom:25px}.tl-modal-content{color:#ffffffe6;font-size:1.05rem;font-style:italic;line-height:1.8;margin-bottom:30px;text-align:left}.tl-modal-img{border-radius:16px;box-shadow:0 8px 30px #0006;margin-bottom:20px;max-height:240px;object-fit:cover;width:100%}.secret-section{border-radius:20px;margin:30px 0;padding:30px;text-align:center}.secret-title{color:#ff69b4;font-family:Dancing Script,cursive;font-size:2rem;margin-bottom:8px}.secret-hint{color:#ffffffb3;font-size:.95rem;font-style:italic;margin-bottom:20px}.secret-methods{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:20px}.method-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:20px;color:#fff;cursor:pointer;font-size:.9rem;padding:8px 18px;transition:all .3s}.method-btn.active,.method-btn:hover{background:linear-gradient(45deg,#ff69b4,#ffb6c1);border-color:#0000}.hearts-row{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:10px}.secret-heart{background:none;border:none;cursor:pointer;font-size:2rem;transition:transform .2s}.secret-heart.clicked{filter:drop-shadow(0 0 8px rgba(255,105,180,.8))}.hearts-progress{color:#fff9;font-size:.85rem;margin-top:8px;width:100%}.secret-form{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:10px}.secret-input{max-width:220px}.love-letter-overlay{align-items:center;background:#000c;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.love-letter{border-radius:25px;max-width:520px;padding:50px 40px;text-align:center;width:100%}.letter-seal{animation:sway 3s ease-in-out infinite;font-size:3rem;margin-bottom:15px}@keyframes sway{0%,to{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}.letter-heading{color:#ff69b4;font-family:Dancing Script,cursive;font-size:2rem;margin-bottom:25px}.letter-body{color:#ffffffe6;font-size:1rem;line-height:1.9;margin-bottom:30px;text-align:left}.letter-body p{margin-bottom:14px}.letter-sign{color:gold;font-family:Dancing Script,cursive;font-size:1.4rem;text-align:right}.universe-page{background:#0000;min-height:calc(100vh - 74px);overflow:hidden;position:relative;width:100%}.nebula,.shooting-star,.universe-canvas{display:none}.universe-header{left:50%;pointer-events:none;position:absolute;text-align:center;top:24px;transform:translateX(-50%);z-index:10}.universe-title{color:#fff;font-family:Dancing Script,cursive;font-size:2.8rem;margin-bottom:6px;text-shadow:0 0 40px #ff69b4e6,0 0 80px #ff69b466}.universe-subtitle{color:#ffffff80;font-size:.88rem;font-style:italic;letter-spacing:.3px}.memory-star{background:radial-gradient(circle at 40% 35%,#fff 0,#fffbe0 25%,gold 55%,#ffc80026 80%,#0000 100%);border:none;border-radius:50%;box-shadow:0 0 6px 2px #ffe650b3,0 0 18px 4px #ffc8004d;cursor:pointer;position:absolute;transform:translate(-50%,-50%);transition:box-shadow .25s,transform .25s;z-index:8}.memory-star:hover{box-shadow:0 0 10px 4px #fff064e6,0 0 30px 10px #ffc80080,0 0 60px 20px #ffb40033}.star-glow{animation:star-pulse 2.8s ease-in-out infinite;background:radial-gradient(circle,#ffdc3c40,#0000 70%);border-radius:50%;inset:-8px;position:absolute}@keyframes star-pulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.7)}}.star-label{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#050514d1;border:1px solid #ffd7004d;border-radius:20px;color:#fff;font-family:Poppins,sans-serif;font-size:.72rem;left:50%;letter-spacing:.2px;opacity:0;padding:3px 9px;pointer-events:none;position:absolute;top:calc(100% + 10px);transform:translateX(-50%);transition:opacity .2s;white-space:nowrap}.memory-star:hover .star-label{opacity:1}.memory-star.star-active{background:radial-gradient(circle at 40% 35%,#fff 0,#ffcce8 25%,#ff69b4 55%,#ff69b426 80%,#0000 100%);box-shadow:0 0 10px 4px #ff69b4e6,0 0 30px 10px #ff69b480,0 0 70px 24px #ff69b433;z-index:12}.memory-star.star-active .star-glow{animation:star-pulse-active 1.8s ease-in-out infinite;background:radial-gradient(circle,#ff69b459,#0000 70%)}@keyframes star-pulse-active{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(2.2)}}.constellation-svg{height:100%;inset:0;pointer-events:none;position:absolute;width:100%;z-index:7}.uv-box-anchor{gap:12px;position:absolute;right:36px;top:88px;z-index:20}.uv-box-anchor,.uv-wooden-box{align-items:center;display:flex;flex-direction:column}.uv-frame{background:repeating-linear-gradient(88deg,#0000,#0000 3px,#0000000f 0,#0000000f 5px),repeating-linear-gradient(180deg,#ffc8780a,#ffc8780a 8px,#0000 0,#0000 16px),linear-gradient(175deg,#4a3020,#2e1a0a 30%,#3d2510 60%,#1e0e04);border:5px solid #120800;border-radius:14px;box-shadow:0 30px 80px #000000d9,0 8px 20px #0009,inset 0 3px 6px #ffd28c33,inset 0 -4px 8px #00000080,inset 4px 0 8px #ffc8781a,inset -4px 0 8px #0006;height:300px;outline:2px solid #ffaa502e;padding:20px;position:relative;width:300px}.uv-frame:before{background:linear-gradient(90deg,#8a6a30,#d4a843,#c49030,#d4a843,#8a6a30);border-radius:0 0 8px 8px;box-shadow:0 2px 8px #00000080;color:#2a1a00;content:"✦ memories ✦";font-size:.6rem;font-weight:700;left:50%;letter-spacing:2px;padding:3px 16px;position:absolute;text-transform:uppercase;top:-1px;transform:translateX(-50%);z-index:10}.uv-notch{display:none}.uv-display{background:#050508;border-radius:6px;box-shadow:inset 0 0 20px #000c;height:100%;overflow:hidden;position:relative;width:100%}.uv-layer{align-items:center;display:flex;inset:0;justify-content:center;position:absolute}.uv-layer-top{z-index:2}.uv-box-img{display:block;height:100%;object-fit:contain;object-position:center;width:100%}.uv-box-emoji{align-items:center;display:flex;font-size:4.5rem;height:100%;justify-content:center;width:100%}.uv-screw{background:radial-gradient(circle at 35% 30%,#c8a060,#6a4010,#2a1005);border-radius:50%;box-shadow:inset 0 1px 3px #000000b3,inset 0 -1px 2px #ffc86433,0 1px 2px #ffb4504d;height:12px;position:absolute;width:12px;z-index:9}.uv-screw:after{transform:translate(-50%,-50%) rotate(45deg)}.uv-screw:after,.uv-screw:before{background:#0009;border-radius:1px;content:"";height:1.5px;left:50%;position:absolute;top:50%;width:7px}.uv-screw:before{transform:translate(-50%,-50%) rotate(-45deg)}.uv-screw-tl{left:8px;top:8px}.uv-screw-tr{right:8px;top:8px}.uv-screw-bl{bottom:8px;left:8px}.uv-screw-br{bottom:8px;right:8px}.uv-box-info{align-items:center;display:flex;flex-direction:column;gap:4px;max-width:300px}.uv-box-label{color:#fff;font-family:Dancing Script,cursive;font-size:1.2rem;max-width:300px;overflow:hidden;text-align:center;text-overflow:ellipsis;text-shadow:0 0 16px #ff69b499;white-space:nowrap}.uv-box-caption{color:#ffffff73;font-size:.78rem;font-style:italic;line-height:1.5;max-width:280px;text-align:center}@media (max-width:900px){.uv-box-anchor{bottom:20px;right:50%;top:auto;transform:translateX(50%)}.uv-frame{height:200px;padding:14px;width:200px}.uv-box-label{font-size:1rem}}.mm-page{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:calc(100vh - 74px);padding:20px 20px 40px;position:relative}.mm-menu{border-radius:24px;max-width:440px;padding:44px 36px;text-align:center;width:100%}.mm-menu-icon{font-size:3rem;margin-bottom:10px}.mm-menu-title{color:#ff69b4;display:block;font-family:Dancing Script,cursive;font-size:2.8rem;font-weight:700;margin-bottom:4px;text-shadow:0 0 30px #ff69b466}.mm-menu-sub{color:#fff9;font-size:1rem;font-style:italic;margin-bottom:10px}.mm-menu-desc{color:#ffffffa6;font-size:.88rem;line-height:1.6;margin-bottom:24px}.mm-diff-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}.mm-diff-btn{align-items:center;background:#ffffff12;border:1px solid #ffffff1f;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:4px;padding:12px 8px;transition:all .2s}.mm-diff-btn.active,.mm-diff-btn:hover{background:#ff69b433;border-color:#ff69b480}.mm-diff-label{color:#fff;font-size:.9rem;font-weight:600}.mm-diff-info{color:#ffffff80;font-size:.72rem}.mm-start-btn{background:linear-gradient(45deg,#ff69b4,gold);border:none;border-radius:25px;box-shadow:0 4px 20px #ff69b466;color:#fff;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:13px 36px;transition:all .2s}.mm-start-btn.secondary{background:#ffffff1f;border:1px solid #fff3;box-shadow:none}.mm-hud{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff14;border:1px solid #ffffff26;border-radius:50px;flex-wrap:wrap;gap:16px;justify-content:center;margin-bottom:20px;padding:10px 20px}.mm-hud,.mm-hud-item{align-items:center;display:flex}.mm-hud-item{flex-direction:column;min-width:48px}.mm-hud-item.danger .mm-hud-val{animation:pulse-red .8s ease-in-out infinite;color:#f87171}@keyframes pulse-red{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.mm-hud-val{color:#fff;font-size:1.1rem;font-weight:700}.mm-hud-lbl{color:#ffffff80;font-size:.68rem}.mm-progress-wrap{align-items:center;display:flex;flex-direction:column;gap:4px;min-width:120px}.mm-progress-bar{background:#ffffff26;border-radius:3px;height:6px;overflow:hidden;width:120px}.mm-progress-fill{background:linear-gradient(90deg,#ff69b4,gold);border-radius:3px;height:100%}.mm-progress-lbl{color:#ffffff80;font-size:.68rem}.mm-quit-btn{background:#ffffff1a;border:none;border-radius:50%;color:#fff9;cursor:pointer;font-size:.85rem;height:30px;transition:all .2s;width:30px}.mm-quit-btn:hover{background:#f871714d;color:#fff}.mm-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,1fr);grid-template-columns:repeat(var(--cols,4),1fr);max-width:600px;width:100%}.mm-card{aspect-ratio:3/4;border-radius:14px;cursor:pointer;perspective:800px}.mm-card-inner{border-radius:14px;height:100%;position:relative;transform-style:preserve-3d;transition:transform .5s cubic-bezier(.4,0,.2,1);width:100%}.mm-card.flipped .mm-card-inner,.mm-card.matched .mm-card-inner{transform:rotateY(180deg)}.mm-card-back,.mm-card-front{align-items:center;backface-visibility:hidden;border-radius:14px;display:flex;inset:0;justify-content:center;overflow:hidden;position:absolute}.mm-card-back{background:linear-gradient(135deg,#c471ed,#f64f59);border:2px solid #fff3;box-shadow:0 4px 15px #0000004d}.mm-card-back-icon{font-size:1.6rem;opacity:.8}.mm-card-front{background:linear-gradient(135deg,#1a1a2e,#16213e);border:2px solid #ff69b44d;box-shadow:0 4px 15px #0000004d;flex-direction:column;transform:rotateY(180deg)}.mm-card.matched .mm-card-front{border-color:#ffd70099;box-shadow:0 0 20px #ffd7004d}.mm-card-img{border-radius:12px;height:100%;object-fit:contain;padding:6px;width:100%}.mm-card-emoji-fallback{align-items:center;background:linear-gradient(135deg,#ff69b433,#ffd7001a);font-size:2rem;height:100%;justify-content:center;width:100%}.mm-card-matched-glow{animation:matched-pulse 2s ease-in-out infinite;background:radial-gradient(circle,#ffd70033,#0000 70%);border-radius:12px;inset:0;position:absolute}@keyframes matched-pulse{0%,to{opacity:.5}50%{opacity:1}}.mm-reveal-overlay{align-items:center;background:#000000d1;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.mm-reveal-card{border-radius:24px;max-width:360px;overflow:visible;padding:36px 28px;position:relative;text-align:center;width:100%}.mm-reveal-sparkle{font-size:1.2rem;left:50%;pointer-events:none;position:absolute;top:50%;transform:rotate(var(--angle)) translateX(120px);transform-origin:0 0}.mm-reveal-match-badge{background:linear-gradient(45deg,#ff69b4,gold);border-radius:20px;color:#fff;display:inline-block;font-size:.82rem;font-weight:600;margin-bottom:14px;padding:4px 14px}.mm-reveal-img{background:#0003;border-radius:14px;box-shadow:0 8px 30px #0006;margin-bottom:14px;max-height:180px;object-fit:contain;width:100%}.mm-reveal-emoji{font-size:4rem;margin-bottom:14px}.mm-reveal-title{color:#ff69b4;font-family:Dancing Script,cursive;font-size:1.7rem;margin-bottom:8px}.mm-reveal-caption{color:#fffc;font-size:.9rem;font-style:italic;line-height:1.6;margin-bottom:20px}.mm-reveal-btn{background:linear-gradient(45deg,#ff69b4,#ffb6c1);border:none;border-radius:20px;color:#fff;cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:600;padding:10px 28px}.mm-confetti{align-items:center;display:flex;inset:0;justify-content:center;pointer-events:none;position:fixed;z-index:0}.mm-confetti-piece{font-size:1.4rem;position:absolute;top:0}.mm-win{border-radius:24px;max-width:480px;padding:44px 36px;position:relative;text-align:center;width:100%;z-index:1}.mm-win-heart{font-size:4rem}.mm-win-heart,.mm-win-title{display:block;margin-bottom:12px}.mm-win-title{color:#ff69b4;font-family:Dancing Script,cursive;font-size:2.5rem;font-weight:700;text-shadow:0 0 30px #ff69b466}.mm-win-msg{color:#ffffffd9;font-size:1rem;font-style:italic;line-height:1.7;margin-bottom:20px}.mm-win-stats{display:flex;gap:24px;justify-content:center;margin-bottom:20px}.mm-stat{align-items:center;display:flex;flex-direction:column;gap:2px}.mm-stat-val{color:gold;font-size:1.5rem;font-weight:700}.mm-stat-lbl{color:#ffffff80;font-size:.72rem}.mm-collage{flex-wrap:wrap;gap:6px;margin-bottom:24px}.mm-collage,.mm-collage-item{display:flex;justify-content:center}.mm-collage-item{align-items:center;background:#ffffff14;border:2px solid #ffd70066;border-radius:10px;height:52px;overflow:hidden;width:52px}.mm-collage-item img{height:100%;object-fit:cover;width:100%}.mm-collage-emoji{font-size:1.5rem}@media (max-width:500px){.mm-grid{gap:7px}.mm-card-back-icon{font-size:1.2rem}.mm-diff-grid{grid-template-columns:1fr}}.cinematic-start{align-items:center;display:flex;justify-content:center;min-height:calc(100vh - 74px);padding:20px}.cinematic-start-card{border-radius:24px;max-width:480px;padding:48px 36px;text-align:center;width:100%}.cinematic-icon{font-size:3rem;margin-bottom:12px}.cinematic-start-title{color:#ff69b4;display:block;font-family:Dancing Script,cursive;font-size:2.8rem;font-weight:700;margin-bottom:8px;text-shadow:0 0 30px #ff69b466}.cinematic-start-sub{color:#ffffffa6;font-size:.95rem;font-style:italic;margin-bottom:28px}.chapter-preview{display:flex;flex-direction:column;gap:10px;margin-bottom:28px;text-align:left}.chapter-preview-item{align-items:center;background:#ffffff0f;border-radius:10px;display:flex;font-size:1.2rem;gap:12px;padding:10px 14px}.cp-title{color:#ffffffe6;font-size:.88rem;font-weight:600}.cp-sub{color:#ffffff80;font-size:.78rem}.cinematic-play-btn{background:linear-gradient(45deg,#ff69b4,gold);border:none;border-radius:25px;box-shadow:0 4px 20px #ff69b466;color:#fff;cursor:pointer;font-family:inherit;font-size:1rem;font-weight:600;padding:14px 36px}.cinematic-player{align-items:center;background:#000;cursor:pointer;display:flex;inset:0;justify-content:center;position:fixed;z-index:500}.cinematic-progress{background:#ffffff26;height:3px;left:0;position:absolute;right:0;top:0;z-index:10}.cinematic-progress-fill{background:linear-gradient(90deg,#ff69b4,gold);height:100%}.cinematic-controls{display:flex;gap:8px;position:absolute;right:16px;top:16px;z-index:10}.cin-ctrl-btn{background:#ffffff1f;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.1rem;height:36px;transition:background .2s;width:36px}.cin-ctrl-btn:hover{background:#ffffff38}.cin-ctrl-btn:disabled{cursor:default;opacity:.3}.cinematic-slide{align-items:center;display:flex;flex-direction:column;inset:0;justify-content:center;position:absolute}.chapter-slide{background:radial-gradient(ellipse at center,#ff69b426 0,#000 70%)}.chapter-emoji{font-size:4rem;margin-bottom:16px}.chapter-title{color:#fff;font-family:Dancing Script,cursive;font-size:3.5rem;margin-bottom:8px;text-shadow:0 0 40px #ff69b499}.chapter-subtitle{color:#fff9;font-size:1.2rem;font-style:italic}.cinematic-img{height:100%;inset:0;object-fit:cover;opacity:.6;position:absolute;width:100%}.cinematic-img-placeholder{font-size:8rem;opacity:.3}.cinematic-text-overlay{max-width:700px;padding:0 40px;position:relative;text-align:center;z-index:2}.cinematic-memory-title{color:#fff;font-family:Dancing Script,cursive;font-size:3rem;margin-bottom:16px;text-shadow:0 2px 20px #000c}.cinematic-memory-caption{color:#ffffffd9;font-size:1.2rem;font-style:italic;line-height:1.7;text-shadow:0 1px 10px #000000e6}.end-slide{background:radial-gradient(ellipse at center,#ff69b433 0,#000 70%);gap:16px}.end-hearts{font-size:5rem}.end-title{color:#fff;font-family:Dancing Script,cursive;font-size:3rem;text-shadow:0 0 30px #ff69b480}.end-sub{color:#fff9;font-size:1.1rem;font-style:italic;margin-bottom:8px}.cinematic-hint{bottom:20px;color:#ffffff4d;font-size:.78rem;left:50%;pointer-events:none;position:absolute;transform:translateX(-50%)}.video-slide{background:#000;cursor:default}.cinematic-video{background:#000;object-fit:contain}.chapter-bg-video,.cinematic-video{height:100%;inset:0;position:absolute;width:100%}.chapter-bg-video{object-fit:cover;opacity:.45;pointer-events:none}.chapter-slide-content{gap:8px;position:relative;z-index:2}.chapter-slide-content,.pw-page{align-items:center;display:flex;flex-direction:column}.pw-page{gap:24px;min-height:calc(100vh - 74px);padding:20px 24px 50px}.pw-page-title{color:#ff69b4;display:block;font-family:Dancing Script,cursive;font-size:2.6rem;font-weight:700;text-align:center;text-shadow:0 0 30px #ff69b466}.pw-layout{grid-column-gap:120px;column-gap:120px;display:grid;grid-template-columns:1fr 1fr;max-width:1100px;padding:0 20px}.pw-box-side,.pw-layout{align-items:center;width:100%}.pw-box-side{display:flex;flex-direction:column;gap:20px}.pw-frame,.pw-wooden-box{position:relative;width:100%}.pw-frame{aspect-ratio:1/1;background:repeating-linear-gradient(92deg,#0000,#0000 2px,#0000000a 0,#0000000a 4px),linear-gradient(180deg,#3d2b1f,#2a1a0e 40%,#3d2b1f 70%,#1e1008);border:4px solid #1a0d05;border-radius:10px;box-shadow:0 24px 70px #000000bf,inset 0 2px 4px #ffc89626,inset 0 -3px 6px #0006,inset 3px 0 6px #ffc89614,inset -3px 0 6px #0000004d;outline:1px solid #ffb4641f;padding:22px}.pw-notch{color:#c8a882;font-size:1rem;left:50%;text-shadow:0 0 8px #c8a88299;top:-14px;transform:translateX(-50%)}.pw-notch,.pw-screw{position:absolute;z-index:5}.pw-screw{background:radial-gradient(circle at 35% 35%,#8a6a4a,#3d2010);border-radius:50%;box-shadow:inset 0 1px 2px #0009,0 1px 1px #ffc89633;height:10px;width:10px}.pw-screw:after{background:#00000080;content:"";height:1px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%) rotate(45deg);width:6px}.pw-screw-tl{left:8px;top:8px}.pw-screw-tr{right:8px;top:8px}.pw-screw-bl{bottom:8px;left:8px}.pw-screw-br{bottom:8px;right:8px}.pw-panels{grid-gap:3px;background:#1a0d05;display:grid;gap:3px;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;overflow:hidden;position:relative}.pw-full-img,.pw-panels{border-radius:4px;height:100%;width:100%}.pw-full-img{object-fit:contain;object-position:center;pointer-events:none}.pw-full-fallback,.pw-full-img{inset:0;position:absolute;z-index:0}.pw-full-fallback{align-items:center;display:flex;justify-content:center}.pw-panel-slot{background:#0000;border-radius:2px;overflow:hidden;position:relative;z-index:1}.pw-quadrant-fallback{align-items:center;display:flex;inset:0;justify-content:center;position:absolute}.pw-flip-page{background:#0a0a0a;inset:0;overflow:hidden;position:absolute;transform-style:preserve-3d;z-index:3}.pw-slot-img{height:200%;left:0;object-fit:contain;pointer-events:none;position:absolute;top:0;width:200%}.pw-fallback-emoji{font-size:1.6rem;pointer-events:none}.pw-seam-h{height:3px;left:0;right:0;top:50%;transform:translateY(-50%)}.pw-seam-h,.pw-seam-v{background:#1a0d05;pointer-events:none;position:absolute;z-index:8}.pw-seam-v{bottom:0;left:50%;top:0;transform:translateX(-50%);width:3px}.pw-panel-border{border:1px solid #1a0d0599;inset:0;pointer-events:none;position:absolute;z-index:6}.pw-controls{align-items:center;display:flex;gap:12px}.pw-spin-btn{background:linear-gradient(45deg,#ff69b4,gold);border:none;border-radius:22px;box-shadow:0 4px 18px #ff69b466;color:#fff;cursor:pointer;font-family:inherit;font-size:.95rem;font-weight:700;padding:11px 28px;transition:opacity .2s}.pw-spin-btn:disabled{cursor:not-allowed;opacity:.55}.pw-auto-btn{background:#ffffff1a;border:1px solid #fff3;border-radius:18px;color:#ffffffbf;cursor:pointer;font-family:inherit;font-size:.85rem;padding:9px 20px;transition:all .2s}.pw-auto-btn.on{background:#ff69b433;border-color:#ff69b480;color:#ff69b4}.pw-dots{display:flex;flex-wrap:wrap;gap:7px;justify-content:center;max-width:300px}.pw-dot{background:#fff3;border:none;border-radius:50%;cursor:pointer;height:9px;padding:0;transition:all .2s;width:9px}.pw-dot.active{background:#ff69b4;box-shadow:0 0 8px #ff69b4b3;transform:scale(1.35)}.rd-wrap{align-items:center;display:flex;flex-direction:column;gap:18px}.rd-disc,.rd-wrap{position:relative;width:100%}.rd-disc{aspect-ratio:1/1;background:radial-gradient(circle at 50% 50%,#1a1a2e 0,#0d0d1a 100%);background-image:radial-gradient(circle at 50% 50%,#1a1a2e 0,#0d0d1a 100%),repeating-conic-gradient(#ffffff08 0deg 1deg,#0000 1deg 30deg);border-radius:50%;box-shadow:0 0 0 6px #ff69b426,0 0 0 12px #ff69b412,0 20px 60px #0009,0 0 80px #ff69b426;user-select:none;-webkit-user-select:none}.rd-disc.grab{cursor:grab}.rd-disc.grabbing{cursor:grabbing}.rd-segment{height:50%;left:50%;pointer-events:none;position:absolute;top:0;transform-origin:bottom center;width:2px}.rd-segment-content{border:2px solid #ff69b466;border-radius:50%;box-shadow:0 0 12px #ff69b44d;height:52px;left:50%;overflow:hidden;position:absolute;top:8%;transform:translateX(-50%);width:52px}.rd-seg-img{-webkit-user-drag:none;object-fit:cover;pointer-events:none}.rd-seg-emoji,.rd-seg-img{border-radius:50%;height:100%;width:100%}.rd-seg-emoji{align-items:center;display:flex;font-size:1.4rem;justify-content:center}.rd-disc:before{background:repeating-conic-gradient(#ffffff0f 0deg 1deg,#0000 1deg 60deg);content:"";inset:0}.rd-disc:before,.rd-hub{border-radius:50%;pointer-events:none;position:absolute}.rd-hub{align-items:center;background:radial-gradient(circle,#2a1a2e,#0d0d1a);border:3px solid #ff69b480;box-shadow:0 0 20px #ff69b466,inset 0 0 10px #00000080;display:flex;height:56px;justify-content:center;left:50%;top:50%;transform:translate(-50%,-50%);width:56px;z-index:10}.rd-hub-icon{animation:hub-counter 8s linear infinite;font-size:1.4rem}@keyframes hub-counter{to{transform:rotate(-1turn)}}.rd-pointer{animation:ptr-bounce 1.5s ease-in-out infinite;color:gold;font-size:1.3rem;left:50%;pointer-events:none;position:absolute;text-shadow:0 0 10px #ffd700e6;top:-18px;transform:translateX(-50%);z-index:20}@keyframes ptr-bounce{0%,to{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(5px)}}.rd-label{border-radius:14px;max-width:280px;padding:12px 20px;text-align:center;width:100%}.rd-label-title{color:#ff69b4;display:block;font-family:Dancing Script,cursive;font-size:1.3rem;margin-bottom:4px}.rd-label-caption{color:#ffffffa6;display:block;font-size:.82rem;font-style:italic}.rd-hint{color:#ffffff4d;font-size:.75rem;font-style:italic}.pw-overlay{background:#000000d9;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.pw-modal,.pw-overlay{align-items:center;display:flex}.pw-modal{border-radius:24px;flex-direction:column;gap:12px;max-width:460px;padding:34px 28px;text-align:center;width:100%}.pw-modal-img{border-radius:14px;box-shadow:0 8px 30px #00000080;max-height:260px;object-fit:cover;width:100%}.pw-modal-title{color:#ff69b4;font-family:Dancing Script,cursive;font-size:2rem}.pw-modal-caption{color:#ffffffd9;font-size:.95rem;font-style:italic;line-height:1.7}.pw-open-btn{background:linear-gradient(45deg,#ff69b4,#ffb6c1);border:none;border-radius:20px;color:#fff;cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:600;padding:10px 26px}@media (max-width:700px){.pw-layout{column-gap:0;grid-template-columns:1fr;padding:0;row-gap:32px}}.vc-container{margin:0 auto;max-width:1100px;padding:40px 20px 60px}.vc-subtitle{color:#ffffffb3;font-size:1rem;font-style:italic;margin:-8px 0 28px;text-align:center}.vc-composer{grid-gap:24px;align-items:start;border-radius:24px;display:grid;gap:24px;grid-template-columns:1.2fr .8fr;padding:28px}.vc-form{display:flex;flex-direction:column;gap:12px}.vc-label{color:#ffffffbf;font-size:.85rem}.vc-textarea{background:#ffffffe6;border:2px solid #0000;border-radius:14px;font-size:.95rem;outline:none;padding:12px 16px;resize:vertical;transition:all .3s ease;width:100%}.vc-textarea:focus{border-color:var(--primary-pink);box-shadow:0 0 20px #ff69b44d}.vc-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px}.vc-record-btn{background:#ffffff1f;border:1px solid #fff3;border-radius:22px;color:#ffffffe6;cursor:pointer;font-size:.9rem;padding:10px 18px;transition:all .2s}.vc-record-btn:hover{background:#fff3}.vc-record-btn.recording{background:#ff505040;border-color:#ff505073;color:#ffd1d1}.vc-clear-btn{background:#ffffff1f;border:1px solid #fff3;border-radius:22px;color:#fffc;cursor:pointer;padding:10px 16px}.vc-clear-btn:hover{background:#fff3}.vc-error{background:#ff000014;border:1px solid #f003;border-radius:10px;color:#ffcccb;font-size:.85rem;padding:8px 10px}.vc-preview{background:#00000040;border:1px solid #ffffff26;border-radius:18px;display:flex;flex-direction:column;gap:10px;padding:18px}.vc-preview audio{width:100%}.vc-preview-title{color:#ffffffe6;font-weight:600}.vc-preview-name{color:#ffffffa6;font-size:.85rem}.vc-preview-empty{align-items:center;color:#fff9;display:flex;font-style:italic;justify-content:center;min-height:80px;text-align:center}.vc-list{margin-top:28px}.vc-empty,.vc-loading{color:#ffffffb3;padding:24px;text-align:center}.vc-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.vc-card{border-radius:18px;display:flex;flex-direction:column;gap:8px;padding:20px 18px}.vc-card-title{color:#ff69b4;font-family:Dancing Script,cursive;font-size:1.5rem}.vc-card-header{align-items:center;display:flex;gap:8px;justify-content:space-between}.vc-delete-btn{background:#ff50501f;border:1px solid #ff505040;border-radius:8px;color:#ff8080;cursor:pointer;flex-shrink:0;font-size:.9rem;padding:4px 8px;transition:background .2s,transform .15s}.vc-delete-btn:hover{background:#ff505047;transform:scale(1.1)}.vc-card-note{color:#ffffffd9;font-size:.95rem;line-height:1.5}.vc-card-date{color:#ffffff8c;font-size:.8rem}.vc-card audio{margin-top:6px;width:100%}@media (max-width:900px){.vc-composer{grid-template-columns:1fr}}@media (max-width:600px){.vc-container{padding:24px 12px 40px}}.vp-page{margin:0 auto;max-width:1100px;padding:40px 24px 80px;text-align:center}.vp-heading{color:#ff69b4;font-family:Dancing Script,cursive;font-size:2.8rem;font-weight:700;margin-bottom:6px;text-shadow:0 0 30px #ff69b466}.vp-subtitle{color:#ffffff8c;font-size:1rem;font-style:italic;margin-bottom:40px}.vp-loading{align-items:center;color:#ffffff80;display:flex;flex-direction:column;font-size:3rem;gap:16px;height:400px;justify-content:center}.vp-loading p{font-size:1rem;font-style:italic}.vp-empty{align-items:center;color:#ffffff80;display:flex;flex-direction:column;gap:14px;padding:60px 20px}.vp-empty-icon{font-size:3.5rem}.vp-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.vp-card{border-radius:18px;cursor:pointer;overflow:hidden;text-align:left}.vp-thumb{aspect-ratio:16/9;background:#0a0a0a;overflow:hidden;position:relative;width:100%}.vp-thumb-video{display:block;height:100%;object-fit:cover;pointer-events:none;width:100%}.vp-play-overlay{align-items:center;background:#00000059;display:flex;inset:0;justify-content:center;position:absolute;transition:background .2s}.vp-card:hover .vp-play-overlay{background:#0000008c}.vp-play-btn{align-items:center;background:#ff69b4d9;border-radius:50%;box-shadow:0 4px 20px #ff69b480;color:#fff;display:flex;font-size:1.2rem;height:52px;justify-content:center;transition:transform .2s;width:52px}.vp-card:hover .vp-play-btn{transform:scale(1.12)}.vp-info{padding:14px 16px}.vp-title{color:#ff69b4;font-family:Dancing Script,cursive;font-size:1.2rem;margin-bottom:4px}.vp-caption{color:#ffffff8c;font-size:.82rem;font-style:italic;line-height:1.4}.vp-overlay{align-items:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000e6;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:600}.vp-player{border-radius:20px;max-width:860px;overflow:hidden;position:relative;width:100%}.vp-video{background:#000;display:block;max-height:70vh;width:100%}.vp-player-info{padding:16px 20px 20px}.vp-close{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.9rem;height:34px;justify-content:center;position:absolute;right:14px;top:12px;transition:background .2s;width:34px;z-index:10}.vp-close:hover{background:#ff69b480}@media (max-width:600px){.vp-grid{grid-template-columns:1fr}.vp-heading{font-size:2.2rem}}.main-app{background:#0000;min-height:100vh;position:relative;z-index:2}.app-background{display:none}.app-content{min-height:100vh;padding:74px 20px 60px;position:relative;z-index:10}.section-content{margin:0 auto;max-width:1200px}@media (max-width:768px){.app-content{padding:64px 12px 40px}}.music-player-wrap{bottom:24px;position:fixed;right:24px;z-index:200}.music-player{align-items:center;border-radius:50px;display:flex;gap:10px;overflow:hidden;padding:10px 14px;transition:all .3s ease;white-space:nowrap}.music-toggle-btn{background:none;border:none;cursor:pointer;flex-shrink:0;font-size:1.4rem;line-height:1}.music-controls{align-items:center;display:flex;gap:8px;overflow:hidden}.track-name{color:#ffffffd9;font-size:.8rem;max-width:120px;overflow:hidden;text-overflow:ellipsis}.ctrl-btn{background:none;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:1rem;padding:2px 4px;transition:background .2s}.ctrl-btn:hover{background:#ffffff26}.volume-slider{accent-color:#ff69b4;cursor:pointer;width:70px}.track-info{display:flex;flex-direction:column;max-width:130px}.track-artist{color:#ffffff80;font-size:.7rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cursor-heart{animation:heart-trail .9s ease-out forwards;font-size:1rem;pointer-events:none;position:fixed;transform:translate(-50%,-50%);-webkit-user-select:none;user-select:none;z-index:9999}@keyframes heart-trail{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}to{opacity:0;transform:translate(-50%,-120%) scale(.4)}}.surprise-fab{border-radius:50%;bottom:90px;box-shadow:0 4px 20px #ff69b466;cursor:pointer;font-size:1.5rem;height:52px;justify-content:center;right:24px;width:52px}.mood-bar,.surprise-fab{align-items:center;display:flex;position:fixed;z-index:200}.mood-bar{border-radius:50px;bottom:24px;gap:10px;left:24px;padding:10px 18px}.mood-label{color:#fffc;font-size:.8rem;white-space:nowrap}.mood-btn{background:none;border:none;border-radius:50%;cursor:pointer;font-size:1.3rem;padding:2px;transition:transform .2s}.mood-btn:hover{transform:scale(1.2)}.surprise-overlay{align-items:center;background:#000000bf;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.confetti-burst{left:50%;pointer-events:none;position:absolute;top:50%}.confetti-piece{font-size:1.5rem;position:absolute}.surprise-card{border-radius:30px;max-width:420px;padding:50px 40px;position:relative;text-align:center;width:90%}.surprise-icon{animation:pulse 1.5s ease-in-out infinite;font-size:3.5rem;margin-bottom:20px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.surprise-message{color:#fffffff2;font-family:Dancing Script,cursive;font-size:1.3rem;font-style:italic;line-height:1.7;margin-bottom:30px}.surprise-close{font-size:1rem}@media (max-width:600px){.mood-label{display:none}.mood-bar{gap:6px;padding:8px 12px}}.env-layer{inset:0;overflow:hidden;pointer-events:none;position:fixed;z-index:5}.rain-overlay{background:#1e285040;inset:0;position:absolute}.raindrop{animation:fall linear infinite;background:linear-gradient(180deg,#0000,#b4d2ff99);border-radius:2px;height:18px;position:absolute;top:-20px;width:1.5px}@keyframes fall{to{transform:translateY(110vh)}}.night-overlay{background:#05051e73;inset:0;position:absolute}.star{animation:twinkle ease-in-out infinite;background:#fff;border-radius:50%;position:absolute}@keyframes twinkle{0%,to{opacity:.2;transform:scale(1)}50%{opacity:1;transform:scale(1.4)}}.snowflake{animation:snowfall linear infinite;color:#c8e6ffcc;position:absolute;top:-20px}@keyframes snowfall{to{transform:translateY(110vh) rotate(1turn)}}.fireplace-glow{animation:flicker 2s ease-in-out infinite alternate;background:radial-gradient(ellipse at 50% 100%,#ff780059 0,#ff3c0026 40%,#0000 70%);bottom:0;height:300px;left:50%;position:absolute;transform:translateX(-50%);width:400px}@keyframes flicker{0%{opacity:.7;transform:translateX(-50%) scaleX(1)}to{opacity:1;transform:translateX(-50%) scaleX(1.05)}}.ember{animation:ember-rise ease-out infinite;background:#f60;border-radius:50%;bottom:0;box-shadow:0 0 4px #f60;height:3px;position:absolute;width:3px}@keyframes ember-rise{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-200px) scale(0)}}.env-fab{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #ffffff40;border-radius:50%;bottom:220px;box-shadow:0 4px 20px #0003;cursor:pointer;font-size:1.3rem;height:50px;position:fixed;right:24px;width:50px;z-index:200}.env-picker{border-radius:14px;bottom:215px;display:flex;flex-direction:column;gap:4px;min-width:150px;padding:10px;position:fixed;right:80px;z-index:201}.env-option{align-items:center;background:#ffffff14;border:1px solid #ffffff1a;border-radius:8px;color:#ffffffd9;cursor:pointer;display:flex;font-family:inherit;font-size:.85rem;gap:8px;padding:7px 12px;transition:all .2s}.env-option.active,.env-option:hover{background:#ff69b433;border-color:#ff69b459;color:#fff}.star-bg{background:#020208;inset:0;overflow:hidden;pointer-events:none;position:fixed;z-index:0}.star-canvas{height:100%;inset:0;position:absolute;width:100%}.nebula{animation:nb-drift 25s ease-in-out infinite alternate;border-radius:50%;filter:blur(90px);opacity:.14;position:absolute}.nb-pink{animation-delay:0s;background:radial-gradient(ellipse,#ff69b4,#0000 70%);height:400px;left:-5%;top:-5%;width:600px}.nb-purple{animation-delay:8s;background:radial-gradient(ellipse,#7c3aed,#0000 70%);height:500px;right:-8%;top:40%;width:500px}.nb-blue{animation-delay:16s;background:radial-gradient(ellipse,#1e40af,#0000 70%);bottom:-5%;height:300px;left:25%;width:450px}@keyframes nb-drift{0%{opacity:.12;transform:translate(0) scale(1)}50%{opacity:.18;transform:translate(20px,-15px) scale(1.08)}to{opacity:.14;transform:translate(-10px,10px) scale(.95)}}.shooting-star-bg{background:linear-gradient(90deg,#0000,#ffffffe6,#0000);border-radius:2px;height:1.5px;position:absolute;transform-origin:left center;width:140px}.mood-fab{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #ffffff40;border-radius:50%;bottom:160px;box-shadow:0 4px 20px #0003;cursor:pointer;font-size:1.4rem;height:50px;position:fixed;right:24px;width:50px;z-index:200}.mood-picker{border-radius:16px;bottom:155px;min-width:200px;padding:16px;position:fixed;right:80px;z-index:201}.mood-picker-title{color:#ffffffb3;font-size:.82rem;margin-bottom:10px;text-align:center}.mood-options{display:flex;flex-direction:column;gap:6px}.mood-option{align-items:center;background:#ffffff14;border:1px solid #ffffff1f;border-radius:10px;color:#ffffffd9;cursor:pointer;display:flex;font-family:inherit;font-size:.88rem;gap:10px;padding:8px 12px;transition:all .2s}.mood-option.active,.mood-option:hover{background:#ff69b440;border-color:#ff69b466;color:#fff}.mood-emoji{font-size:1.1rem}.mood-label-text{font-size:.85rem}.mood-message{border-radius:14px;bottom:160px;color:#fffffff2;font-size:.9rem;line-height:1.5;max-width:260px;padding:14px 18px;right:80px;z-index:201}.mood-message,.time-greeting{font-style:italic;position:fixed}.time-greeting{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff1f;border:1px solid #fff3;border-radius:30px;color:#ffffffe6;font-size:.85rem;left:50%;padding:8px 20px;pointer-events:none;top:68px;transform:translateX(-50%);white-space:nowrap;z-index:150}@media (max-width:600px){.mood-picker{bottom:150px;right:10px}.mood-message{max-width:220px;right:10px}.time-greeting{font-size:.78rem;padding:8px 16px}}.mystery-box-wrap{display:inline-block}.mystery-box-btn{align-items:center;border:none;border-radius:20px;cursor:pointer;display:flex;font-family:inherit;gap:8px;padding:10px 18px;transition:all .2s}.mystery-box-icon{font-size:1.3rem}.mystery-box-label{color:#ffffffd9;font-size:.88rem}.mystery-overlay{align-items:center;background:#000c;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.mystery-reveal{border-radius:24px;max-width:400px;padding:48px 36px;position:relative;text-align:center;width:100%}.mystery-sparkle{display:inline-block;font-size:2rem;margin-bottom:16px}.mystery-emoji-burst{display:flex;flex-wrap:wrap;font-size:2rem;gap:8px;justify-content:center;margin-bottom:24px}.mystery-note{color:#fffffff2;font-family:Dancing Script,cursive;font-size:1.4rem;line-height:1.7;margin-bottom:24px}.mystery-close-btn{background:linear-gradient(45deg,#ff69b4,#ffb6c1);border:none;border-radius:20px;color:#fff;cursor:pointer;font-family:inherit;font-size:.9rem;padding:10px 24px}.remember-popup{border-radius:16px;bottom:100px;left:24px;max-width:280px;padding:16px;position:fixed;z-index:300}.remember-close{background:none;border:none;color:#ffffff80;cursor:pointer;font-size:.85rem;position:absolute;right:10px;top:8px}.remember-header{align-items:center;display:flex;gap:6px;margin-bottom:10px}.remember-icon{font-size:1.1rem}.remember-label{color:#fff9;font-size:.78rem;font-style:italic}.remember-img{border-radius:10px;height:100px;margin-bottom:8px;object-fit:cover;width:100%}.remember-title{color:#ff69b4;font-family:Dancing Script,cursive;font-size:1.1rem;margin-bottom:4px}.remember-caption{color:#ffffffbf;font-size:.82rem;font-style:italic;line-height:1.4;margin-bottom:4px}.remember-date{color:#fff6;font-size:.75rem}.countdown-widget{border-radius:14px;min-width:200px;padding:14px 18px}.countdown-header{color:#fff9;font-size:.8rem;font-weight:500;margin-bottom:10px}.countdown-item{align-items:center;display:flex;gap:10px;margin-bottom:8px}.countdown-emoji{font-size:1.1rem}.countdown-info{display:flex;flex-direction:column;gap:2px}.countdown-label{color:#ffffffd9;font-size:.82rem}.countdown-time{color:gold;font-size:.78rem;font-weight:600}.bulk-dropzone{padding:36px 20px}.bulk-dropzone-icon{font-size:2.2rem}.bulk-dropzone-text{font-size:.92rem}.bulk-dropzone-sub{font-size:.78rem}.bulk-preview-grid{grid-gap:10px;gap:10px;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));max-height:320px;padding:4px 2px}.bulk-preview-item{border-radius:10px;transition:border-color .2s}.bulk-remove-btn{font-size:.8rem;height:26px;transition:background .2s;width:26px}.bulk-remove-btn:hover{background:#f87171cc}.bulk-status-icon{font-size:1.4rem;text-shadow:0 0 8px #4ade80cc}.bulk-status-icon.error{text-shadow:0 0 8px #f87171cc}.bulk-preview-name{font-size:.65rem;padding:3px 5px}.bulk-spinner{height:22px;width:22px}.gc-info-banner{align-items:center;background:#e879a014;border:1px solid #e879a033;border-radius:10px;color:#ffffffbf;display:flex;flex-wrap:wrap;font-size:.85rem;gap:8px;justify-content:space-between;margin-bottom:14px;padding:10px 16px}.gc-counts{display:flex;gap:10px}.gc-count{border-radius:12px;font-size:.8rem;font-weight:600;padding:3px 10px}.gc-count.in{background:#4ade8026;color:#4ade80}.gc-count.out{background:#f8717126;color:#f87171}.gc-toolbar{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:16px}.gc-filter-tabs{display:flex;gap:4px}.gc-tab{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:8px;color:var(--am);cursor:pointer;font-family:inherit;font-size:.83rem;padding:6px 14px;transition:all .18s}.gc-tab:hover{background:#ffffff1a;color:var(--at)}.gc-tab.active{background:#e879a033;border-color:#e879a066;color:var(--ap)}.gc-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.gc-card{background:var(--as);border:1px solid var(--ab);border-radius:14px;display:flex;flex-direction:column;overflow:hidden;transition:all .2s}.gc-card.inactive{filter:grayscale(.4);opacity:.5}.gc-card.active{border-color:#e879a04d}.gc-card-img-wrap{aspect-ratio:1;background:var(--as2);overflow:hidden;position:relative}.gc-card-img{display:block;height:100%;object-fit:cover;transition:transform .3s;width:100%}.gc-card:hover .gc-card-img{transform:scale(1.04)}.gc-card-no-img{align-items:center;color:#ffffff4d;display:flex;font-size:2.5rem;height:100%;justify-content:center;width:100%}.gc-toggle-btn{border:none;border-radius:20px;bottom:6px;cursor:pointer;font-family:inherit;font-size:.72rem;font-weight:600;left:50%;opacity:0;padding:4px 12px;position:absolute;transform:translateX(-50%);transition:all .2s;white-space:nowrap}.gc-card:hover .gc-toggle-btn{opacity:1}.gc-toggle-btn.on{background:#4ade80e6;color:#000}.gc-toggle-btn.off{background:#e879a0e6;color:#fff}.gc-card-info{flex:1 1;padding:8px 10px 4px}.gc-card-title{color:var(--at);font-size:.82rem;font-weight:600;margin-bottom:3px}.gc-card-caption,.gc-card-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gc-card-caption{color:var(--am);font-size:.72rem;font-style:italic}.gc-edit-btn{justify-content:center;margin:4px 8px 8px;width:calc(100% - 16px)}.bulk-dropzone{background:#e879a00a;border:2px dashed #e879a066;border-radius:14px;cursor:pointer;margin-bottom:16px;padding:32px 20px;text-align:center;transition:all .2s}.bulk-dropzone.drag-over,.bulk-dropzone:hover{background:#e879a01a;border-color:var(--ap)}.bulk-dropzone-icon{font-size:2rem;margin-bottom:8px}.bulk-dropzone-text{color:var(--at);font-size:.9rem;font-weight:500;margin-bottom:4px}.bulk-dropzone-sub{color:var(--am);font-size:.76rem}.bulk-preview-grid{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));max-height:280px;overflow-y:auto}.bulk-preview-item{border:2px solid #0000;border-radius:8px;overflow:hidden;position:relative}.bulk-preview-item.done{border-color:#4ade8099}.bulk-preview-item.error{border-color:#f8717199}.bulk-preview-img{aspect-ratio:1;display:block;object-fit:cover;width:100%}.bulk-preview-overlay{align-items:center;background:#00000059;display:flex;inset:0;justify-content:center;opacity:0;position:absolute;transition:opacity .2s}.bulk-preview-item.done .bulk-preview-overlay,.bulk-preview-item.error .bulk-preview-overlay,.bulk-preview-item:hover .bulk-preview-overlay{opacity:1}.bulk-remove-btn{align-items:center;background:#0009;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.75rem;height:24px;justify-content:center;width:24px}.bulk-status-icon{color:#4ade80;font-size:1.3rem;font-weight:700}.bulk-status-icon.error{color:#f87171}.bulk-preview-name{background:#000000a6;bottom:0;color:#ffffffd9;font-size:.6rem;left:0;overflow:hidden;padding:2px 4px;position:absolute;right:0;text-align:center;text-overflow:ellipsis;white-space:nowrap}.bulk-spinner{animation:spin .7s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.admin-layout,.admin-login-wrap{--ap:#e879a0;--as:#1a1a24;--as2:#22222f;--ab:#ffffff14;--at:#e2e2e8;--am:#8888a0;--ok:#4ade80;--err:#f87171;--warn:#fbbf24;font-family:Inter,Poppins,sans-serif}.admin-layout{background:#0f0f13;color:var(--at);display:flex;min-height:100vh}.admin-main{flex:1 1;min-height:100vh;overflow-y:auto;padding:32px}.admin-sidebar{background:var(--as);border-right:1px solid var(--ab);display:flex;flex-direction:column;flex-shrink:0;min-height:100vh;padding:20px 0;width:210px}.admin-sidebar-logo{align-items:center;border-bottom:1px solid var(--ab);display:flex;font-size:1.1rem;gap:10px;margin-bottom:12px;padding:0 18px 22px}.admin-logo-text{color:var(--ap);font-size:1rem;font-weight:700}.admin-sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;padding:0 8px}.admin-nav-link{align-items:center;border-radius:8px;color:var(--am);display:flex;font-size:.88rem;font-weight:500;gap:10px;padding:9px 12px;text-decoration:none;transition:all .18s}.admin-nav-link:hover{background:var(--as2);color:var(--at)}.admin-nav-link.active{background:#e879a026;color:var(--ap)}.admin-sidebar-footer{border-top:1px solid var(--ab);display:flex;flex-direction:column;padding:12px 8px 0}.admin-logout-btn{background:none;border:1px solid var(--ab);border-radius:8px;color:var(--am);cursor:pointer;font-size:.85rem;padding:8px 12px;text-align:left;transition:all .2s}.admin-logout-btn:hover{border-color:var(--err);color:var(--err)}.admin-login-wrap{align-items:center;background:radial-gradient(ellipse at 50% 0,#e879a01a 0,#0000 60%),#0f0f13;display:flex;justify-content:center;min-height:100vh}.admin-login-card{background:var(--as);border:1px solid var(--ab);border-radius:20px;max-width:360px;padding:44px 36px;text-align:center;width:100%}.admin-login-icon{font-size:2.8rem;margin-bottom:10px}.admin-login-title{color:var(--at);font-size:1.4rem;font-weight:700;margin-bottom:4px}.admin-login-sub{color:var(--am);font-size:.85rem;margin-bottom:28px}.admin-login-form{display:flex;flex-direction:column;gap:12px}.admin-login-err{color:var(--err);font-size:.82rem}.admin-login-hint{color:var(--am);font-size:.76rem;margin-top:18px}.admin-input{background:var(--as2);border:1px solid var(--ab);border-radius:8px;color:var(--at);font-family:inherit;font-size:.9rem;padding:10px 12px;transition:border-color .2s;width:100%}.admin-input:focus{border-color:var(--ap);outline:none}.admin-textarea{background:var(--as2);border:1px solid var(--ab);border-radius:8px;color:var(--at);font-family:inherit;font-size:.9rem;min-height:90px;padding:10px 12px;resize:vertical;transition:border-color .2s;width:100%}.admin-textarea:focus{border-color:var(--ap);outline:none}.admin-select{border:1px solid var(--ab);border-radius:8px;color:var(--at);font-family:inherit;font-size:.88rem;padding:10px 12px;width:100%}.admin-select,.admin-select option{background:var(--as2)}.admin-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:.87rem;font-weight:500;gap:6px;padding:9px 16px;transition:all .18s}.admin-btn:disabled{cursor:not-allowed;opacity:.5}.admin-btn-primary{background:var(--ap);color:#fff}.admin-btn-primary:hover:not(:disabled){background:#d4608a}.admin-btn-secondary{background:var(--as2);border:1px solid var(--ab);color:var(--at)}.admin-btn-secondary:hover{border-color:var(--ap);color:var(--ap)}.admin-btn-danger{background:#f871711f;border:1px solid #f8717140;color:var(--err)}.admin-btn-danger:hover{background:#f8717138}.admin-btn-sm{font-size:.8rem;padding:5px 11px}.admin-page-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:22px}.admin-page-title{color:var(--at);font-size:1.25rem;font-weight:700}.admin-card{background:var(--as);border:1px solid var(--ab);border-radius:14px;padding:20px}.admin-table{border-collapse:collapse;width:100%}.admin-table th{color:var(--am);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:9px 12px;text-align:left;text-transform:uppercase}.admin-table td,.admin-table th{border-bottom:1px solid var(--ab)}.admin-table td{font-size:.87rem;padding:11px 12px;vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#ffffff05}.admin-badge{border-radius:20px;display:inline-block;font-size:.74rem;font-weight:500;padding:3px 8px}.badge-green{background:#4ade8026;color:#4ade80}.badge-red{background:#f8717126;color:#f87171}.badge-yellow{background:#fbbf2426;color:#fbbf24}.badge-purple{background:#a78bfa26;color:#a78bfa}.admin-empty{color:var(--am);padding:50px 20px;text-align:center}.admin-empty-icon{font-size:2.5rem;margin-bottom:10px}.admin-actions{display:flex;gap:6px}.admin-search{background:var(--as2);border:1px solid var(--ab);border-radius:8px;color:var(--at);font-family:inherit;font-size:.87rem;padding:8px 12px;width:220px}.admin-search:focus{border-color:var(--ap);outline:none}.admin-form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.admin-form-group label{color:var(--am);font-size:.8rem;font-weight:500}.admin-grid-2{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.toast-container{bottom:24px;display:flex;flex-direction:column;gap:8px;position:fixed;right:24px;z-index:9999}.toast{border-radius:10px;box-shadow:0 4px 20px #0006;color:#fff;font-size:.87rem;max-width:280px;padding:10px 18px}.toast-success{background:#14532d;border:1px solid #4ade80}.toast-error{background:#7f1d1d;border:1px solid #f87171}.toast-warning{background:#78350f;border:1px solid #fbbf24}.admin-modal-overlay{align-items:center;background:#000000b8;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.admin-modal{background:var(--as);border:1px solid var(--ab);border-radius:16px;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.admin-modal-header{align-items:center;border-bottom:1px solid var(--ab);display:flex;justify-content:space-between;padding:18px 22px 14px}.admin-modal-header h3{font-size:.97rem;font-weight:600}.admin-modal-close{background:none;border:none;border-radius:5px;color:var(--am);cursor:pointer;font-size:1rem;padding:3px 7px}.admin-modal-close:hover{color:var(--at)}.admin-modal-body{padding:18px 22px 22px}@media (max-width:768px){.admin-sidebar{width:56px}.admin-logo-text,.admin-logout-btn,.admin-nav-link span:last-child{display:none}.admin-nav-link{justify-content:center;padding:10px}.admin-main{padding:16px}}.anniv-overlay{align-items:center;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#05050feb;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1200}.anniv-media{inset:0;overflow:hidden;position:absolute;z-index:1}.anniv-media:after{background:radial-gradient(ellipse at center,#ff69b440,#05050fe6);content:"";inset:0;position:absolute}.anniv-media img,.anniv-media video{height:100%;object-fit:cover;opacity:.45;width:100%}.anniv-media-fallback{display:grid;font-size:6rem;height:100%;opacity:.35;place-items:center;width:100%}.anniv-card{background:#0c0819c7!important;border:1px solid #ff69b44d!important;border-radius:26px;box-shadow:0 20px 60px #0000008c;max-width:620px;padding:36px 32px;position:relative;text-align:center;width:100%;z-index:2}.anniv-badge{background:#ff69b433;border-radius:999px;color:#ffb6c1;display:inline-block;font-size:.78rem;letter-spacing:.08em;margin-bottom:16px;padding:6px 14px;text-transform:uppercase}.anniv-title{color:#ffd1e6;font-family:Dancing Script,cursive;font-size:2.8rem;margin-bottom:12px;text-shadow:0 0 25px #ff69b499}.anniv-message{color:#ffffffe6;font-size:1.05rem;line-height:1.7;margin-bottom:20px;white-space:pre-line}.anniv-audio{margin:16px 0 10px}.anniv-audio audio{width:100%}.anniv-actions{align-items:center;display:flex;flex-direction:column;gap:10px;margin-top:10px}.anniv-countdown{color:#fff9;font-size:.85rem;font-style:italic}@media (max-width:600px){.anniv-card{padding:28px 20px}.anniv-title{font-size:2.2rem}}
/*# sourceMappingURL=main.c07ad351.css.map*/