@font-face{font-family:Harry P;src:url(/assets/HarryP-331c720e.ttf) format("truetype");font-weight:400;font-style:normal}:root{--font-heading: "Cinzel Decorative", cursive;--font-harry: "Harry P", serif;--font-display: "Crimson Text", serif;--font-body: "Inter", sans-serif;--font-mono: "JetBrains Mono", monospace;--gold: #FFD700;--gold-light: #FFE55C;--gold-dark: #B8860B;--text-primary: #FFFFFF;--text-secondary: rgba(255, 255, 255, .7);--dark-bg: #0a0a0a;--ink: #2c1810}#root{width:100%;margin:0;padding:0;cursor:url(/assets/wand-3daceefc.svg) 2 2,auto}a,button,input,label,select,textarea,[role=button]{cursor:url(/assets/wand-3daceefc.svg) 2 2,pointer!important}.landing-wrapper{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;justify-content:center;align-items:center}.content-overlay{position:relative;z-index:10;text-align:center;pointer-events:none}.countdown-container{position:relative;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;-webkit-user-select:none;user-select:none}.countdown-label{font-family:var(--font-ui);font-size:.8rem;color:#fff6;letter-spacing:.3em;text-transform:uppercase;margin-bottom:40px}.countdown-blocks{display:flex;align-items:baseline;gap:10px}.countdown-sep{font-family:var(--font-mono);font-size:clamp(3rem,8vw,10rem);font-weight:700;color:#fff;opacity:.2;margin-top:-10px}.time-block{display:flex;flex-direction:column;align-items:center}.time-value{font-family:var(--font-mono);font-size:clamp(4rem,10vw,12rem);font-weight:800;color:#fff;line-height:1;letter-spacing:-.02em;transition:all .3s}.time-label{font-family:var(--font-ui);font-size:.7rem;color:#fff6;letter-spacing:.25em;margin-top:12px}.countdown-hint{font-family:var(--font-ui);font-size:.7rem;color:#ffffff4d;letter-spacing:.2em;margin-top:60px}.mouse-glow{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:1;background:radial-gradient(600px circle at var(--mouse-x, 50%) var(--mouse-y, 50%),hsla(220,80%,60%,.07),transparent 40%)}.skip-btn{position:fixed;bottom:30px;right:30px;z-index:200;background:none;border:1px solid rgba(255,255,255,.2);color:#ffffff4d;font-family:var(--font-ui);font-size:12px;padding:8px 16px;border-radius:20px;cursor:pointer;transition:all .3s;pointer-events:all;letter-spacing:2px;text-transform:uppercase}.skip-btn:hover{color:#ffffffb3;border-color:#ffffff80}.transition-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;pointer-events:none;background-color:transparent}.transition-overlay canvas{width:100%;height:100%}.stun-flash{position:fixed;top:0;right:0;bottom:0;left:0;background:white;opacity:0;z-index:600;pointer-events:none}.main-page-wrapper{opacity:0;transition:opacity 1.2s ease-out}.main-page-wrapper.visible{opacity:1}.anniversary-page{position:relative;z-index:1;background:var(--dark-bg)}.hero-section{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;position:relative;overflow:hidden}.hero-content{position:relative;z-index:2;text-align:center;padding:0 20px}.hero-title{font-family:var(--font-harry);font-size:clamp(4rem,12vw,9rem);color:var(--gold);margin-bottom:30px;line-height:1.3;perspective:500px}.hero-letter{will-change:transform,opacity}.hero-subtitle{font-family:var(--font-body);font-size:clamp(1rem,2vw,1.5rem);color:var(--text-secondary);font-style:italic;letter-spacing:2px}.hero-stars{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;z-index:0}.hero-star{position:absolute;width:3px;height:3px;background:var(--gold-light);border-radius:50%;animation:twinkle var(--duration, 3s) infinite alternate}@keyframes twinkle{0%{opacity:.1;transform:scale(.5)}to{opacity:.8;transform:scale(1.2)}}.snitch{color:var(--gold);will-change:transform}.footer-section{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:80vh;position:relative;overflow:hidden;text-align:center}.footer-message{position:relative;z-index:2}.footer-names{font-family:var(--font-body);font-size:clamp(1.2rem,2.5vw,2rem);color:var(--text-secondary);letter-spacing:4px;text-transform:uppercase;margin-bottom:20px}.footer-forever{font-family:var(--font-display);font-size:clamp(2.5rem,6vw,5rem);color:var(--gold);margin-bottom:20px;line-height:1.2}.footer-date{font-family:var(--font-body);font-size:clamp(.9rem,1.5vw,1.2rem);color:var(--text-secondary);font-style:italic;letter-spacing:3px}.float-heart{will-change:transform,opacity;pointer-events:none}.gallery-section{padding:100px 40px}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:30px;max-width:1200px;margin:0 auto 60px;perspective:1000px}.polaroid{background:#1a1a24;border:1px solid rgba(212,164,55,.15);border-radius:8px;padding:15px 15px 20px;transition:transform .3s,box-shadow .3s;will-change:transform,opacity;cursor:pointer}.polaroid:hover{transform:translateY(-8px) rotateY(0)!important;box-shadow:0 20px 50px #d4a43726}.polaroid-image{width:100%;aspect-ratio:4/3;background:linear-gradient(135deg,#12121a,#1a1a2e);border-radius:4px;display:flex;justify-content:center;align-items:center;margin-bottom:15px;overflow:hidden}.polaroid-placeholder{font-size:48px;opacity:.3}.polaroid-caption{font-family:var(--font-body);font-size:.9rem;color:var(--text-secondary);text-align:center;font-style:italic}.video-placeholder{max-width:700px;margin:0 auto;aspect-ratio:16/9;background:linear-gradient(135deg,#12121a,#1a1a2e);border:1px solid rgba(212,164,55,.15);border-radius:12px;display:flex;justify-content:center;align-items:center;cursor:pointer;transition:box-shadow .3s}.video-placeholder:hover{box-shadow:0 10px 40px #d4a4371a}.video-inner{text-align:center;color:var(--text-secondary)}.video-icon{font-size:60px;display:block;margin-bottom:10px;opacity:.4}.timeline-section{padding:100px 20px}.timeline{position:relative;max-width:900px;margin:0 auto}.timeline-line{position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,transparent,var(--gold-dark),var(--gold),var(--gold-dark),transparent);transform:translate(-50%)}.timeline-item{position:relative;width:45%;margin-bottom:50px;will-change:transform,opacity}.timeline-left{margin-right:auto;padding-right:40px;text-align:right}.timeline-right{margin-left:auto;padding-left:40px;text-align:left}.timeline-dot{position:absolute;width:14px;height:14px;background:var(--gold);border-radius:50%;top:20px;box-shadow:0 0 15px #d4a43766}.timeline-left .timeline-dot{right:-7px}.timeline-right .timeline-dot{left:-7px}.timeline-card{background:rgba(26,26,36,.8);border:1px solid rgba(212,164,55,.12);border-radius:12px;padding:25px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.timeline-date{font-family:var(--font-ui);font-size:.75rem;color:var(--gold);letter-spacing:2px;text-transform:uppercase;display:block;margin-bottom:8px}.timeline-title{font-family:var(--font-display);font-size:1.3rem;color:var(--gold-light);margin-bottom:10px}.timeline-desc{font-family:var(--font-body);font-size:.95rem;color:var(--text-secondary);line-height:1.6}.secret-message-section{padding:80px 40px;text-align:center}.secret-subtitle{font-family:var(--font-body);font-size:1.1rem;color:#ffffff80;margin-bottom:40px;font-style:italic}.secret-wrapper{max-width:600px;margin:0 auto}.secret-reveal-btn{font-family:var(--font-display);font-size:1.2rem;color:var(--gold);background:rgba(212,164,55,.08);border:1px solid rgba(212,164,55,.25);padding:20px 48px;border-radius:12px;cursor:pointer;transition:all .4s;letter-spacing:.5px}.secret-reveal-btn:hover{background:rgba(212,164,55,.15);border-color:var(--gold);transform:scale(1.03);box-shadow:0 0 30px #d4a43726}.secret-content{animation:secretFadeIn .8s ease-out}@keyframes secretFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.secret-label{font-family:var(--font-ui);font-size:.85rem;color:#fff6;text-transform:uppercase;letter-spacing:2px;margin-bottom:16px}.secret-code-box{background:rgba(0,0,0,.5);border:1px solid rgba(212,164,55,.15);border-radius:10px;padding:24px;margin-bottom:20px;overflow-wrap:break-word;word-break:break-all}.secret-base64{font-family:var(--font-mono);font-size:1rem;color:#64ff96cc;letter-spacing:1px;line-height:1.6}.secret-hint{font-family:var(--font-body);font-size:.9rem;color:#fff6;margin-bottom:24px}.secret-decode-btn{font-family:var(--font-ui);font-size:.95rem;color:#ffffffb3;background:rgba(212,164,55,.1);border:1px solid rgba(212,164,55,.2);padding:14px 36px;border-radius:10px;cursor:pointer;transition:all .3s}.secret-decode-btn:hover{color:var(--gold-light);background:rgba(212,164,55,.18);border-color:var(--gold);box-shadow:0 0 20px #d4a4371f}.secret-decoded{animation:secretFadeIn .6s ease-out;margin-top:24px;padding:30px;background:radial-gradient(ellipse at center,rgba(212,164,55,.08),transparent 70%);border-radius:12px}.secret-decoded-text{font-family:var(--font-display);font-size:1.8rem;color:var(--gold);text-shadow:0 0 30px rgba(212,164,55,.3);line-height:1.5}.marauder-section{padding:100px 40px;cursor:none}.wand-cursor{position:absolute;font-size:28px;color:var(--gold);pointer-events:none;z-index:10;filter:drop-shadow(0 0 8px rgba(212,164,55,.6));transition:left .05s,top .05s}.marauder-map{max-width:800px;margin:0 auto;background:linear-gradient(135deg,#f5e6c8,#d4b896);border-radius:12px;padding:60px 50px;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000080,inset 0 0 100px #8b5a2b33}.marauder-map:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 30px,rgba(139,90,43,.05) 30px,rgba(139,90,43,.05) 31px),repeating-linear-gradient(90deg,transparent,transparent 30px,rgba(139,90,43,.05) 30px,rgba(139,90,43,.05) 31px);pointer-events:none}.map-header{text-align:center;margin-bottom:40px}.map-subtitle{font-family:var(--font-body);font-size:.9rem;color:#1a0a0099;font-style:italic;line-height:1.8}.map-reveal-btn{display:block;margin:40px auto;background:none;border:2px solid rgba(26,10,0,.3);padding:20px 40px;border-radius:8px;cursor:pointer;transition:all .3s}.map-reveal-btn:hover{border-color:#1a0a0099;background:rgba(26,10,0,.05)}.map-spell{font-family:var(--font-body);font-size:1.1rem;color:var(--ink);font-style:italic}.map-message{text-align:center;padding:30px 0}.map-love-msg{font-family:var(--font-body);font-size:1.2rem;color:var(--ink);line-height:2.2;will-change:clip-path,opacity}.map-quotes{margin-top:50px;border-top:1px solid rgba(26,10,0,.15);padding-top:30px}.map-quote{font-family:var(--font-body);font-size:.85rem;color:#1a0a0073;text-align:center;font-style:italic;margin-bottom:15px;line-height:1.6}@media (max-width: 768px){.timeline-line{left:20px}.timeline-item{width:calc(100% - 50px);margin-left:50px!important;margin-right:0!important;padding-left:30px!important;padding-right:0!important;text-align:left!important}.timeline-dot{left:-37px!important;right:auto!important}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:20px}.marauder-map{padding:40px 25px}.section{padding:60px 20px}.shelf-books{gap:8px}.book{width:50px;height:160px}.book-open{flex-direction:column;max-width:90vw}}.sudoku-section{padding:100px 40px;text-align:center}.sudoku-hint{font-family:var(--font-body);color:var(--text-secondary);margin-bottom:40px;font-style:italic}.sudoku-board{display:inline-block;background:linear-gradient(135deg,#f5e6c8,#d4b896);padding:20px;border-radius:12px;box-shadow:0 15px 50px #0006}.sudoku-row{display:flex}.sudoku-cell{width:65px;height:65px;text-align:center;font-family:var(--font-display);font-size:1.5rem;color:var(--ink);background:rgba(255,255,255,.4);border:1px solid rgba(139,90,43,.25);outline:none;transition:all .2s;cursor:pointer}.sudoku-cell:nth-child(2){border-right:2px solid rgba(139,90,43,.5)}.sudoku-row:nth-child(2) .sudoku-cell{border-bottom:2px solid rgba(139,90,43,.5)}.sudoku-cell:focus{background:rgba(212,164,55,.2);box-shadow:inset 0 0 10px #d4a4374d}.sudoku-cell.prefilled{font-weight:700;color:#1a0a00cc;background:rgba(255,255,255,.6);cursor:default}.sudoku-cell.error{background:rgba(200,50,50,.2);color:#c83232}.sudoku-cell.solved{background:rgba(100,200,100,.15)}.sudoku-message{margin-top:40px}.sudoku-reveal{font-family:var(--font-display);font-size:2rem;color:var(--gold);margin-bottom:15px}.sudoku-love{font-family:var(--font-body);font-size:1.1rem;color:var(--text-secondary);font-style:italic;max-width:500px;margin:0 auto;line-height:1.8}.crossword-section{padding:100px 40px}.crossword-subtitle{font-family:var(--font-body);font-size:1.1rem;color:#fff9;text-align:center;margin-bottom:40px;font-style:italic}.crossword-wrapper{max-width:900px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:30px}.crossword-grid-container{background:linear-gradient(135deg,rgba(245,230,200,.08),rgba(212,164,55,.05));border-radius:12px;padding:20px;border:1px solid rgba(212,164,55,.15);box-shadow:0 10px 40px #0000004d}.crossword-grid{display:grid;gap:2px;width:min(400px,80vw);height:min(400px,80vw)}.crossword-cell{position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;border-radius:3px;transition:background .2s}.crossword-cell.black{background:transparent}.crossword-cell.white{background:rgba(245,230,200,.9);border:1px solid rgba(139,90,43,.2);cursor:pointer}.crossword-cell.white:hover{background:rgba(245,230,200,1)}.crossword-cell.highlighted{background:rgba(212,164,55,.35)!important;border-color:var(--gold)}.crossword-cell.solved{background:rgba(100,200,120,.2)!important;border-color:#64c87866}.crossword-cell.solved.highlighted{background:rgba(100,200,120,.35)!important}.cell-number{position:absolute;top:2px;left:3px;font-family:var(--font-ui);font-size:.55rem;font-weight:600;color:#1a0a0080;z-index:1;line-height:1}.cell-input{width:100%;height:100%;border:none;background:transparent;text-align:center;font-family:var(--font-mono);font-size:clamp(.7rem,2.5vw,1.1rem);font-weight:700;color:var(--ink);text-transform:uppercase;cursor:pointer;outline:none;caret-color:var(--gold-dark);padding:0}.cell-input:focus{background:rgba(212,164,55,.15)}.crossword-clues{display:flex;gap:40px;width:100%;max-width:800px}.clues-column{flex:1}.clues-heading{font-family:var(--font-display);font-size:1rem;color:var(--gold);margin-bottom:12px}.clue-item{font-family:var(--font-body);font-size:.9rem;color:#fff9;padding:6px 10px;border-radius:6px;cursor:pointer;transition:all .2s;margin-bottom:4px;line-height:1.4}.clue-item:hover{background:rgba(212,164,55,.1);color:#ffffffd9}.clue-item.active{background:rgba(212,164,55,.15);color:var(--gold-light);border-left:2px solid var(--gold)}.clue-item.clue-solved{color:#64c878b3;text-decoration:line-through;text-decoration-color:#64c8784d}.clue-num{font-weight:700;color:var(--gold);margin-right:4px}.crossword-reveal-btn{font-family:var(--font-ui);font-size:.85rem;color:#ffffff80;background:none;border:1px solid rgba(255,255,255,.15);padding:10px 24px;border-radius:8px;cursor:pointer;transition:all .3s}.crossword-reveal-btn:hover{color:var(--gold-light);border-color:var(--gold);background:rgba(212,164,55,.1)}.crossword-success{text-align:center;margin-top:20px;animation:successPulse 1s ease-out}.crossword-success p{font-family:var(--font-display);font-size:1.3rem;color:var(--gold);text-shadow:0 0 20px rgba(212,164,55,.4)}@keyframes successPulse{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}.future-plans-section{padding:100px 40px}.plans-subtitle{font-family:var(--font-body);font-size:1.1rem;color:#ffffff80;text-align:center;margin-bottom:50px;font-style:italic}.plans-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;max-width:700px;margin:0 auto}.horizontal-gallery-section{width:100%;height:100vh;position:relative;overflow:hidden;background:var(--dark-bg);display:flex;align-items:center}.horizontal-wrapper{display:flex;gap:0;padding:0 calc(50vw - 300px);width:max-content;height:500px;will-change:transform;align-items:center;overflow:visible}.horizontal-panel{width:600px;height:100%;flex-shrink:0;display:flex;justify-content:center;align-items:center;position:relative;overflow:hidden;border-radius:12px;box-shadow:0 10px 30px #00000080;background:var(--card-bg, #2a2a2a);border:none;margin:0 20px;transform-origin:center center}.panel-image-container{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;background:linear-gradient(45deg,#1a1a1a,#2c3e50)}.panel-image{width:100%;height:100%;object-fit:contain;will-change:transform;opacity:.9;transition:opacity .5s}.panel-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.2);z-index:2;transition:background .3s}.horizontal-panel:hover .panel-overlay{background:rgba(0,0,0,0)}.panel-content-minimal{position:absolute;z-index:10;width:100%;height:100%;pointer-events:none}.panel-number{font-family:var(--font-harry);font-size:4rem;color:#fff9;text-shadow:0 2px 5px rgba(0,0,0,.8);opacity:.7;transition:all .3s ease;position:absolute;bottom:10px;left:20px;line-height:1}.horizontal-panel:hover .panel-number{opacity:1;color:var(--gold);transform:scale(1.1)}.plan-card-flip{perspective:800px;height:200px;width:320px;cursor:pointer}.plan-card-inner{position:relative;width:100%;height:100%;transition:transform .7s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.plan-card-flip.flipped .plan-card-inner{transform:rotateY(180deg)}.plan-card-front,.plan-card-back{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;border-radius:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px}.plan-card-front{background:linear-gradient(145deg,rgba(212,164,55,.06),rgba(255,255,255,.02));border:1px dashed rgba(212,164,55,.2)}.plan-card-flip:hover .plan-card-front{border-color:var(--gold);box-shadow:0 0 25px #d4a4371a}.plan-mystery-num{font-family:var(--font-mono);font-size:.75rem;color:#d4a43759;position:absolute;top:12px;left:14px}.plan-mystery-icon{font-family:var(--font-display);font-size:2.8rem;color:#d4a43740;margin-bottom:10px}.plan-mystery-text{font-family:var(--font-body);font-size:.85rem;color:#ffffff4d;font-style:italic}.plan-card-back{background:rgba(212,164,55,.06);border:1px solid rgba(212,164,55,.2);transform:rotateY(180deg)}.plan-icon{font-size:2.2rem;display:block;margin-bottom:12px}.plan-title{font-family:var(--font-ui);font-size:1.05rem;font-weight:600;color:var(--gold-light);margin-bottom:8px;text-align:center}.plan-desc{font-family:var(--font-body);font-size:.85rem;color:#ffffff73;line-height:1.5;text-align:center}.plans-footer-note{font-family:var(--font-body);font-size:1rem;color:var(--gold);text-align:center;margin-top:40px;font-style:italic;animation:secretFadeIn .8s ease-out}.bookshelf-section{padding:100px 40px}.bookshelf{max-width:700px;margin:0 auto;position:relative}.shelf-books{display:flex;justify-content:center;gap:12px;padding:0 30px 20px;position:relative;z-index:2}.book{width:70px;height:220px;background:var(--book-color, #7c1b1b);border-radius:3px 6px 6px 3px;cursor:pointer;position:relative;transition:transform .3s,box-shadow .3s;display:flex;align-items:center;justify-content:center;box-shadow:2px 2px 8px #0006,inset -3px 0 8px #0000004d}.book:before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;background:rgba(255,255,255,.1);border-radius:3px 0 0 3px}.book:hover{transform:translateY(-15px) rotate(-2deg);box-shadow:4px 10px 20px #00000080}.book-spine{writing-mode:vertical-rl;text-orientation:mixed;font-family:var(--font-display);font-size:.65rem;color:var(--gold-light);text-align:center;letter-spacing:1px;display:flex;flex-direction:column;align-items:center;gap:4px;transform:rotate(180deg)}.shelf-wood{height:20px;background:linear-gradient(to bottom,#6b4226,#4a2e1a);border-radius:0 0 4px 4px;box-shadow:0 4px 12px #00000080;position:relative}.shelf-wood:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:rgba(255,255,255,.1)}.book-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.8);display:flex;justify-content:center;align-items:center;z-index:100;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:overlayFadeIn .3s ease-out}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}.book-open{display:flex;max-width:700px;width:90%;background:linear-gradient(135deg,#f5e6c8,#e8d5b0);border-radius:8px;overflow:hidden;box-shadow:0 30px 80px #00000080;position:relative;animation:bookSlideIn .4s ease-out}@keyframes bookSlideIn{0%{opacity:0;transform:scale(.9) translateY(30px)}to{opacity:1;transform:scale(1) translateY(0)}}.book-open-left{flex:1;padding:50px 30px;background:rgba(139,90,43,.08);display:flex;flex-direction:column;justify-content:center;align-items:center;border-right:1px solid rgba(139,90,43,.15)}.book-open-title{font-family:var(--font-display);font-size:1.5rem;color:var(--ink);margin-bottom:20px}.book-open-decor{color:var(--gold-dark);font-size:1.2rem;letter-spacing:8px}.book-open-right{flex:1.5;padding:50px 40px;display:flex;align-items:center}.book-open-note{font-family:var(--font-body);font-size:1.05rem;color:var(--ink);line-height:1.9;font-style:italic}.book-close-btn{position:absolute;top:15px;right:20px;background:none;border:none;font-size:1.5rem;color:#1a0a0066;cursor:pointer;transition:color .2s}.book-close-btn:hover{color:#1a0a00cc}.mosaic-section{padding:120px 20px;background:var(--dark-bg);display:flex;justify-content:center;position:relative;overflow:hidden}.mosaic-container{max-width:1000px;width:100%;text-align:center;position:relative;z-index:2}.mosaic-image-wrapper{position:relative;width:100%;border-radius:12px;overflow:hidden;box-shadow:0 20px 60px #00000080;border:1px solid rgba(212,164,55,.2);margin-bottom:50px;background:#000}.mosaic-image{width:100%;height:auto;display:block;object-fit:cover;max-height:80vh}.mosaic-image-wrapper:before,.mosaic-image-wrapper:after{content:"";position:absolute;width:40px;height:40px;border:2px solid var(--gold);transition:all .5s ease;z-index:3;pointer-events:none}.mosaic-image-wrapper:before{top:20px;left:20px;border-right:none;border-bottom:none}.mosaic-image-wrapper:after{bottom:20px;right:20px;border-left:none;border-top:none}.mosaic-image-wrapper:hover:before{top:10px;left:10px}.mosaic-image-wrapper:hover:after{bottom:10px;right:10px}.mosaic-content{max-width:700px;margin:0 auto;padding:0 20px}.mosaic-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,3rem);color:var(--gold);margin-bottom:20px;text-shadow:0 4px 10px rgba(0,0,0,.3)}.mosaic-message{font-family:var(--font-body);font-size:clamp(1rem,2vw,1.2rem);color:var(--text-secondary);line-height:1.8;font-style:italic;letter-spacing:.5px}:root{--font-display: "Cinzel Decorative", serif;--font-body: "Crimson Text", serif;--font-ui: "Inter", sans-serif;--font-mono: "JetBrains Mono", monospace;--gold: #d4a437;--gold-light: #f0d27a;--gold-dark: #a67c21;--gryffindor-red: #9c1203;--parchment: #f5e6c8;--parchment-dark: #d4b896;--ink: #1a0a00;--dark-bg: #0a0a0f;--dark-surface: #12121a;--text-primary: #ffffff;--text-secondary: rgba(255, 255, 255, .7);font-family:var(--font-ui);line-height:1.5;font-weight:400;color-scheme:dark;color:var(--text-primary);background-color:var(--dark-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--dark-bg)}::-webkit-scrollbar-thumb{background:var(--gold-dark);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--gold)}.section{min-height:100vh;padding:80px 40px;position:relative;overflow:hidden}.section-title{font-family:var(--font-display);font-size:clamp(2rem,5vw,4rem);color:var(--gold);text-align:center;margin-bottom:60px}
