:root{--r1: #E40303;--r2: #FF8C00;--r3: #FFED00;--r4: #008026;--r5: #24408E;--r6: #732982;--freiburg-red: #C41E3A;--freiburg-dark: #8B1528;--pink: #FF6B9D;--coral: #FB7185;--lavender: #C084FC;--sky: #60A5FA;--mint: #34D399;--gold: #FBBF24;--sunset: #FB923C;--ocean: #06B6D4;--bg-deep: #0C0818;--bg-mid: #151027;--bg-card: rgba(255, 255, 255, .04);--glass: rgba(255, 255, 255, .06);--glass-border: rgba(255, 255, 255, .1);--frame-gold: #D4A546;--frame-gold-light: #F0D68A;--font-display: "Bangers", cursive;--font-script: "Pacifico", cursive;--font-body: "Comic Neue", cursive;--outline: 3px solid #222;--outline-thin: 2px solid #222;--rainbow: linear-gradient(90deg, var(--r1), var(--r2), var(--r3), var(--r4), var(--r5), var(--r6))}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg-deep);color:#fff;min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 15% 15%,rgba(196,30,58,.08) 0%,transparent 50%),radial-gradient(ellipse at 85% 20%,rgba(192,132,252,.1) 0%,transparent 50%),radial-gradient(ellipse at 50% 70%,rgba(96,165,250,.06) 0%,transparent 50%),radial-gradient(ellipse at 30% 90%,rgba(52,211,153,.05) 0%,transparent 40%);z-index:0;pointer-events:none}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle,rgba(255,255,255,.015) 1px,transparent 1px);background-size:4px 4px;pointer-events:none;z-index:0}#particles{position:fixed;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1}.deco{position:fixed;pointer-events:none;z-index:1}.deco-muenster-left{width:120px;top:10%;left:10px;opacity:.6}.deco-muenster-right{width:120px;top:10%;right:10px;opacity:.6}.app{position:relative;z-index:2;max-width:1200px;margin:0 auto}.header{position:relative;text-align:center;padding:70px 20px 80px;background:linear-gradient(160deg,var(--freiburg-red) 0%,var(--r2) 15%,var(--r3) 28%,var(--r4) 42%,var(--r5) 57%,var(--r6) 71%,var(--pink) 85%,var(--freiburg-red) 100%);background-size:400% 400%;animation:rainbowShift 12s ease-in-out infinite;border:var(--outline);border-radius:28px 28px 0 0;overflow:hidden;margin-top:20px}.header-glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.15) 0%,transparent 70%);animation:glowPulse 4s ease-in-out infinite;pointer-events:none}@keyframes glowPulse{0%,to{transform:translate(-50%,-50%) scale(.8);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.2);opacity:1}}.header-stripes{position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(-45deg,transparent 0px,transparent 30px,rgba(255,255,255,.03) 30px,rgba(255,255,255,.03) 32px)}.header-rainbow-arc{position:absolute;top:0;left:10%;right:10%;height:120px;pointer-events:none;animation:arcFloat 6s ease-in-out infinite}@keyframes arcFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.header-skyline{position:absolute;bottom:35px;left:0;right:0;height:200px;pointer-events:none}.header-skyline svg{width:100%;height:100%}@keyframes rainbowShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.header-content{position:relative;z-index:2}.title{font-family:var(--font-script);font-size:clamp(3.2rem,10vw,6.5rem);color:#fff;text-shadow:5px 5px 0 #222,-2px -2px 0 #222,2px -2px 0 #222,-2px 2px 0 #222,0 0 60px rgba(255,255,255,.3),0 0 120px rgba(255,107,157,.15);letter-spacing:3px;line-height:1}.tagline{font-family:var(--font-display);font-size:clamp(1.1rem,3.5vw,1.8rem);letter-spacing:4px;margin-top:8px;text-shadow:2px 2px 0 #222;color:#fff}.tagline-sub{font-family:var(--font-body);font-size:clamp(.8rem,2vw,1rem);letter-spacing:3px;margin-top:6px;color:#ffffffb3;text-shadow:1px 1px 0 #222}.header-wave{position:absolute;bottom:-1px;left:0;right:0;line-height:0}.header-wave svg{width:100%;height:50px}.baechle{height:6px;margin:0 20px;border-radius:3px;overflow:hidden;position:relative}.baechle-water{height:100%;background:linear-gradient(90deg,transparent 0%,rgba(96,165,250,.3) 10%,rgba(52,211,153,.2) 30%,rgba(96,165,250,.4) 50%,rgba(52,211,153,.2) 70%,rgba(96,165,250,.3) 90%,transparent 100%);background-size:200% 100%;animation:baechleFlow 3s linear infinite;border-radius:3px}@keyframes baechleFlow{0%{background-position:0% 0}to{background-position:-200% 0}}.countdown-section{padding:20px 20px 0;margin-top:10px;position:relative;z-index:3}.countdown-bubble{background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:24px;padding:30px 24px;text-align:center;position:relative;overflow:hidden;box-shadow:0 8px 32px #0000004d,inset 0 1px #ffffff0d}.countdown-bubble:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--rainbow)}.countdown-heading{font-family:var(--font-display);font-size:clamp(1.2rem,3vw,1.8rem);letter-spacing:2px;color:var(--gold);text-shadow:2px 2px 0 #222;margin-bottom:20px}.countdown{display:flex;justify-content:center;align-items:center;gap:12px;flex-wrap:wrap}.countdown-item{display:flex;flex-direction:column;align-items:center}.countdown-number{font-family:var(--font-display);font-size:clamp(2.5rem,7vw,4.5rem);letter-spacing:2px;background:linear-gradient(135deg,var(--pink),var(--sunset),var(--gold),var(--mint),var(--sky),var(--lavender));background-size:300% 300%;animation:rainbowShift 6s ease-in-out infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(2px 3px 0 #222);line-height:1;min-width:80px}.countdown-label{font-family:var(--font-body);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:#fff6;margin-top:4px}.countdown-sep{font-family:var(--font-display);font-size:clamp(2rem,5vw,3.5rem);color:var(--lavender);text-shadow:2px 2px 0 #222;padding-bottom:20px;animation:sepPulse 1s ease-in-out infinite}@keyframes sepPulse{0%,to{opacity:1}50%{opacity:.3}}.countdown-sub{font-family:var(--font-display);font-size:clamp(.9rem,2.5vw,1.2rem);color:var(--mint);text-shadow:1px 1px 0 #222;margin-top:15px;letter-spacing:1px}.countdown-section.hidden{display:none}.gallery-section{padding:40px 20px;position:relative}.section-title{font-family:var(--font-display);font-size:clamp(1.5rem,4vw,2.2rem);text-align:center;letter-spacing:4px;margin-bottom:30px;background:linear-gradient(90deg,var(--freiburg-red),var(--pink),var(--gold),var(--mint),var(--sky),var(--lavender),var(--freiburg-red));background-size:200% auto;animation:rainbowShift 8s ease-in-out infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(2px 2px 0 #222)}.gallery-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:24px;perspective:1000px}.frame{position:relative;cursor:default;transition:transform .4s cubic-bezier(.25,.46,.45,.94),filter .4s ease,z-index 0s;transform-style:preserve-3d}.frame.revealed{cursor:pointer}.frame.revealed:hover{transform:scale(1.08) rotateY(-4deg) rotateX(2deg);filter:brightness(1.15) saturate(1.2);z-index:10}.frame.revealed:hover .frame-inner{box-shadow:0 10px #222,0 20px 50px #ff6b9d40,0 0 40px #c084fc26}.frame.revealed:hover .frame-border{border-color:var(--frame-gold-light);box-shadow:inset 0 0 0 2px var(--gold),inset 0 0 25px #fbbf244d}.frame.revealed:hover .day-badge{transform:scale(1.25) rotate(12deg);box-shadow:0 4px #222,0 6px 20px #ff6b9d80}.frame.revealed:hover .frame-label{color:var(--pink);text-shadow:0 0 15px rgba(255,107,157,.6),1px 1px 0 #222}.frame.locked{opacity:.6;transition:transform .3s ease,opacity .3s ease}.frame.locked:hover{opacity:.8;transform:scale(1.03)}.frame-inner{position:relative;aspect-ratio:2 / 3;border:var(--outline);border-radius:14px;overflow:hidden;box-shadow:0 6px #222,0 12px 30px #00000080;background:var(--bg-card);transition:box-shadow .4s ease}.frame.revealed .frame-inner{border:none;position:relative}.frame.revealed .frame-inner:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:16px;padding:3px;background:linear-gradient(var(--angle, 0deg),var(--r1),var(--r2),var(--r3),var(--r4),var(--r5),var(--r6));-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask-composite:exclude;z-index:0;animation:rotateBorder 3s linear infinite}@property --angle{syntax: "<angle>"; initial-value: 0deg; inherits: false;}@keyframes rotateBorder{to{--angle: 360deg}}.frame-border{position:absolute;top:0;right:0;bottom:0;left:0;border:5px solid var(--frame-gold);border-radius:12px;box-shadow:inset 0 0 0 1px var(--frame-gold-light),inset 0 0 12px #0000004d;z-index:1;pointer-events:none;transition:border-color .3s,box-shadow .3s}.frame-corner{position:absolute;width:14px;height:14px;z-index:2;pointer-events:none}.frame-corner svg{width:100%;height:100%}.frame-corner.tl{top:2px;left:2px}.frame-corner.tr{top:2px;right:2px;transform:scaleX(-1)}.frame-corner.bl{bottom:2px;left:2px;transform:scaleY(-1)}.frame-corner.br{bottom:2px;right:2px;transform:scale(-1)}.image-container{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;overflow:hidden}.image-container img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}.frame.revealed:hover .image-container img{transform:scale(1.05)}.image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:var(--font-display);color:#ffffff80;text-shadow:2px 2px 4px rgba(0,0,0,.3);gap:6px}.image-placeholder .lock-icon{font-size:1.8rem;opacity:.5}.image-placeholder .day-num{font-size:1.1rem;letter-spacing:2px}.curtain{position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;overflow:hidden;pointer-events:none}.curtain-half{position:absolute;top:0;bottom:0;width:50%;transition:transform 1.2s cubic-bezier(.68,-.15,.27,1.15);will-change:transform}.curtain-left{left:0;background:linear-gradient(90deg,#520e38,#7b1450,#b91c72,#7b1450 60%,#520e38,#7b1450 90%,#b91c72);border-right:2px solid #520E38}.curtain-right{right:0;background:linear-gradient(90deg,#b91c72,#7b1450 10%,#520e38,#7b1450 40%,#b91c72,#7b1450,#520e38);border-left:2px solid #520E38}.curtain-half:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(90deg,transparent 0px,rgba(255,255,255,.04) 3px,transparent 6px,rgba(0,0,0,.06) 9px,transparent 12px)}.curtain:after{content:"";position:absolute;top:12%;left:50%;transform:translate(-50%);width:10px;height:18px;background:var(--gold);border:2px solid #222;border-radius:0 0 5px 5px;z-index:4;transition:opacity .6s ease}.frame.revealed .curtain-left{transform:translate(-105%)}.frame.revealed .curtain-right{transform:translate(105%)}.frame.revealed .curtain:after{opacity:0}.day-badge{position:absolute;top:-10px;right:-10px;width:34px;height:34px;background:linear-gradient(135deg,var(--freiburg-red),var(--pink));border:var(--outline-thin);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.85rem;color:#fff;z-index:5;box-shadow:0 3px #222,0 5px 10px #0000004d;opacity:0;transform:scale(0);transition:all .5s cubic-bezier(.68,-.55,.27,1.55)}.frame.revealed .day-badge{opacity:1;transform:scale(1)}.frame-label{text-align:center;margin-top:10px;font-family:var(--font-display);font-size:.95rem;letter-spacing:2px;color:var(--gold);text-shadow:1px 1px 0 #222;transition:color .3s,text-shadow .3s}.sparkle-burst{position:absolute;top:0;right:0;bottom:0;left:0;z-index:10;pointer-events:none;overflow:visible}.sparkle{position:absolute;width:8px;height:8px;border-radius:50%;animation:sparkleFly 1s ease-out forwards;box-shadow:0 0 6px currentColor}@keyframes sparkleFly{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(var(--tx),var(--ty)) scale(0);opacity:0}}.frame.reveal-animate .curtain-left{transition-delay:.2s}.frame.reveal-animate .curtain-right{transition-delay:.3s}.frame.reveal-animate .day-badge{transition-delay:1s}.lightbox{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#080412f2;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s ease;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:20px;overflow-y:auto}.lightbox.active{opacity:1;pointer-events:all}.lightbox-close{position:fixed;top:16px;right:20px;font-size:2rem;color:#fff;background:linear-gradient(135deg,var(--freiburg-red),var(--coral));border:var(--outline);border-radius:50%;width:48px;height:48px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px #222,0 6px 15px #0006;transition:transform .2s ease;z-index:1001;font-family:var(--font-body);line-height:1}.lightbox-close:hover{transform:scale(1.1) rotate(90deg)}.lightbox-body{display:flex;gap:30px;max-width:1100px;width:100%;align-items:flex-start;transform:scale(.9) translateY(20px);transition:transform .5s cubic-bezier(.34,1.56,.64,1)}.lightbox.active .lightbox-body{transform:scale(1) translateY(0)}.lightbox-image-wrap{flex:0 1 auto;min-width:0;display:flex;flex-direction:column;align-items:center}.lightbox-frame{position:relative;line-height:0;display:inline-block;max-height:75vh;aspect-ratio:2 / 3;border:12px solid var(--frame-gold);border-radius:6px;box-shadow:inset 0 0 20px #0006,inset 0 0 0 2px var(--frame-gold-light),0 0 0 4px #222,0 0 0 8px var(--frame-gold),0 0 0 10px var(--frame-gold-light),0 0 0 12px #222,0 16px 60px #0009,0 0 80px #d4a5461a;overflow:hidden;background:#0a0a0a}.lightbox-frame:before{content:"";position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px;border-radius:14px;background:conic-gradient(from var(--angle, 0deg),var(--r1),var(--r2),var(--r3),var(--r4),var(--r5),var(--r6),var(--r1));z-index:-1;opacity:.4;filter:blur(15px);animation:rotateBorder 4s linear infinite}.lightbox-frame:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid rgba(240,214,138,.3);border-radius:2px;pointer-events:none;box-shadow:inset 0 1px #ffffff1a}.lightbox-frame img{display:block;width:100%;height:100%;object-fit:cover}.lightbox-title{font-family:var(--font-display);font-size:1.4rem;margin-top:12px;color:var(--gold);text-shadow:2px 2px 0 #222;letter-spacing:2px;text-align:center}.lightbox-placeholder{width:100%;aspect-ratio:2 / 3;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:4rem;color:#ffffff80}.lightbox-comments{flex:1 1 40%;min-width:0;max-height:80vh;display:flex;flex-direction:column;background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:20px;padding:24px;box-shadow:0 8px 32px #0000004d;position:relative;overflow:hidden}.lightbox-comments:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--rainbow)}.comments-heading{font-family:var(--font-display);font-size:1.3rem;letter-spacing:2px;color:var(--freiburg-red);text-shadow:2px 2px 0 #222;margin-bottom:16px}.comments-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;margin-bottom:16px;padding-right:4px;min-height:60px}.comments-list::-webkit-scrollbar{width:5px}.comments-list::-webkit-scrollbar-track{background:#ffffff08;border-radius:3px}.comments-list::-webkit-scrollbar-thumb{background:var(--lavender);border-radius:3px}.comment-bubble{background:#ffffff0f;border:1px solid rgba(255,255,255,.08);border-radius:16px 16px 16px 4px;padding:12px 14px;animation:commentIn .3s ease-out}@keyframes commentIn{0%{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.comment-author{font-family:var(--font-display);font-size:.9rem;color:var(--mint);text-shadow:1px 1px 0 #222;letter-spacing:1px}.comment-time{font-size:.7rem;color:#ffffff40;margin-left:8px}.comment-text{font-size:.95rem;color:#ffffffd9;margin-top:4px;line-height:1.4;word-break:break-word}.comments-empty{color:#ffffff40;font-style:italic;text-align:center;padding:20px 0}.comment-form{display:flex;flex-direction:column;gap:10px;border-top:1px solid rgba(255,255,255,.06);padding-top:16px}.comment-input,.comment-textarea{font-family:var(--font-body);font-size:.95rem;background:#ffffff0a;border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:10px 14px;color:#fff;outline:none;transition:border-color .2s,box-shadow .2s}.comment-input:focus,.comment-textarea:focus{border-color:var(--freiburg-red);box-shadow:0 0 0 3px #c41e3a33}.comment-input::placeholder,.comment-textarea::placeholder{color:#ffffff40}.comment-textarea{resize:vertical;min-height:60px}.comment-honeypot{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}.comment-submit{font-family:var(--font-display);font-size:1.1rem;letter-spacing:2px;padding:10px 20px;background:linear-gradient(135deg,var(--freiburg-red),var(--pink));border:var(--outline);border-radius:12px;color:#fff;cursor:pointer;box-shadow:0 4px #222,0 6px 15px #0000004d;transition:transform .15s,box-shadow .15s;text-shadow:1px 1px 0 #222}.comment-submit:hover{transform:translateY(-2px);box-shadow:0 6px #222,0 8px 20px #0006}.comment-submit:active{transform:translateY(2px);box-shadow:0 2px #222}.game-section{padding:20px 20px 0}.game-bubble{background:var(--glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:24px;padding:24px;text-align:center;position:relative;overflow:hidden;box-shadow:0 8px 32px #0000004d}.game-bubble:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--rainbow)}.game-heading{font-family:var(--font-display);font-size:clamp(1.3rem,3.5vw,2rem);letter-spacing:2px;background:linear-gradient(90deg,var(--freiburg-red),var(--pink),var(--gold),var(--mint),var(--sky),var(--lavender));background-size:200% auto;animation:rainbowShift 6s ease-in-out infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(2px 2px 0 #222);margin-bottom:6px}.game-sub{font-family:var(--font-body);font-size:.9rem;color:#fff6;margin-bottom:16px}.game-wrapper{border:var(--outline);border-radius:12px;overflow:hidden;background:#87ceeb;max-width:800px;margin:0 auto}#gameCanvas{display:block;width:100%;cursor:pointer;image-rendering:pixelated;image-rendering:crisp-edges}.game-controls{font-family:var(--font-body);font-size:.75rem;color:#ffffff40;margin-top:10px;letter-spacing:1px}.footer{text-align:center;padding:40px 20px 60px}#footerText{font-family:var(--font-display);font-size:clamp(.9rem,2.5vw,1.2rem);letter-spacing:2px;color:var(--lavender);text-shadow:1px 1px 0 #222}.footer-domain{font-family:var(--font-script);font-size:clamp(1.8rem,5vw,2.8rem);margin-top:15px;background:linear-gradient(90deg,var(--freiburg-red),var(--pink),var(--sunset),var(--gold),var(--mint),var(--sky),var(--lavender));background-size:200% auto;animation:rainbowShift 6s ease-in-out infinite;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:drop-shadow(2px 3px 0 #222)}.footer-freiburg{font-family:var(--font-body);font-size:.85rem;color:#fff3;margin-top:8px;letter-spacing:2px}@media(max-width:1000px){.gallery-grid{grid-template-columns:repeat(3,1fr);gap:20px}}@media(max-width:768px){.lightbox-body{flex-direction:column}.lightbox-comments{max-height:50vh}.lightbox-frame img{max-height:45vh}.deco-muenster-left,.deco-muenster-right{display:none}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:16px}.countdown-number{min-width:55px}.header{padding:50px 15px 70px}.header-skyline{display:none}}@media(max-width:480px){.header{padding:40px 12px 60px;margin-top:10px;border-radius:18px 18px 0 0}.gallery-grid{grid-template-columns:repeat(2,1fr);gap:12px}.frame-border{border-width:4px}.lightbox{padding:10px}.lightbox-comments{padding:16px;border-radius:14px}.countdown-bubble{padding:20px 12px;border-radius:16px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
