@import"https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=Inter:wght@300;400;500;600&family=Great+Vibes&display=swap";:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.contact-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.contact-form-modal{background:var(--surface);border-radius:var(--radius-lg);padding:2rem;width:90%;max-width:500px;position:relative;box-shadow:var(--shadow-lg)}.close-button{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:.5rem;line-height:1;border-radius:50%;transition:all .2s}.close-button:hover{background:var(--background);color:var(--text-primary)}.contact-form-modal h2{font-size:1.75rem;font-weight:700;color:var(--text-primary);margin-bottom:1.5rem;text-align:center}.contact-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--text-primary)}.form-group input,.form-group textarea{padding:.875rem 1rem;border:2px solid var(--border);border-radius:var(--radius);font-size:1rem;background:var(--background);color:var(--text-primary);transition:all .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.form-group textarea{resize:vertical;min-height:120px}.submit-button{background:var(--gradient-primary);color:var(--surface);border:none;padding:.875rem 1.5rem;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.submit-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-lg)}.submit-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.error-message{background:#fee2e2;color:#991b1b;padding:1rem;border-radius:var(--radius);margin-bottom:1rem;text-align:center}.success-message{background:#dcfce7;color:#166534;padding:1rem;border-radius:var(--radius);text-align:center}:root{--amber-50: #fefdf8;--amber-100: #fef9e7;--amber-200: #fde68a;--amber-700: #d97706;--amber-800: #b45309;--amber-900: #92400e;--white: #ffffff;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--text-primary: #3b3b3b;--text-secondary: #6b7280;--shadow: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,sans-serif;color:var(--text-primary);background-color:var(--amber-50);line-height:1.6}h1,h2,h3{font-family:Playfair Display,serif;font-weight:600}.homepage{min-height:100vh;overflow-x:hidden}.hero-section{position:relative;height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:1rem;background:linear-gradient(135deg,var(--amber-50) 0%,var(--amber-100) 100%)}.hero-background{position:absolute;top:0;right:0;bottom:0;left:0;background-image:url(/assets/background-BLMVQVFU.png);background-size:cover;background-position:center;pointer-events:none}.hero-background:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#000000b3,#000000b3 40%,#0000004d);pointer-events:none}.hero-content{position:relative;z-index:2;max-width:800px;margin:0 auto}.logo-container{margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.5rem;position:relative;min-height:100px}.hero-logo{font-family:Great Vibes,cursive;font-size:6rem;font-weight:400;background:linear-gradient(45deg,#fddb92,#d1fdff);background-clip:text;-webkit-background-clip:text;color:transparent;text-shadow:1px 1px 4px rgba(253,219,146,.3);margin:0 0 1rem;line-height:1}.hero-logo-image-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:-1;transition:all .6s ease;pointer-events:none}.hero-logo-image-wrapper.glow{filter:drop-shadow(0 0 60px #fddb92) drop-shadow(0 0 120px #d1fdff)}.hero-logo-image{height:400px;width:400px;object-fit:contain;position:relative;z-index:-1;border-radius:50%;opacity:.9;filter:drop-shadow(0 0 40px rgba(253,219,146,.4)) drop-shadow(0 0 80px rgba(209,253,255,.3)) drop-shadow(0 0 120px rgba(255,255,255,.2)) brightness(1.2) saturate(1.4) contrast(1.15);transition:all .6s ease;animation:pulse-glow 4s ease-in-out infinite}.hero-logo-image-wrapper:hover .hero-logo-image{opacity:.8;filter:drop-shadow(0 0 60px rgba(253,219,146,.6)) drop-shadow(0 0 100px rgba(209,253,255,.5)) drop-shadow(0 0 140px rgba(255,255,255,.3)) brightness(1.3) saturate(1.6) contrast(1.25);transform:scale(1.05)}@keyframes pulse-glow{0%,to{opacity:.9;filter:drop-shadow(0 0 60px #fddb92) drop-shadow(0 0 120px #d1fdff) drop-shadow(0 0 40px rgba(253,219,146,.4)) drop-shadow(0 0 80px rgba(209,253,255,.3)) drop-shadow(0 0 120px rgba(255,255,255,.2)) brightness(1.2) saturate(1.4) contrast(1.15)}50%{opacity:1;filter:drop-shadow(0 0 90px #fddb92) drop-shadow(0 0 180px #d1fdff) drop-shadow(0 0 60px rgba(253,219,146,.5)) drop-shadow(0 0 120px rgba(209,253,255,.4)) drop-shadow(0 0 180px rgba(255,255,255,.3)) brightness(1.3) saturate(1.6) contrast(1.2)}}.hero-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:600;margin-bottom:1rem;line-height:1.2;letter-spacing:-.025em;color:#fff;text-shadow:2px 2px 8px rgba(0,0,0,.5)}.hero-description{font-size:clamp(1.125rem,2vw,1.25rem);color:#ffffffe6;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto;text-shadow:1px 1px 4px rgba(0,0,0,.5)}.hero-actions{display:flex;flex-direction:column;align-items:center;gap:1rem}.login-prompt{color:#fffc;font-size:1rem;margin:0;text-shadow:1px 1px 4px rgba(0,0,0,.5)}.login-link{color:#fff;text-decoration:none;font-weight:500;transition:all .3s ease;border-bottom:1px solid transparent;text-shadow:1px 1px 4px rgba(0,0,0,.5)}.login-link:hover{color:#fffc;text-decoration:none;border-bottom-color:#fffc}.cta-button{display:inline-block;background:linear-gradient(45deg,#fddb92,#d1fdff);color:var(--gray-800);padding:.75rem 2rem;border-radius:9999px;font-size:1.125rem;font-weight:500;border:none;cursor:pointer;text-decoration:none;transition:all .3s ease;box-shadow:var(--shadow)}.cta-button:hover:not(:disabled){background:linear-gradient(45deg,#d1fdff,#fddb92);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.cta-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.cta-button.large{padding:1rem 2.5rem;font-size:1.125rem}.section-container{max-width:1200px;margin:0 auto;padding:0 1.5rem}.section-title{font-size:clamp(2rem,4vw,2.5rem);font-weight:600;text-align:center;margin-bottom:3rem;color:var(--text-primary)}.features-section{padding:5rem 0;background:linear-gradient(135deg,var(--gray-50) 0%,var(--gray-100) 100%)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2.5rem}.feature-card{text-align:center;padding:1.5rem}.feature-separator{position:relative;width:100px;height:1px;background:linear-gradient(to right,transparent,#fddb92,transparent);margin:0 auto 2rem}.feature-separator:before{content:"♦";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background-color:var(--white);color:#fddb92;font-size:1.5rem;line-height:1;padding:0 .5rem}.feature-separator:after{content:"";position:absolute;top:-2px;left:50%;transform:translate(-50%);width:6px;height:6px;background-color:#fddb92;border-radius:50%;box-shadow:-15px 0 0 -2px #fddb92,15px 0 0 -2px #fddb92,-30px 0 0 -3px #fddb92,30px 0 0 -3px #fddb92}.feature-card h3{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.feature-card p{color:var(--text-secondary);line-height:1.6}.steps-section{padding:5rem 0;background:linear-gradient(135deg,var(--amber-100) 0%,var(--amber-200) 100%)}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.step-card{background-color:var(--white);border-radius:1rem;padding:2rem;text-align:center;box-shadow:var(--shadow);transition:transform .3s ease}.step-card:hover{transform:translateY(-5px)}.step-number{font-size:3rem;font-weight:700;background:linear-gradient(45deg,#fddb92,#d1fdff);background-clip:text;-webkit-background-clip:text;color:transparent;display:block;margin-bottom:1rem}.step-card h3{font-size:1.25rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.step-card p{color:var(--text-secondary);line-height:1.6}.templates-section{padding:5rem 0;background-color:var(--white)}.templates-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.template-card{border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow);transition:transform .3s ease}.template-card:hover{transform:translateY(-5px)}.template-placeholder{aspect-ratio:3/4;background:linear-gradient(135deg,var(--amber-100) 0%,var(--amber-200) 100%);display:flex;align-items:center;justify-content:center;color:var(--amber-700);font-weight:600;font-size:1.125rem}.pricing-section{padding:5rem 0;background-color:var(--white)}.pricing-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;max-width:900px;margin:0 auto}.pricing-card{background-color:var(--white);border-radius:1rem;padding:2.5rem;display:flex;flex-direction:column;box-shadow:var(--shadow);transition:transform .3s ease;border:1px solid transparent}.pricing-card:hover{transform:translateY(-5px)}.pricing-card.featured{border-color:#fddb92;border-width:4px;position:relative}.pricing-card.featured:before{content:"Empfohlen";position:absolute;top:-.5rem;left:50%;transform:translate(-50%);background:linear-gradient(45deg,#fddb92,#d1fdff);color:var(--gray-800);padding:.25rem 1rem;border-radius:9999px;font-size:.875rem;font-weight:600}.pricing-card h3{font-size:1.5rem;font-weight:600;margin-bottom:1rem;text-align:center;color:var(--text-primary)}.price{font-size:2.5rem;font-weight:700;text-align:center;margin-bottom:1.5rem;color:var(--text-primary)}.features-list{list-style:none;margin-bottom:2rem;flex-grow:1}.features-list li{color:var(--text-secondary);position:relative;padding:.5rem 0 .5rem 1.5rem}.features-list li:before{content:"✓";position:absolute;left:0;color:#fddb92;font-weight:600}.pricing-button{background:linear-gradient(45deg,#fddb92,#d1fdff);color:var(--gray-800);border:none;padding:.75rem 1.5rem;border-radius:9999px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:auto}.pricing-button:hover{background:linear-gradient(45deg,#d1fdff,#fddb92);transform:translateY(-2px)}.cta-section{padding:5rem 0;background:linear-gradient(135deg,var(--amber-200) 0%,rgba(217,119,6,.2) 100%);text-align:center}.cta-title{font-size:clamp(2rem,4vw,2.5rem);font-weight:600;margin-bottom:1.5rem;color:var(--text-primary)}.homepage-footer{background:linear-gradient(135deg,var(--amber-50) 0%,var(--amber-100) 100%);padding:4rem 0 2rem;border-top:1px solid rgba(0,0,0,.05)}.footer-container{max-width:1200px;margin:0 auto;padding:0 1.5rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2.5rem}.footer-section{background:var(--white);padding:2rem;border-radius:16px;box-shadow:var(--shadow);transition:all .3s ease}.footer-section:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}.footer-section h4{font-family:Playfair Display,serif;font-weight:600;font-size:1.25rem;margin-bottom:1rem;color:var(--text-primary);border-bottom:2px solid #fddb92;padding-bottom:.5rem}.footer-section ul{list-style:none}.footer-section ul li{margin-bottom:.75rem}.footer-section button,.footer-section a{background:none;border:none;color:var(--text-secondary);text-decoration:none;cursor:pointer;transition:all .3s ease;font-size:.95rem;font-weight:400;padding:.25rem 0;display:inline-block;position:relative}.footer-section button:hover,.footer-section a:hover{color:var(--amber-700);transform:translate(4px)}.footer-section button:after,.footer-section a:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(45deg,#fddb92,#d1fdff);transition:width .3s ease}.footer-section button:hover:after,.footer-section a:hover:after{width:100%}.footer-logo{font-family:Great Vibes,cursive;font-size:3rem;font-weight:400;background:linear-gradient(45deg,#fddb92,#d1fdff);background-clip:text;-webkit-background-clip:text;color:transparent;text-shadow:1px 1px 4px rgba(253,219,146,.3);margin:0 0 1rem;line-height:1}.footer-section p{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin-top:1rem}@media (max-width: 768px){.hero-section{padding:2rem 1rem}.hero-logo{font-size:4rem}.hero-logo-image{height:280px;width:280px}.hero-logo-image-wrapper:before{top:-80px;left:-80px;right:-80px;bottom:-80px}.logo-container{flex-direction:column;gap:1rem}.section-container{padding:0 1rem}.features-grid,.steps-grid,.templates-grid{grid-template-columns:1fr}.templates-grid{grid-template-columns:repeat(2,1fr)}.pricing-grid{grid-template-columns:1fr}.footer-container{grid-template-columns:1fr;text-align:center}}@media (max-width: 480px){.hero-logo-image{height:200px;width:200px}.hero-logo-image-wrapper:before{top:-60px;left:-60px;right:-60px;bottom:-60px}.hero-title{font-size:2rem}.hero-logo{font-size:3rem}.templates-grid{grid-template-columns:1fr}.step-card,.pricing-card{padding:1.5rem}.cta-button{padding:.75rem 1.5rem;font-size:1rem}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.hero-content{animation:fadeInUp .8s ease-out}html{scroll-behavior:smooth}button:focus-visible,a:focus-visible{outline:2px solid #fddb92;outline-offset:2px}.wedding-upload-container{max-width:600px;margin:0 auto;padding:2rem 1rem;align-items:center}.wedding-upload-header{text-align:center;margin-bottom:3rem}.wedding-upload-header h1{font-size:2.5rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem}.wedding-upload-header p{color:var(--text-secondary);font-size:1.125rem;line-height:1.6}.wedding-upload-section{background:linear-gradient(135deg,var(--surface) 0%,var(--background) 100%);border-radius:var(--radius-xl, 1.5rem);padding:1.5rem;margin-bottom:2rem;border:2px solid transparent;background-clip:padding-box;position:relative}.wedding-upload-section:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,var(--primary-color) 0%,var(--secondary-color) 100%);border-radius:var(--radius-xl, 1.5rem);padding:2px;mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;z-index:-1}.wedding-guest-info{margin-bottom:1.5rem}.wedding-guest-input{width:100%;padding:1rem;border:2px solid var(--border);border-radius:var(--radius-lg);font-size:1.1rem;background-color:var(--form-bg);color:var(--form-text);transition:all .3s ease;text-align:center;font-weight:500}.wedding-guest-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 4px #3b82f61a;transform:translateY(-1px)}.wedding-upload-actions{display:flex;justify-content:center;margin-bottom:1.5rem}.wedding-upload-button{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;padding:2rem 3rem;border-radius:var(--radius-lg);font-size:1.3rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:1rem;min-height:140px;justify-content:center;position:relative;overflow:hidden;box-shadow:0 6px 20px #3b82f64d;width:100%;max-width:400px}.wedding-upload-button:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1e40af);transform:translateY(-3px);box-shadow:0 10px 30px #3b82f666}.wedding-upload-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.wedding-upload-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.wedding-upload-button:hover:before{left:100%}.wedding-upload-status{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.5rem;background:var(--gradient-info);border-radius:var(--radius);border:1px solid var(--border);color:var(--text-primary);font-weight:500}.wedding-recent-photos{background:var(--surface);border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow);border:1px solid var(--border)}.wedding-recent-photos h2{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin-bottom:1.5rem;text-align:center}.wedding-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.5rem}.wedding-photo-item{text-align:center;background:var(--surface);border-radius:var(--radius-lg);padding:.75rem;box-shadow:var(--shadow);border:1px solid var(--border);cursor:pointer;transition:all .3s ease}.wedding-photo-thumbnail{width:100%;height:160px;object-fit:cover;border-radius:var(--radius);margin-bottom:.75rem;cursor:pointer}.wedding-photo-info{font-size:.875rem;color:var(--text-primary);font-weight:500;padding:.25rem 0}.wedding-preview-section{margin-bottom:2rem}.wedding-preview-container{position:relative;width:100%;max-width:400px;margin:0 auto 2rem;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:2px solid var(--primary-color);background:var(--surface);min-height:200px;display:flex;align-items:center;justify-content:center}.wedding-preview-image{width:100%;max-height:400px;object-fit:contain;display:block;border-radius:var(--radius)}.wedding-preview-actions{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.confirm-button{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:1.25rem 2rem;border-radius:var(--radius-lg);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:60px;flex:1;box-shadow:0 4px 15px #10b9814d}.confirm-button:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 8px 25px #10b98166}.confirm-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.cancel-button{background:var(--surface);color:var(--text-secondary);border:2px solid var(--border);padding:1.25rem 2rem;border-radius:var(--radius-lg);font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:60px;flex:1}.cancel-button:hover:not(:disabled){background:var(--surface-hover);border-color:var(--text-primary);color:var(--text-primary);transform:translateY(-2px);box-shadow:0 4px 15px #0000001a}.cancel-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.photo-preview-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000e6;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);padding:2rem}.photo-preview-content{background:var(--surface);border-radius:var(--radius-lg);padding:2rem;max-width:90%;max-height:90%;display:flex;flex-direction:column;align-items:center;gap:1.5rem;box-shadow:0 20px 60px #0000004d}.photo-preview-image{max-width:100%;max-height:60vh;object-fit:contain;border-radius:var(--radius);box-shadow:0 8px 25px #00000026}.photo-preview-actions{display:flex;gap:1rem;width:100%;max-width:400px}.error-message{color:var(--error-color, #dc2626);font-size:.9rem;margin-top:1rem;padding:.75rem;background:var(--error-bg, #fef2f2);border:1px solid var(--error-border, #fecaca);border-radius:var(--radius);text-align:center}.button-spinner{width:16px;height:16px;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}.success-message{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1.5rem;color:var(--surface);border-radius:var(--radius-lg);font-weight:600;font-size:1rem;text-align:center;border:1px solid var(--success-border, #10b981);animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 480px){.wedding-upload-container{padding:1rem .75rem}.wedding-upload-header h1{font-size:2rem}.wedding-upload-section,.wedding-recent-photos{padding:1.25rem;margin-bottom:1.5rem}.wedding-upload-button{padding:1.5rem 2rem;min-height:120px;font-size:1.1rem;max-width:none}.photo-preview-overlay{padding:1rem}.photo-preview-content{padding:1.5rem;max-width:95%}.photo-preview-image{max-height:50vh}.photo-preview-actions{flex-direction:column;gap:.75rem;max-width:none}.wedding-photos-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.wedding-photo-thumbnail{height:120px}.wedding-photo-item{padding:.5rem}.confirm-button,.cancel-button{padding:1rem 1.5rem;min-height:50px;font-size:1rem}.gallery-content{gap:1.5rem}.gallery-main{max-width:95%}.gallery-image{max-height:60vh}.gallery-close{top:10px;right:10px;width:40px;height:40px;font-size:1.5rem}.gallery-nav{width:50px;height:50px;font-size:1.25rem}.gallery-navigation{gap:.75rem}.gallery-info{padding:.75rem;font-size:.8rem}.wedding-view-all-button{padding:.875rem 1.5rem;font-size:.875rem;min-height:45px}}.gallery-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000f2;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.gallery-content{position:relative;width:90%;height:90%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2rem}.gallery-main{position:relative;max-width:80%;display:flex;flex-direction:column;align-items:center;flex:1;justify-content:center}.gallery-image{max-width:100%;max-height:70vh;object-fit:contain;border-radius:var(--radius);box-shadow:var(--shadow-lg)}.gallery-navigation{display:flex;gap:1rem;justify-content:center;align-items:center;position:relative;z-index:1002}.gallery-nav{position:static;transform:none;background:var(--surface);border:2px solid var(--primary-color);color:var(--primary-color);font-size:1.5rem;width:60px;height:60px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1001;box-shadow:var(--shadow)}.gallery-nav span{display:flex;align-items:center;justify-content:center;width:100%;height:100%;line-height:1}.gallery-info{background:var(--surface);padding:1rem;border-radius:var(--radius);text-align:center;color:var(--text-primary);box-shadow:var(--shadow);border:1px solid var(--border)}.gallery-info p{margin:.25rem 0;font-size:.875rem}.gallery-close{position:absolute;top:20px;right:20px;background:#fff3;border:none;color:#fff;font-size:2rem;width:50px;height:50px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .2s}.gallery-close:hover{background:#ffffff4d;transform:scale(1.1)}.gallery-actions{margin-top:1.5rem;text-align:center}.wedding-view-all-button{background:var(--gradient-success);color:var(--surface);border:none;padding:1rem 2rem;border-radius:var(--radius-lg);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-height:50px}.wedding-view-all-button:hover:not(:disabled){background:linear-gradient(135deg,#3b82f6,#1d4ed8);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.wedding-view-all-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.admin-container{display:flex;flex-direction:column;max-width:1200px;margin:0 auto;min-height:100vh;box-sizing:border-box}.admin-container.compact{max-width:1200px;margin:0 auto}.admin-header{flex:0 0 auto;text-align:center;margin-bottom:20px;padding:2.5rem;background:var(--surface);border-radius:24px;box-shadow:0 4px 20px var(--shadow-color);border:1px solid var(--border)}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.header-actions{display:flex;gap:.5rem}.admin-header h1{margin:0;font-size:24px}.admin-header p{color:var(--text-secondary);font-size:1.2rem;font-weight:500}.admin-actions{flex:0 0 auto;display:flex;justify-content:center;gap:1.5rem;margin-bottom:3rem;flex-wrap:wrap}.action-button{background:var(--surface);border:2px solid var(--border);color:var(--text-primary);padding:.75rem 1.5rem;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 2px 10px var(--shadow-color);min-width:160px;justify-content:center}.action-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px var(--shadow-color-hover);border-color:var(--primary-color);background:var(--surface)}.action-button.primary{background:var(--gradient-primary);color:var(--surface);border:none;box-shadow:0 4px 20px #6366f14d}.action-button.primary:hover{background:var(--gradient-primary);transform:translateY(-2px);box-shadow:0 8px 30px #6366f166;filter:brightness(1.1)}.admin-tabs{flex:0 0 auto;display:flex;justify-content:center;margin-bottom:2rem;background:var(--surface);border-radius:16px;padding:.5rem;box-shadow:0 4px 20px var(--shadow-color);border:1px solid var(--border);max-width:600px;width:100%;margin-left:auto;margin-right:auto;box-sizing:border-box}.tab-navigation{display:flex;gap:10px;margin-bottom:20px;border-bottom:1px solid #e0e0e0;padding-bottom:10px}.tab-button{padding:10px 20px;border:none;background:none;cursor:pointer;font-size:16px;color:#666;border-radius:4px;transition:all .2s ease}.tab-button:hover{background-color:#f5f5f5}.tab-button.active{color:#4a90e2;background-color:#e8f0fe;font-weight:500}.tab-content{padding:20px 0}.photos-section,.rsvp-section{flex:1 0 auto;margin-top:2rem;width:100%;box-sizing:border-box;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;overflow:visible;min-height:200px;max-width:100%}.photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:2rem;width:100%;box-sizing:border-box}.photos-grid.compact{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem;margin-top:1rem}.photo-card{background:var(--surface);border-radius:16px;overflow:hidden;box-shadow:0 4px 20px var(--shadow-color);transition:all .3s ease;border:1px solid var(--border);cursor:pointer;transition:transform .2s}.photo-card:hover{transform:scale(1.02)}.photo-thumbnail{width:100%;height:200px;object-fit:contain}.photo-details{padding:1.5rem}.photo-uploader{font-weight:600;color:var(--text-primary);margin-bottom:.5rem;font-size:1.1rem}.photo-date{font-size:.9rem;color:var(--text-secondary);font-weight:500}.rsvp-list{display:grid;gap:1.5rem;width:100%;box-sizing:border-box}.rsvp-list.compact{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1rem}.rsvp-card{background:var(--surface);border-radius:16px;padding:2rem;box-shadow:0 4px 20px var(--shadow-color);border:1px solid var(--border);transition:all .3s ease}.rsvp-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px var(--shadow-color-hover)}.rsvp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.rsvp-header h4{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.status-badge{padding:.25rem .6rem;border-radius:6px;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.03em;display:inline-block}.status-badge.attending{background:var(--status-attending-bg);color:var(--status-attending-text)}.status-badge.declined{background:var(--status-declined-bg);color:var(--status-declined-text)}.status-badge.pending{background:var(--status-pending-bg);color:var(--status-pending-text)}.status-emoji{cursor:help;display:inline-block;text-align:center}.rsvp-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.rsvp-details p{font-size:.95rem;color:var(--text-secondary);margin:0;padding:.75rem;background:var(--background);border-radius:8px;border-left:4px solid var(--border)}.rsvp-details strong{color:var(--text-primary);font-weight:600}.rsvp-table-container{background:var(--surface);border-radius:16px;padding:1.5rem;box-shadow:0 4px 20px var(--shadow-color);border:1px solid var(--border);overflow-x:auto}.rsvp-table{width:100%;border-collapse:collapse;font-size:.95rem}.rsvp-table th{background:var(--background);padding:1rem .75rem;text-align:left;font-weight:600;color:var(--text-primary);border-bottom:2px solid var(--border);white-space:nowrap}.rsvp-table td{padding:1rem .75rem;border-bottom:1px solid var(--border);color:var(--text-secondary);vertical-align:top}.rsvp-table tr:hover{background:var(--background)}.rsvp-table tr:last-child td{border-bottom:none}.guest-name{font-weight:600;color:var(--text-primary)!important}.guest-count{text-align:center;font-weight:500}.accommodation{font-weight:500}.message{max-width:200px;word-wrap:break-word}.message span{cursor:help}.no-message{color:var(--text-tertiary);font-style:italic}.no-rsvps{text-align:center;padding:2rem;color:var(--text-secondary)}.no-rsvps p{margin:0;font-size:1.1rem;font-style:italic}.empty-state{background:var(--surface);border-radius:16px;box-shadow:0 4px 20px var(--shadow-color);border:1px solid var(--border);width:100%;max-width:100%;box-sizing:border-box;padding:2rem 1.5rem;margin-top:0;margin-bottom:0;text-align:center;flex-shrink:0}.empty-state p{color:var(--text-secondary);font-size:1.1rem;margin-bottom:1rem}.empty-state p:last-child{margin-bottom:0;font-weight:600;color:var(--secondary-color)}.loading{text-align:center;padding:4rem;font-size:1.25rem;color:var(--text-secondary);font-weight:600}@media (max-width: 768px){.admin-header h1{font-size:2rem}.admin-header p{font-size:1.1rem}.admin-actions{flex-direction:column;align-items:center;gap:1rem}.action-button{width:100%;max-width:320px}.admin-tabs{padding:6px;max-width:100%}.tab-button{padding:.875rem 1rem;font-size:.9rem;min-height:48px}.photos-section,.rsvp-section{min-height:150px;max-width:100%;overflow-x:hidden}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(min(200px,100%),1fr));gap:1.5rem;max-width:100%;overflow-x:hidden}.photo-thumbnail{height:160px}.rsvp-summary{grid-template-columns:repeat(2,1fr);gap:1rem}.summary-card{padding:1.5rem}.summary-number{font-size:2rem}.rsvp-details{grid-template-columns:1fr}.rsvp-header{flex-direction:column;align-items:flex-start;gap:1rem}.rsvp-table-container{padding:1rem;margin:0 -.5rem}.rsvp-table{font-size:.85rem}.rsvp-table th,.rsvp-table td{padding:.75rem .5rem}.rsvp-table th{font-size:.8rem}.message{max-width:120px}}@media (max-width: 480px){.admin-header{margin-left:3.5rem;margin-right:.75rem}.mobile-header h1{font-size:1.1rem}.admin-header p{font-size:1rem}.tab-button{font-size:.8rem;padding:.75rem .5rem}.photos-section,.rsvp-section{min-height:120px;max-width:100%;overflow-x:hidden}.photos-grid{grid-template-columns:repeat(auto-fill,minmax(min(150px,calc(100% - 2rem)),1fr));gap:1rem;max-width:100%;overflow-x:hidden}.rsvp-summary{grid-template-columns:1fr}.admin-sidebar{width:260px}}.qr-code-section{flex:0 0 auto;margin:2rem auto;max-width:500px;width:100%;box-sizing:border-box}.qr-code-card{background:var(--surface);border-radius:16px;padding:2rem;box-shadow:0 4px 20px var(--shadow-color);border:1px solid var(--border);text-align:center}.qr-code-card h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.qr-code-card p{color:var(--text-secondary);font-size:1rem;margin-bottom:1.5rem}.qr-code-container{display:flex;justify-content:center;margin:2rem 0;padding:1rem;background:var(--background);border-radius:12px;border:2px dashed var(--border)}.qr-code-image{max-width:200px;max-height:200px;width:auto;height:auto;border-radius:8px;background:var(--surface);padding:.5rem}.qr-code-url{font-family:Courier New,monospace;font-size:.9rem;color:var(--primary-color);background:var(--background);padding:.75rem;border-radius:8px;word-break:break-all;margin-top:1rem}.link-container{margin-top:20px;width:100%}.link-row{display:flex;gap:10px;margin-bottom:10px;align-items:center}.link-input{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background-color:#f5f5f5;color:#333}.copy-button{padding:8px 16px;background-color:#f0f0f0;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;white-space:nowrap;transition:background-color .2s}.copy-button:hover{background-color:#e0e0e0}.view-all-container{text-align:center;margin:20px 0}.view-all-button{padding:10px 20px;background-color:#f0f0f0;border:1px solid #ddd;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s}.view-all-button:hover{background-color:#e0e0e0}.download-container{text-align:center;margin:20px 0}.gallery-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000e6;display:flex;justify-content:center;align-items:center}.gallery-content{position:relative;width:90%;height:90%;display:flex;align-items:center;justify-content:center}.gallery-main{display:flex;flex-direction:column;align-items:center;gap:20px}.gallery-image{max-width:100%;max-height:80vh;object-fit:contain}.gallery-info{color:#000;text-align:center;padding:20px}.gallery-close{position:absolute;top:-40px;right:0;background:none;border:none;color:#fff;font-size:30px;cursor:pointer;padding:10px}.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);background:#ffffff1a;border:none;color:#fff;font-size:40px;cursor:pointer;padding:20px;border-radius:50%;transition:background-color .2s}.gallery-nav:hover{background:#fff3}.gallery-prev{left:20px}.gallery-next{right:20px}.delete-button{background-color:#f44;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;margin-top:10px;transition:background-color .2s}.delete-button:hover{background-color:#c00}.wedding-details-section{width:100%;max-width:900px;margin:0 auto}.wedding-details-card{background:var(--surface);border-radius:24px;padding:2.5rem;box-shadow:0 8px 32px var(--shadow-color);border:1px solid var(--border);transition:all .3s ease}.wedding-details-card:hover{transform:translateY(-2px);box-shadow:0 12px 40px var(--shadow-color-hover)}.wedding-details-card h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:2rem;text-align:center;background:var(--gradient-primary);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.details-form{display:flex;flex-direction:column;gap:1rem;max-width:600px}.details-form .form-group{display:flex;flex-direction:column;gap:.5rem}.details-form label{font-size:1rem;font-weight:600;color:var(--text-primary)}.details-form input{padding:.875rem 1rem;border:2px solid var(--border);border-radius:12px;font-size:1rem;background:var(--background);color:var(--text-primary);transition:all .3s ease}.details-form input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a;outline:none}.details-actions{display:flex;gap:1rem;justify-content:flex-end}.details-display{display:grid;gap:1.25rem;padding:1rem;max-width:700px;margin:0 auto}.details-display p{font-size:1.1rem;line-height:1.5;color:var(--text-primary);display:flex;align-items:center;gap:1rem}.details-display strong{font-weight:600;color:var(--text-secondary);min-width:100px;font-size:1rem}.details-display .detail-icon{font-size:1.25rem;color:var(--primary-color);opacity:.8;width:24px;text-align:center}.details-display .detail-value{flex:1;padding:.75rem 1rem;background:var(--background);border-radius:8px;border:1px solid var(--border);font-size:1.1rem}@media (max-width: 768px){.wedding-details-card{padding:1.5rem}.details-display{gap:1rem;padding:.5rem}.details-display p{flex-direction:column;align-items:flex-start;gap:.5rem}.details-display strong{min-width:auto}.details-display .detail-value{width:100%}.action-button{padding:.75rem 1rem;min-width:140px}}.upload-section h3{margin:0 0 15px;color:#333}.upload-container{display:flex;flex-direction:column;gap:15px}.file-input-area{position:relative;border:2px dashed #ccc;border-radius:8px;background:#f9f9f9;transition:all .2s ease;min-height:120px}.file-input-area:hover{border-color:#666;background:#f5f5f5}.file-input-area.has-previews{border-color:#4a90e2;background:#f8fafe;min-height:auto}.file-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2}.file-input-content{padding:20px;display:flex;align-items:center;justify-content:center;min-height:80px}.file-input-placeholder{text-align:center;color:#666}.upload-icon{font-size:2rem;margin-bottom:.5rem}.file-input-placeholder p{margin:.5rem 0;font-size:1rem;font-weight:500}.file-types{font-size:.875rem;color:#999}.upload-preview-container{width:100%}.upload-preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid #e0e0e0}.clear-selection{background:#f44;color:#fff;border:none;border-radius:50%;width:24px;min-width:24px;aspect-ratio:1;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.875rem;transition:background .2s ease;position:relative;z-index:10;flex-shrink:0}.clear-selection:hover{background:#c00}.upload-actions{display:flex;align-items:center;gap:15px}.selected-files{color:#666;font-size:.9em}.error-message{color:#dc3545;font-size:.9em;margin-top:5px}.background-image-section{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border)}.background-image-section h4{margin-bottom:1rem;color:var(--text-primary)}.background-preview{display:flex;flex-direction:column;gap:1rem;align-items:center}.background-preview-image{max-width:100%;max-height:300px;border-radius:var(--radius);box-shadow:var(--shadow-md);min-height:200px}.background-upload{display:flex;flex-direction:column;gap:1rem}.background-upload .file-input{width:100%;padding:1rem;border:2px dashed var(--border);border-radius:var(--radius);background:var(--background);cursor:pointer}.background-upload .upload-actions{display:flex;flex-direction:column;gap:.5rem}.background-upload .selected-files{color:var(--text-secondary);font-size:.875rem}.action-button.danger{background:var(--error);color:#fff}.action-button.danger:hover{background:var(--error-dark)}.checkbox-label{display:flex;align-items:center;gap:8px;margin-bottom:4px;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-description{font-size:.9em;color:#666;margin-top:4px;margin-bottom:16px;padding-left:26px}.section-group{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:12px;overflow:hidden}.section-header{padding-bottom:15px;padding-left:20px;background-color:#f8f9fa;border-bottom:1px solid #e0e0e0}.section-header h3{margin:0;font-size:18px;color:#333}.section-content{padding:1rem;overflow-y:auto;display:flex;flex-direction:column}.form-row{display:flex;gap:.75rem;flex-wrap:wrap}.form-group{flex:1;min-width:200px}.form-group label{display:block;font-size:.9rem;color:#666}.form-input{width:100%;border:1px solid #ddd;border-radius:4px;font-size:.9rem}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.detail-item{display:flex;align-items:center;gap:.5rem}.detail-icon{font-size:1.2rem}.detail-value{font-size:.9rem;color:#333}.action-button.small{padding:.4rem .8rem;font-size:.9rem;margin:1rem}.photos-actions{display:flex;justify-content:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.qr-code-section.compact{text-align:center;padding:1rem;width:100%;max-width:100%;box-sizing:border-box;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;gap:1rem}.section-description{color:#666;font-size:.9rem;margin-bottom:1rem}.qr-code-container{display:inline-block;padding:1rem;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.qr-code-image{width:200px;height:200px}.rsvp-settings{display:flex;flex-direction:column;gap:.75rem}.rsvp-settings h4{margin:0 0 .5rem;font-size:1rem;color:#333}.background-image-section.compact{background:#f8f9fa;padding:1rem;border-radius:4px}.background-preview{display:flex;align-items:center;gap:1rem;margin-top:.5rem}.background-preview-image{max-width:200px;max-height:100px;object-fit:cover;border-radius:4px}.settings-container{display:flex;flex-direction:column;gap:1rem;box-sizing:border-box}.settings-save-section{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;background:var(--surface);border-radius:16px;box-shadow:0 4px 20px var(--shadow-color);border:1px solid var(--border);margin-bottom:.5rem}.unsaved-changes-indicator{color:#f59e0b;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.unsaved-changes-indicator:before{content:"⚠️";font-size:1rem}.action-button.disabled{opacity:.5;cursor:not-allowed;transform:none!important;box-shadow:0 2px 10px var(--shadow-color)!important}.action-button.disabled:hover{transform:none!important;box-shadow:0 2px 10px var(--shadow-color)!important;filter:none!important;border-color:var(--border)!important}.admin-container.sidebar-layout{display:flex;flex-direction:column;max-width:100%;height:100vh;overflow:hidden}.admin-main{display:flex;flex:1;overflow:hidden;position:relative}.admin-sidebar{width:250px;background:var(--surface);border-right:1px solid var(--border);box-shadow:2px 0 10px var(--shadow-color);display:flex;flex-direction:column;transition:transform .3s ease}.sidebar-nav{display:flex;flex-direction:column;padding:1rem;gap:.5rem;flex:1}.sidebar-item{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;font-size:.95rem;font-weight:500;border-radius:12px;transition:all .2s ease;text-align:left;width:100%;box-sizing:border-box}.sidebar-item:hover{background:var(--background);color:var(--text-primary);transform:translate(2px)}.sidebar-item.active{background:var(--gradient-primary);color:var(--surface);box-shadow:0 4px 15px #6366f133}.sidebar-item.active:hover{background:var(--gradient-primary);transform:translate(0);filter:brightness(1.1)}.admin-content{flex:1;overflow-y:auto;background:var(--background);max-width:100%;box-sizing:border-box}.sidebar-user-section{margin-top:auto;padding:1rem;border-top:1px solid var(--border);background:var(--surface-secondary, rgba(0, 0, 0, .02));display:none}@media (max-width: 768px){.sidebar-user-section{display:block}}.sidebar-user-info{margin-bottom:.75rem}.sidebar-user-name{font-size:.9rem;color:var(--text-secondary);font-weight:500}.sidebar-logout-button{width:100%;background:transparent;border:2px solid var(--border);color:var(--text-primary);padding:.75rem 1rem;border-radius:12px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.sidebar-logout-button:hover{background:var(--error-color, #dc2626);color:#fff;border-color:var(--error-color, #dc2626);transform:translateY(-1px)}.mobile-menu-toggle{display:none;position:fixed;top:1rem;left:1rem;background:var(--surface);border:2px solid var(--border);border-radius:12px;padding:.75rem;cursor:pointer;box-shadow:0 4px 20px var(--shadow-color);transition:all .3s ease}.mobile-menu-toggle:hover{transform:scale(1.05);box-shadow:0 6px 25px var(--shadow-color-hover)}.hamburger{width:20px;height:15px;position:relative;display:flex;flex-direction:column;justify-content:space-between}.hamburger span{display:block;height:2px;width:100%;background:var(--text-primary);border-radius:1px;transition:all .3s ease}.hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(7px,-6px)}.sidebar-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;opacity:0;transition:opacity .3s ease}.sidebar-overlay.active{opacity:1}.desktop-only{display:block}.mobile-header{display:none}@media (max-width: 768px){.desktop-only{display:none!important}.mobile-menu-toggle{display:block;z-index:1001}.mobile-header{display:flex;position:fixed;top:0;left:0;right:0;height:4rem;background:var(--surface);border-bottom:1px solid var(--border);align-items:center;justify-content:center;padding:0 5rem;box-shadow:0 2px 10px var(--shadow-color);z-index:100}.mobile-header h1{margin:0;font-size:1.25rem;color:var(--text-primary);text-align:center}.admin-header{position:relative;z-index:1;margin-left:4rem;margin-right:1rem}.admin-sidebar{position:fixed;top:0;left:0;height:100vh;width:280px;transform:translate(-100%);box-shadow:4px 0 20px var(--shadow-color)}.admin-sidebar.open{transform:translate(0)}.admin-content{width:100%;min-width:100vw;margin-top:4rem;padding-top:1rem}.sidebar-item{padding:1rem;font-size:.95rem}.sidebar-overlay{display:block}}.js-layer-base{position:relative}.js-layer-overlay,.js-layer-modal,.js-layer-menu{position:fixed}.js-layer-dropdown{position:absolute}.js-hidden{display:none!important}.js-visible{display:block}.js-transparent{opacity:0;pointer-events:none}.js-opaque{opacity:1;pointer-events:auto}@media (max-width: 480px){.admin-header{margin-left:3.5rem;margin-right:.75rem}.admin-sidebar{width:260px}.sidebar-item{padding:.875rem;font-size:.9rem}.mobile-menu-toggle{top:.75rem;left:.75rem;padding:.625rem}.hamburger{width:18px;height:13px}}.auto-save-indicator{color:#3b82f6;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.5rem;animation:pulse 1.5s infinite}.auto-save-indicator:before{content:"💾";font-size:1rem}.saved-indicator{color:#10b981;font-size:.9rem;font-weight:500;display:flex;align-items:center;gap:.5rem}.saved-indicator:before{content:"✅";font-size:1rem}.auto-save-info{color:var(--text-secondary);font-size:.85rem;margin:.5rem 0 0;font-style:italic}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.desktop-table-header{display:inline}.mobile-table-header{display:none}@media (max-width: 768px){.desktop-table-header{display:none}.mobile-table-header{display:inline}}.admin-content>.section-group{margin-bottom:0;min-width:1200px}@media (max-width: 768px){.admin-content>.section-group{min-width:auto;margin:0;width:100%}.section-content{margin:0;padding:1rem;width:100%;box-sizing:border-box}}.upload-section{background:#fff;border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:0 2px 4px #0000001a}.photos-grid.compact,.rsvp-table-container,.qr-code-section.compact{width:100%;max-width:100%;box-sizing:border-box}.settings-container{min-width:1200px;box-sizing:border-box}@media (max-width: 768px){.settings-container{min-width:auto;width:100%;max-width:100%;margin:0;padding:0}}.upload-preview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem;max-height:250px;overflow-y:auto}.upload-preview-item{display:flex;flex-direction:column;background:#f9f9f9;border-radius:8px;overflow:hidden;border:1px solid #e0e0e0;transition:transform .2s ease}.upload-preview-item:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.upload-preview-image{width:100%;height:70px;object-fit:cover;background:#f5f5f5}.upload-preview-info{padding:.375rem;background:#fff}.upload-preview-filename{display:block;font-size:.7rem;color:#666;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}@media (max-width: 768px){.file-input-area{min-height:100px}.file-input-content{padding:15px;min-height:60px}.upload-icon{font-size:1.5rem}.file-input-placeholder p{font-size:.9rem}.file-types{font-size:.8rem}.upload-preview-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:.5rem;max-height:200px}.upload-preview-image{height:60px}.upload-preview-info{padding:.25rem}.upload-preview-filename{font-size:.65rem}.clear-selection{width:20px;min-width:20px;font-size:.75rem}}.invitation-settings-container{display:flex;flex-direction:column;gap:2rem;min-width:1200px;margin:0 auto;box-sizing:border-box}@media (max-width: 768px){.invitation-settings-container{min-width:auto;width:100%;margin:0}}.invitation-qr-section{background:var(--surface);border-radius:16px;padding:2rem;box-shadow:0 4px 20px var(--shadow-color);border:1px solid var(--border);text-align:center}.invitation-qr-section h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem}.invitation-qr-section p{color:var(--text-secondary);font-size:1rem;margin-bottom:1.5rem}.invitation-actions{display:flex;justify-content:center;gap:1rem;margin-top:1.5rem;flex-wrap:wrap}.invitation-settings-form{background:var(--surface);border-radius:16px;padding:2rem;box-shadow:0 4px 20px var(--shadow-color);border:1px solid var(--border)}.invitation-settings-form h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:2rem;text-align:center}.invitation-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.invitation-form-group{display:flex;flex-direction:column;gap:.5rem}.invitation-form-group label{font-size:1rem;font-weight:600;color:var(--text-primary)}.invitation-form-group input,.invitation-form-group textarea{padding:.875rem 1rem;border:2px solid var(--border);border-radius:12px;font-size:1rem;background:var(--background);color:var(--text-primary);transition:all .3s ease}.invitation-form-group input:focus,.invitation-form-group textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a;outline:none}.invitation-form-group textarea{resize:vertical;min-height:100px}.invitation-background-section{grid-column:1 / -1;padding-top:1.5rem;border-top:1px solid var(--border);margin-top:1rem}.invitation-background-section h4{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}@media (max-width: 768px){.invitation-settings-container{gap:1.5rem}.invitation-qr-section,.invitation-settings-form{padding:1.5rem}.invitation-form-grid{grid-template-columns:1fr;gap:1rem}.invitation-actions{flex-direction:column;align-items:center}.action-button{width:100%;max-width:300px}}.admin-photos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem;margin-top:1.5rem;width:100%}.admin-photo-item{display:flex;flex-direction:column;background:var(--surface);border-radius:12px;overflow:hidden;box-shadow:0 2px 12px var(--shadow-color);border:1px solid var(--border);transition:all .3s ease}.admin-photo-item:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--shadow-color-hover)}.admin-photo-container{position:relative;width:100%;aspect-ratio:1;overflow:hidden}.admin-photo-image{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.admin-photo-item:hover .admin-photo-image{transform:scale(1.05)}.admin-photo-info{padding:.75rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;min-height:60px}.admin-photo-details{display:flex;flex-direction:column;gap:.25rem;flex:1}.admin-photo-delete{width:24px;height:24px;border-radius:4px;background:#dc3545;color:#fff;border:none;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;cursor:pointer;transition:all .3s ease;flex-shrink:0}.admin-photo-delete:hover{background:#c82333;transform:scale(1.05)}.admin-photo-uploader{font-weight:600;color:var(--text-primary);font-size:.9rem}.admin-photo-date{color:var(--text-secondary);font-size:.8rem}@media (max-width: 768px){.admin-photos-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.admin-photo-delete{width:20px;height:20px;font-size:12px}.admin-photo-info{padding:.5rem;min-height:50px}.admin-photo-uploader{font-size:.85rem}.admin-photo-date{font-size:.75rem}}.presentation-slideshow{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000;display:flex;flex-direction:column;overflow:hidden;z-index:1000;cursor:default}.presentation-slideshow.fullscreen-mode{cursor:none}.presentation-slideshow.fullscreen-mode:hover{cursor:default}.slideshow-loading,.slideshow-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;color:#fff;text-align:center}.loading-spinner{width:50px;height:50px;border:3px solid #333;border-top:3px solid #fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.back-button{background:#4a90e2;color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-size:16px;margin-top:20px;transition:background-color .3s ease}.back-button:hover{background:#357abd}.slideshow-container{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.slideshow-image-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:opacity .6s ease-in-out}.slideshow-image-container.fade-in{opacity:1}.slideshow-image-container.fade-out{opacity:.3}.slideshow-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 4px 20px #00000080}.photo-info-overlay{position:absolute;bottom:80px;right:20px;background:#000000b3;padding:15px 20px;border-radius:10px;color:#fff;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slideInFromRight .5s ease-out;transition:all .3s ease}.fullscreen-mode .photo-info-overlay{bottom:20px;background:#00000080}.photo-info{display:flex;flex-direction:column;gap:5px;font-size:14px}.photo-counter{font-weight:700;font-size:16px}.photo-uploader,.photo-date{opacity:.8}.wedding-title-overlay{position:absolute;top:20px;left:20px;right:20px;text-align:center;z-index:10}.wedding-title{color:#fff;font-size:2.5rem;font-weight:300;margin:0;text-shadow:2px 2px 10px rgba(0,0,0,.8);background:#0000004d;padding:20px 40px;border-radius:15px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);animation:slideInFromTop .5s ease-out;transition:all .3s ease}.fullscreen-mode .wedding-title-overlay{display:none}.slideshow-controls{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:10px;background:#ffffff1a;padding:15px 25px;border-radius:25px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #0000004d;transition:all .3s ease;opacity:1}.slideshow-controls.hidden{opacity:0;pointer-events:none;transform:translate(-50%) translateY(10px)}.control-button{background:#fff3;border:none;color:#fff;width:50px;height:50px;border-radius:50%;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.control-button:hover{background:#ffffff4d;transform:scale(1.1)}.control-button:active{transform:scale(.95)}.play-pause.playing{background:#22c55eb3}.play-pause.paused,.exit-button{background:#ef4444b3}.exit-button:hover{background:#ef4444e6}.fullscreen-button{background:#9ca3afb3}.fullscreen-button:hover{background:#9ca3afe6}.settings-panel{position:absolute;top:20px;right:20px;background:#000000e6;border-radius:15px;padding:25px;color:#fff;min-width:300px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 8px 32px #00000080;animation:slideInFromRight .3s ease-out;z-index:20}.settings-content h3{margin:0 0 20px;font-size:20px;font-weight:300}.setting-group{margin-bottom:20px}.setting-group label{display:block;margin-bottom:10px;font-weight:500}.speed-options{display:flex;flex-direction:column;gap:8px}.speed-option{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:10px 15px;border-radius:8px;cursor:pointer;transition:all .3s ease;text-align:left}.speed-option:hover{background:#fff3}.speed-option.active{background:#4a90e2cc;border-color:#4a90e2}.setting-group input[type=checkbox]{margin-right:10px;transform:scale(1.2)}.settings-help{margin-top:25px;padding-top:20px;border-top:1px solid rgba(255,255,255,.2)}.settings-help h4{margin:0 0 15px;font-size:16px;color:#ccc}.settings-help ul{list-style:none;padding:0;margin:0}.settings-help li{margin-bottom:8px;font-size:14px;color:#bbb}.close-settings{width:100%;background:#4a90e2cc;border:none;color:#fff;padding:12px;border-radius:8px;cursor:pointer;font-size:16px;margin-top:20px;transition:background-color .3s ease}.close-settings:hover{background:#4a90e2}.progress-container{position:absolute;bottom:0;left:0;right:0;height:4px;background:#fff3;transition:opacity .3s ease}.progress-bar{height:100%;background:linear-gradient(90deg,#4a90e2,#63b3ed);transition:width .3s ease}.fullscreen-mode .progress-container{opacity:0}@keyframes slideInFromRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-50px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.wedding-title{font-size:1.8rem;padding:15px 25px}.photo-info-overlay{bottom:100px;right:15px;left:15px;text-align:center}.photo-info{flex-direction:row;justify-content:space-between;align-items:center;gap:10px}.slideshow-controls{bottom:15px;padding:12px 20px}.control-button{width:45px;height:45px;font-size:16px}.settings-panel{top:15px;right:15px;left:15px;min-width:unset}.speed-options{grid-template-columns:1fr}}@media (max-width: 480px){.wedding-title{font-size:1.4rem;padding:12px 20px}.control-button{width:40px;height:40px;font-size:14px}.slideshow-controls{gap:8px;padding:10px 15px}}@media (max-width: 768px){.slideshow-container:after{content:"👆 Wischen für nächstes Foto";position:absolute;bottom:140px;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:8px 15px;border-radius:20px;font-size:12px;opacity:.7;animation:fadeInOut 3s ease-in-out;pointer-events:none}}@keyframes fadeInOut{0%,to{opacity:0}20%,80%{opacity:.7}}.auth-container{min-height:unset;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:.5rem 0}.auth-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:1.25rem;width:100%;max-width:320px;border:1px solid var(--border)}.auth-card h1{text-align:center;font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:2rem}.auth-form{display:flex;flex-direction:column;gap:1.5rem}.auth-button{background:var(--gradient-primary);color:var(--surface);border:none;padding:.875rem 1.5rem;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;margin-top:.5rem}.auth-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-lg)}.auth-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-footer{text-align:center;margin-top:1.5rem;color:var(--text-secondary);font-size:.875rem}.auth-footer a{color:var(--primary-color);text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}.email-verification-info{text-align:center;margin-bottom:1.5rem;color:var(--text-secondary);font-size:.875rem;line-height:1.5}.verification-code-input{text-align:center;font-size:1.5rem;font-weight:600;letter-spacing:.5rem;font-family:Courier New,monospace}.verification-actions{margin-top:2rem;text-align:center}.verification-actions p{margin:.75rem 0;color:var(--text-secondary);font-size:.875rem}.link-button{background:none;border:none;color:var(--primary-color);text-decoration:none;font-weight:500;font-size:inherit;cursor:pointer;padding:0}.loading-spinner{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top:4px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.link-button:hover:not(:disabled){text-decoration:underline}.link-button:disabled{opacity:.7;cursor:not-allowed}@media (max-width: 480px){.auth-container{padding:1rem}.auth-card{padding:2rem 1.5rem}.auth-card h1{font-size:1.75rem}.verification-code-input{font-size:1.25rem;letter-spacing:.3rem}}.rsvp-container{min-height:calc(100vh - 80px);display:flex;flex-direction:column;background:linear-gradient(135deg,var(--background) 0%,var(--border) 100%)}.rsvp-header-section{position:relative;height:50vh;min-height:400px;display:flex;align-items:center;justify-content:center;color:#fff;text-align:center;overflow:hidden}.rsvp-header-section:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:var(--background-image);background-size:cover;background-position:center;background-repeat:no-repeat;filter:brightness(.6);z-index:0}.rsvp-header-section:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(to bottom,#000000b3,#00000080,#000000b3);z-index:1}.rsvp-header-content{position:relative;z-index:2;padding:2rem;max-width:800px}.rsvp-header-content h1{font-size:3rem;font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.5)}.rsvp-header-content p{font-size:1.5rem;line-height:1.6;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.rsvp-form-section{flex:1;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;background:var(--background)}.rsvp-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2.5rem;width:100%;max-width:600px;border:1px solid var(--border);position:relative;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#fffffff2;margin-top:2rem}.rsvp-header{text-align:center;margin-bottom:2.5rem}.rsvp-header h1{font-size:2.25rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem}.rsvp-header p{color:var(--text-secondary);font-size:1.125rem;line-height:1.6}.rsvp-form{display:flex;flex-direction:column;gap:1.5rem}.rsvp-submit-button{background:var(--gradient-primary);color:var(--surface);border:none;padding:1rem 2rem;border-radius:var(--radius-lg);font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .3s;margin-top:1rem;box-shadow:var(--shadow-lg)}.rsvp-submit-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 20px 25px -5px var(--shadow-color),0 10px 10px -5px var(--shadow-color)}.rsvp-submit-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.rsvp-form .form-group{position:relative}.rsvp-form .form-input,.rsvp-form .form-select,.rsvp-form .form-textarea{border:2px solid var(--form-border);padding:.875rem 1rem;font-size:1rem;background-color:var(--form-bg);color:var(--form-text);transition:all .2s}.rsvp-form .form-input:focus,.rsvp-form .form-select:focus,.rsvp-form .form-textarea:focus{border-color:var(--form-focus-border);box-shadow:0 0 0 4px var(--form-focus-shadow);transform:translateY(-1px)}.rsvp-form label{font-weight:600;color:var(--text-primary);margin-bottom:.75rem}.rsvp-form select[name=status]{font-weight:500;font-size:1.125rem;background-color:var(--form-bg)}.rsvp-form select[name=status] option{padding:.5rem;background-color:var(--form-bg);color:var(--form-text)}.rsvp-form .form-group{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.rsvp-form select[name=guest_count]{background-color:var(--form-bg);font-weight:500}.rsvp-form select[name=accommodation]{background-color:var(--form-bg)}.rsvp-form textarea{background-color:var(--form-bg);min-height:120px;resize:vertical}@media (max-width: 768px){.rsvp-header-section{height:40vh;min-height:300px}.rsvp-header-content h1{font-size:2.25rem}.rsvp-header-content p{font-size:1.25rem}.rsvp-card{margin-top:-2rem;padding:2rem 1.5rem}.rsvp-header h1{font-size:1.875rem}.rsvp-header p{font-size:1rem}.rsvp-submit-button{padding:.875rem 1.5rem;font-size:1rem}}@media (max-width: 480px){.rsvp-header-section{height:35vh;min-height:250px}.rsvp-header-content h1{font-size:1.875rem}.rsvp-header-content p{font-size:1.125rem}.rsvp-card{margin-top:-1.5rem;padding:1.5rem 1rem}.rsvp-header{margin-bottom:2rem}.rsvp-header h1{font-size:1.5rem}}.wedding-info{margin:1.5rem 0;padding:1.5rem;background-color:var(--background);border-radius:var(--radius);text-align:center;border:1px solid var(--border)}.wedding-info h2{margin:0 0 1rem;color:var(--text-primary);font-size:1.5rem}.wedding-place,.wedding-time{margin:.5rem 0;color:var(--text-secondary);font-size:1.1rem}.wedding-place .icon,.wedding-time .icon{margin-right:.5rem;font-size:1.2rem;color:var(--primary-color)}.rsvp-success-container{min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:linear-gradient(135deg,var(--success-bg) 0%,#d9f99d 100%)}.rsvp-success-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:3rem 2rem;text-align:center;max-width:500px;width:100%;border:1px solid var(--border);position:relative;overflow:hidden}.rsvp-success-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-color) 0%,var(--secondary-color) 50%,#10b981 100%)}.success-icon{font-size:4rem;margin-bottom:1.5rem;animation:bounce 1s ease-in-out infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.rsvp-success-card h1{font-size:2.25rem;font-weight:700;color:var(--text-primary);margin-bottom:1.5rem;background:linear-gradient(135deg,var(--primary-color) 0%,#10b981 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.rsvp-success-card p{color:var(--text-secondary);font-size:1.125rem;line-height:1.7;margin-bottom:2rem}.success-actions{display:flex;justify-content:center}.back-button{background:var(--gradient-primary);color:var(--surface);text-decoration:none;padding:.875rem 2rem;border-radius:var(--radius-lg);font-size:1rem;font-weight:600;transition:all .3s;box-shadow:var(--shadow-lg);display:inline-flex;align-items:center;gap:.5rem}.back-button:hover{transform:translateY(-2px);box-shadow:0 20px 25px -5px var(--shadow-color),0 10px 10px -5px var(--shadow-color);text-decoration:none}.back-button:before{content:"🏠";font-size:1.125rem}@media (max-width: 768px){.rsvp-success-container{padding:1rem;align-items:flex-start;min-height:auto}.rsvp-success-card{padding:2.5rem 1.5rem;margin-top:2rem}.rsvp-success-card h1{font-size:1.875rem}.rsvp-success-card p{font-size:1rem}.success-icon{font-size:3rem}}@media (max-width: 480px){.rsvp-success-card{padding:2rem 1rem}.rsvp-success-card h1{font-size:1.5rem}.back-button{padding:.75rem 1.5rem;font-size:.875rem}}.dashboard-container{max-width:1200px;margin:0 auto;padding:2rem}.dashboard-header{text-align:center;margin-bottom:2rem}.dashboard-header h1{color:var(--text-primary);margin-bottom:.5rem}.user-info{color:var(--text-secondary);font-size:.9rem}.dashboard-actions{text-align:center;margin-bottom:3rem}.weddings-section{margin-bottom:4rem}.weddings-section h2{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.5rem}.dashboard-stats{background:var(--surface);border-radius:16px;padding:2rem;box-shadow:0 4px 20px var(--shadow-color);border:1px solid var(--border)}.dashboard-stats h2{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.5rem;text-align:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.stat-card{background:var(--background);padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px var(--shadow-color);text-align:center;border:1px solid var(--border);transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px var(--shadow-color-hover)}.stat-card h3{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0 0 .5rem}.stat-card p{color:var(--text-secondary);margin:0;font-size:.9rem}.empty-state{text-align:center;padding:3rem;background:var(--background);border-radius:12px;border:2px dashed var(--border)}.empty-state h2{color:var(--text-primary);margin-bottom:1rem;font-size:1.5rem}.empty-state p{color:var(--text-secondary);margin-bottom:2rem}.wedding-form{display:flex;flex-direction:column;gap:1rem;max-width:400px;margin:0 auto}.wedding-input{padding:1rem;border:1px solid var(--border);border-radius:var(--radius-lg);font-size:1rem;background:var(--surface);color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.wedding-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #d946ef1a}.weddings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.wedding-card{background:var(--surface);border-radius:12px;box-shadow:0 2px 8px var(--shadow-color);border:1px solid var(--border);overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.wedding-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px var(--shadow-color-hover)}.wedding-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 0}.wedding-header h3{margin:0;color:var(--text-primary);font-size:1.1rem}.status{padding:.25rem .75rem;border-radius:20px;font-size:.8rem;font-weight:500;text-transform:uppercase}.status.active{background:var(--status-attending-bg);color:var(--status-attending-text)}.status.inactive{background:var(--status-declined-bg);color:var(--status-declined-text)}.wedding-stats{padding:1rem 1.5rem}.stat{display:flex;justify-content:space-between;margin-bottom:.5rem}.stat:last-child{margin-bottom:0}.stat .label{color:var(--text-secondary);font-size:.9rem}.stat .value{color:var(--text-primary);font-weight:500;font-size:.9rem}.wedding-actions{display:flex;gap:.5rem;padding:1rem 1.5rem 1.5rem}.button{display:inline-block;padding:.75rem 1.5rem;background:var(--surface);color:var(--text-primary);text-decoration:none;border-radius:8px;border:2px solid var(--border);cursor:pointer;font-size:.9rem;font-weight:500;transition:all .3s ease;text-align:center;box-shadow:0 2px 8px var(--shadow-color)}.button:hover{transform:translateY(-2px);box-shadow:0 4px 16px var(--shadow-color-hover);border-color:var(--primary-color)}.button.primary{background:var(--gradient-primary);color:var(--surface);border:none;padding:1rem 2rem;font-size:1rem;box-shadow:0 4px 20px #6366f14d}.button.primary:hover{background:var(--gradient-primary);transform:translateY(-2px);box-shadow:0 8px 30px #6366f166;filter:brightness(1.1)}.button.secondary{background:var(--surface);color:var(--text-primary);border:2px solid var(--border)}.button.secondary:hover{background:var(--surface);border-color:var(--primary-color);transform:translateY(-2px);box-shadow:0 4px 16px var(--shadow-color-hover)}.button.small{padding:.5rem 1rem;font-size:.8rem;flex:1}.loading{text-align:center;padding:3rem;color:var(--text-secondary)}.error{text-align:center;padding:2rem;background:var(--error-bg);border-radius:8px;border:1px solid var(--error-text)}.error p{color:var(--error-text);margin-bottom:1rem}.auth-prompt{text-align:center;padding:3rem;background:var(--background);border-radius:12px}.auth-prompt h2{color:var(--text-primary);margin-bottom:1rem}.auth-prompt p{color:var(--text-secondary);margin-bottom:1.5rem}@media (max-width: 768px){.dashboard-container{padding:1rem}.weddings-grid{grid-template-columns:1fr}.wedding-actions{flex-direction:column}.wedding-form{max-width:100vw;margin:0}.empty-state{padding:2rem 1rem}}.management-dashboard{max-width:1200px;margin:0 auto;padding:2rem}.management-dashboard h1{margin-bottom:2rem;color:var(--text-primary)}.management-dashboard.loading,.management-dashboard.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--text-secondary)}.management-dashboard .spinner{width:40px;height:40px;border:3px solid var(--border);border-top:3px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.empty-state{text-align:center;padding:3rem;background:var(--surface);border-radius:var(--radius);color:var(--text-secondary)}.messages-list{display:grid;gap:1.5rem}.message-card{background:var(--surface);border-radius:var(--radius);padding:1.5rem;box-shadow:var(--shadow);border:1px solid var(--border);transition:all .2s ease}.message-card.unread{border-left:4px solid var(--primary-color);background-color:var(--form-bg)}.message-card.read{opacity:.8}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.message-header h3{margin:0;color:var(--text-primary);font-size:1.25rem}.mark-read-button{background:var(--primary-color);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius);cursor:pointer;font-size:.875rem;transition:background-color .2s}.mark-read-button:hover{background:var(--primary-hover)}.message-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.875rem;color:var(--text-secondary)}.message-sender{font-weight:500}.message-date{color:var(--text-secondary)}.message-content{color:var(--text-primary);line-height:1.6;white-space:pre-wrap}@media (max-width: 768px){.management-dashboard{padding:1rem}.message-header{flex-direction:column;align-items:flex-start;gap:1rem}.message-meta{flex-direction:column;align-items:flex-start;gap:.5rem}}.impressum{padding:2rem;max-width:800px;margin:0 auto;font-family:system-ui,-apple-system,sans-serif}.impressum-content{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.impressum h1{margin-bottom:2rem;color:#333;font-size:2rem}.impressum section{margin-bottom:2rem}.impressum h2{color:#444;font-size:1.25rem;margin-bottom:1rem}.impressum p{color:#666;line-height:1.6;margin-bottom:1rem}.impressum a{color:#007bff;text-decoration:none}.impressum a:hover{text-decoration:underline}.onboarding-container{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;position:relative;overflow:hidden}.onboarding-container:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url(/background.png) center/cover;opacity:.1;z-index:0}.onboarding-progress{position:fixed;top:0;left:0;right:0;z-index:100;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:15px 20px;box-shadow:0 2px 20px #0000001a}.progress-bar{width:100%;height:6px;background:#667eea33;border-radius:3px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;transition:width .5s ease}.progress-text{font-size:14px;color:#666;text-align:center;display:block}.onboarding-content{background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:20px;padding:40px;box-shadow:0 20px 60px #00000026;border:1px solid rgba(255,255,255,.2);max-width:600px;width:100%;margin-top:100px;margin-bottom:40px;position:relative;z-index:1;transform:translateY(0);opacity:1;transition:all .3s ease}.top-back-button{margin-bottom:20px;text-align:left}.onboarding-content.animating{transform:translateY(20px);opacity:0}.step-header{text-align:center;margin-bottom:30px}.step-header h1{font-size:2.5rem;color:#333;margin-bottom:10px;font-weight:700}.step-header p{font-size:1.1rem;color:#666;line-height:1.5}.step-content{margin-bottom:40px}.step-actions{display:flex;gap:15px;justify-content:center;align-items:center}.onboarding-button{padding:12px 30px;border:none;border-radius:25px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:120px}.onboarding-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea4d}.onboarding-button.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.onboarding-button.primary:disabled{opacity:.6;cursor:not-allowed}.onboarding-button.secondary{background:transparent;color:#667eea;border:2px solid #667eea}.onboarding-button.secondary:hover{background:#667eea1a}.onboarding-button.large{padding:15px 40px;font-size:18px}.onboarding-button.back{background:transparent;color:#666;border:2px solid #e1e5e9}.onboarding-button.back:hover{background:#667eea0d;border-color:#667eea;color:#667eea}.names-step{display:flex;flex-direction:column;gap:20px}.input-group{display:flex;flex-direction:column;gap:8px}.input-group label{font-weight:600;color:#333;font-size:14px}.onboarding-input{padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .3s ease;background:#fff;color:#333}.onboarding-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.invitation-page-step{text-align:center}.feature-explanation{margin-bottom:30px}.feature-explanation h3{color:#333;margin-bottom:15px}.feature-explanation ul{list-style:none;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:10px}.feature-explanation li{padding:10px;background:#667eea1a;border-radius:8px;font-size:14px;color:#667eea;font-weight:500}.cost-comparison{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:30px}.package-option{padding:20px;border:2px solid #e1e5e9;border-radius:12px;text-align:center}.package-option.premium{border-color:#667eea;background:#667eea0d}.package-option h4{margin-bottom:10px;color:#333}.package-option p{color:#666;font-size:14px}.choice-buttons{display:flex;gap:15px;justify-content:center}.choice-button{padding:15px 25px;border:2px solid #e1e5e9;border-radius:12px;background:#fff;color:#333;cursor:pointer;transition:all .3s ease;font-weight:500}.choice-button.active{border-color:#667eea;background:#667eea1a;color:#667eea}.choice-button:not(.active){color:#333}.choice-button:hover{border-color:#667eea}.date-time-step{display:grid;grid-template-columns:1fr 1fr;gap:20px}.location-step .input-group{margin-bottom:20px}.feature-option{padding:20px;border:2px solid #e1e5e9;border-radius:12px;background:#667eea05}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:500;margin-bottom:10px}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:#667eea}.feature-description{font-size:14px;color:#666;margin:0}.background-step .feature-option{text-align:center}.upload-label{cursor:pointer;display:block}.upload-area{border:2px dashed #d1d5db;border-radius:12px;padding:40px 20px;text-align:center;transition:border-color .3s ease;background:#fff}.upload-area:hover{border-color:#667eea}.upload-placeholder .upload-icon{font-size:48px;margin-bottom:15px}.upload-placeholder p{font-weight:500;margin-bottom:5px}.upload-cost{font-size:14px;color:#667eea;font-weight:600}.upload-preview{display:flex;flex-direction:column;align-items:center;gap:15px}.preview-image{max-width:200px;max-height:150px;border-radius:8px;box-shadow:0 4px 12px #00000026}.complete-step{text-align:center}.summary{background:#667eea0d;border-radius:12px;padding:30px}.summary h3{color:#333;margin-bottom:20px}.summary-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid rgba(102,126,234,.1)}.summary-item:last-child{border-bottom:none}.summary-total{display:flex;justify-content:space-between;align-items:center;padding:20px 0 10px;border-top:2px solid #667eea;margin-top:15px;font-weight:700;font-size:18px}.total-amount{color:#667eea;font-size:24px}@media (max-width: 768px){.onboarding-container{padding:10px}.onboarding-content{padding:30px 20px;margin-top:120px}.step-header h1{font-size:2rem}.cost-comparison,.date-time-step{grid-template-columns:1fr}.choice-buttons,.step-actions{flex-direction:column}.summary-item{flex-direction:column;align-items:flex-start;gap:5px}.summary-total{flex-direction:column;align-items:flex-start;gap:10px}}.navigation{position:fixed;top:0;left:0;right:0;z-index:1000;background:var(--surface);border-bottom:1px solid var(--border);box-shadow:var(--shadow)}.nav-container{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;align-items:center;justify-content:space-between;height:70px}.nav-logo{font-size:1.5rem;font-weight:700;color:var(--primary-color);text-decoration:none;display:flex;align-items:center;gap:.5rem}.nav-logo:hover{text-decoration:none}.nav-links{display:flex;align-items:center;gap:1rem}.nav-user{color:var(--text-secondary);font-size:.875rem}.nav-button{padding:.5rem 1rem;border-radius:var(--radius);font-size:.875rem;font-weight:500;text-decoration:none;border:none;cursor:pointer;transition:all .2s}.nav-button-primary{background-color:var(--primary-color);color:var(--surface)}.nav-button-primary:hover{background-color:var(--primary-hover);transform:translateY(-1px)}.nav-button-secondary{background-color:transparent;color:var(--text-primary);border:1px solid var(--border)}.nav-button-secondary:hover{background-color:var(--background);transform:translateY(-1px)}@media (max-width: 768px){.nav-container{height:60px;padding:0 .75rem}.nav-logo{font-size:1.25rem}.nav-links{gap:.5rem}.nav-button{padding:.375rem .75rem;font-size:.8rem}.nav-user{display:none}}:root{--primary-color: #4f46e5;--primary-hover: #4338ca;--secondary-color: #7c3aed;--secondary-hover: #6d28d9;--text-primary: #111827;--text-secondary: #4b5563;--background: #f9fafb;--surface: #ffffff;--border: #e5e7eb;--success-bg: #ecfdf5;--success-text: #1f2937;--error-bg: #fee2e2;--error-text: #991b1b;--warning-bg: #fef3c7;--warning-text: #92400e;--gradient-primary: linear-gradient(135deg, var(--primary-color) 0%, var(--secondary-color) 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-warning: linear-gradient(135deg, #fef3c7 0%, #fde68a 100%);--gradient-info: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);--shadow-color: rgba(0, 0, 0, .08);--shadow-color-hover: rgba(0, 0, 0, .15);--shadow: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--status-attending-bg: #ecfdf5;--status-attending-text: #1f2937;--status-declined-bg: #fee2e2;--status-declined-text: #991b1b;--status-pending-bg: #fef3c7;--status-pending-text: #92400e;--button-primary: #2563eb;--button-primary-hover: #1d4ed8;--button-secondary: #4b5563;--button-secondary-hover: #374151;--button-blue: #2563eb;--button-blue-hover: #1d4ed8;--form-bg: #ffffff;--form-border: #e5e7eb;--form-focus-border: #4f46e5;--form-focus-shadow: rgba(79, 70, 229, .1);--form-text: #111827;--form-placeholder: #9ca3af;--radius: 8px;--radius-lg: 12px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--background);color:var(--text-primary);line-height:1.6}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding-top:80px}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-input,.form-select,.form-textarea{width:100%;padding:.75rem;border:1px solid var(--form-border);border-radius:var(--radius);font-size:1rem;background-color:var(--form-bg);color:var(--form-text);transition:border-color .2s,box-shadow .2s}.form-input::placeholder,.form-select::placeholder,.form-textarea::placeholder{color:var(--form-placeholder)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--form-focus-border);box-shadow:0 0 0 3px var(--form-focus-shadow)}.form-textarea{resize:vertical;min-height:100px}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;border:none;border-radius:var(--radius);cursor:pointer;transition:all .2s;text-decoration:none;gap:.5rem;color:var(--surface)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background-color:var(--button-primary);color:var(--surface)}.btn-primary:hover:not(:disabled){background-color:var(--button-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-secondary{background-color:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background-color:var(--background);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.card-header{padding:1.5rem;border-bottom:1px solid var(--border)}.card-body{padding:1.5rem}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.status-badge.attending{background-color:#ecfdf5;color:#1f2937}.status-badge.declined{background-color:#fee2e2;color:#991b1b}.status-badge.pending{background-color:#fef3c7;color:#92400e}.error-message{background-color:#fee2e2;color:#991b1b;padding:.75rem;border-radius:var(--radius);margin-bottom:1rem;border:1px solid #fecaca}.success-message{background-color:#ecfdf5;color:#1f2937;padding:.75rem;border-radius:var(--radius);margin-bottom:1rem;border:1px solid #a7f3d0}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-state p{margin-bottom:.5rem}.loading{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--text-secondary)}.app-loading{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--background)}.loading-spinner{text-align:center}.loading-spinner p{color:var(--text-secondary);margin:0}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top:2px solid var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin-right:.5rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 768px){.main-content{padding-top:10px}.btn{padding:.625rem 1.25rem;font-size:.875rem}.card{margin:0 1rem}}
