:root{--color-bg: #0a0a1a;--color-bg-alt: #0f0f24;--color-surface: #1a1a2e;--color-surface-hover: #22223a;--color-surface-glass: rgba(26, 26, 46, .7);--color-accent: #d4a574;--color-accent-light: #e8c9a0;--color-accent-hover: #c4955a;--color-rose: #b76e79;--color-rose-light: #d4929c;--color-text: #f5f0eb;--color-text-secondary: #8a8a9a;--color-text-muted: #5a5a6e;--color-success: #7ec8a0;--color-error: #e07070;--color-border: rgba(212, 165, 116, .15);--color-border-strong: rgba(212, 165, 116, .3);--gradient-accent: linear-gradient(135deg, var(--color-accent), var(--color-rose));--gradient-bg: radial-gradient(ellipse at 20% 50%, rgba(212, 165, 116, .05) 0%, transparent 50%), radial-gradient(ellipse at 80% 20%, rgba(183, 110, 121, .05) 0%, transparent 50%);--gradient-shimmer: linear-gradient(90deg, transparent, rgba(212, 165, 116, .1), transparent);--font-display: "Playfair Display", serif;--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--fs-hero: clamp(2.5rem, 6vw, 4.5rem);--fs-h1: clamp(2rem, 4vw, 3rem);--fs-h2: clamp(1.5rem, 3vw, 2rem);--fs-h3: clamp(1.1rem, 2vw, 1.4rem);--fs-body: 1rem;--fs-small: .875rem;--fs-xs: .75rem;--radius-sm: 3px;--radius-md: 6px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--shadow-glow: 0 0 30px rgba(212, 165, 116, .15);--shadow-glow-strong: 0 0 50px rgba(212, 165, 116, .25);--transition-fast: .15s ease;--transition-base: .3s ease;--transition-slow: .5s ease;--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1);--max-w: 1200px;--max-w-sm: 600px;--max-w-xs: 480px;--container-padding: clamp(1rem, 4vw, 2rem)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.6;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:var(--gradient-bg);pointer-events:none;z-index:0}#root{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}img{max-width:100%;display:block}a{color:var(--color-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-light)}h1,h2,h3,h4{font-family:var(--font-display);line-height:1.2;letter-spacing:-.02em}.text-gradient{background:var(--gradient-accent);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.container{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 var(--container-padding)}.container--sm{max-width:var(--max-w-sm)}.container--xs{max-width:var(--max-w-xs)}.page{flex:1;display:flex;flex-direction:column}.header{position:sticky;top:0;z-index:100;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:rgba(10,10,26,.8);border-bottom:1px solid var(--color-border)}.header__inner{display:flex;align-items:center;justify-content:space-between;padding:1rem var(--container-padding);max-width:var(--max-w);margin:0 auto}.header__logo{font-family:var(--font-display);font-size:1.4rem;font-weight:600;color:var(--color-text);display:flex;align-items:center;gap:.5rem}.header__logo-icon{font-size:1.6rem}.header__nav{display:flex;gap:.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;font-family:var(--font-body);font-size:var(--fs-body);font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;text-decoration:none;line-height:1.4}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--primary{background:#fe2786;color:#fff;font-weight:800;border-radius:3px;box-shadow:none;letter-spacing:.02em}.btn--primary:hover:not(:disabled){background:#000;transform:none;text-decoration:underline;text-underline-offset:4px;box-shadow:none}.btn--primary:active:not(:disabled){transform:translateY(0);background:#cc1563}.btn--secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-strong)}.btn--ghost{background:transparent;color:var(--color-text-secondary);padding:.5rem 1rem}.btn--ghost:hover:not(:disabled){color:var(--color-text);background:rgba(255,255,255,.05)}.btn--lg{padding:1rem 2rem;font-size:1.1rem;border-radius:var(--radius-lg)}.btn--sm{padding:.5rem 1rem;font-size:var(--fs-small)}.btn--icon{padding:.6rem;border-radius:var(--radius-sm)}.btn--danger{background:var(--color-error);color:#fff}.btn--danger:hover:not(:disabled){background:#c85050}.card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);padding:2rem;transition:all var(--transition-base)}.card--glass{background:var(--color-surface-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.card--hover:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:var(--fs-small);font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.form-input,.form-textarea,.form-select{width:100%;padding:.75rem 1rem;font-family:var(--font-body);font-size:var(--fs-body);color:var(--color-text);background:rgba(255,255,255,.05);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:all var(--transition-fast);outline:none}.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px rgba(212,165,116,.1)}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-text-muted)}.form-textarea{resize:vertical;min-height:100px}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px rgba(212,165,116,.1)}50%{box-shadow:0 0 40px rgba(212,165,116,.25)}}@keyframes spin{to{transform:rotate(360deg)}}.animate-fadeIn{animation:fadeIn .6s ease forwards}.animate-slideUp{animation:slideUp .8s ease forwards}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.footer{margin-top:auto;padding:2rem var(--container-padding);text-align:center;color:var(--color-text-muted);font-size:var(--fs-small);border-top:1px solid var(--color-border)}.footer a{color:var(--color-text-secondary)}.footer a:hover{color:var(--color-accent)}.upload-zone{position:relative;border:2px dashed var(--color-border-strong);border-radius:var(--radius-xl);padding:3rem 2rem;text-align:center;cursor:pointer;transition:all var(--transition-base);overflow:hidden}.upload-zone:hover,.upload-zone--active{border-color:var(--color-accent);background:rgba(212,165,116,.05)}.upload-zone__icon{font-size:3rem;margin-bottom:1rem;animation:float 4s ease-in-out infinite}.upload-zone__title{font-family:var(--font-display);font-size:var(--fs-h3);margin-bottom:.5rem}.upload-zone__subtitle{color:var(--color-text-secondary);font-size:var(--fs-small)}.progress-bar{width:100%;height:4px;background:rgba(255,255,255,.1);border-radius:var(--radius-full);overflow:hidden}.progress-bar__fill{height:100%;background:var(--gradient-accent);border-radius:var(--radius-full);transition:width var(--transition-base)}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.photo-card{position:relative;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all var(--transition-base)}.photo-card:hover{transform:scale(1.02);box-shadow:var(--shadow-lg)}.photo-card img{width:100%;height:100%;object-fit:cover}.photo-card__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(transparent 50%,rgba(0,0,0,.7));opacity:0;transition:opacity var(--transition-base);display:flex;align-items:flex-end;padding:1rem}.photo-card:hover .photo-card__overlay{opacity:1}.photo-card__info{color:#fff;font-size:var(--fs-small)}.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite;margin:2rem auto}.toast{position:fixed;bottom:2rem;left:50%;transform:translate(-50%) translateY(100px);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.5rem;display:flex;align-items:center;gap:.75rem;box-shadow:var(--shadow-lg);z-index:1000;transition:transform var(--transition-spring);backdrop-filter:blur(20px)}.toast--visible{transform:translate(-50%) translateY(0)}.toast--success{border-color:rgba(126,200,160,.3)}.toast--error{border-color:rgba(224,112,112,.3)}.qr-container{background:#fff;border-radius:var(--radius-lg);padding:1.5rem;display:inline-block;box-shadow:var(--shadow-md)}.slideshow{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:200;overflow:hidden}.slideshow__image{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity 1s ease}.slideshow__image--active{opacity:1}.slideshow__image img{width:100vw;height:100vh;object-fit:contain}.slideshow__header{position:absolute;top:1.5rem;left:50%;transform:translate(-50%);background:rgba(0,0,0,.65);padding:.75rem 2rem;border-radius:var(--radius-full);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:10;text-align:center}.slideshow__footer{position:absolute;bottom:2.5rem;left:50%;transform:translate(-50%);background:rgba(0,0,0,.75);padding:1rem 2rem;border-radius:var(--radius-lg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:10;text-align:center;max-width:85vw;box-shadow:0 10px 30px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.05)}.slideshow__event-name{font-family:var(--font-display);font-size:var(--fs-h3);color:var(--color-accent)}.slideshow__caption{color:#fff;font-size:var(--fs-h3);font-weight:500;line-height:1.4}.slideshow__sender{color:var(--color-accent-light);font-size:var(--fs-small);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.slideshow__counter{position:absolute;top:1.5rem;right:1.5rem;background:rgba(0,0,0,.5);padding:.5rem 1rem;border-radius:var(--radius-full);font-size:var(--fs-small);color:rgba(255,255,255,.6);backdrop-filter:blur(10px)}.slideshow__logo{position:absolute;top:1.5rem;left:1.5rem;font-family:var(--font-display);font-size:1.2rem;color:rgba(255,255,255,.4)}.slideshow__waiting{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;text-align:center;gap:1.5rem}.slideshow__waiting-icon{font-size:4rem;animation:float 3s ease-in-out infinite}.slideshow__waiting h2{font-family:var(--font-display);font-size:var(--fs-h2);color:var(--color-accent)}.slideshow__waiting p{color:var(--color-text-secondary);max-width:400px}@media (max-width: 768px){.photo-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem}.card{padding:1.5rem}.header__nav{gap:.25rem}.btn--lg{padding:.875rem 1.5rem;font-size:1rem}}@media (max-width: 480px){.photo-grid{grid-template-columns:repeat(2,1fr)}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-center{text-align:center}.text-accent{color:var(--color-accent)}.text-secondary{color:var(--color-text-secondary)}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1.5rem;animation:fadeIn .2s ease-out}.modal-content{background:#0f0f15;border:1px solid #fe278633;width:100%;max-width:450px;border-radius:3px;box-shadow:0 25px 50px -12px rgba(0,0,0,.5);animation:slideUp .3s ease-out;overflow:hidden}.modal-header{padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.05);display:flex;align-items:center;justify-content:space-between}.modal-title{font-size:1.25rem;font-weight:700;color:#fff}.modal-body{padding:1.5rem;color:rgba(255,255,255,.8);line-height:1.6}.modal-footer{padding:1.25rem 1.5rem;display:flex;justify-content:flex-end;gap:.75rem;background:rgba(255,255,255,.02)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
