@import "https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,600;1,400&family=Great+Vibes&family=Montserrat:wght@300;400;500;600&display=swap";:root{--powder-blue:#afc2d5;--powder-blue-light:#afc2d566;--powder-blue-dark:#8a9eae;--navy-blue:#3a506b;--green:#5f8575;--ivory:#f7f4f1;--white:#fff;--text-dark:#3a506b;--text-light:#5f8575}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--ivory);color:var(--text-dark);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-attachment:fixed;justify-content:center;align-items:flex-start;min-height:100vh;padding:2rem 1rem;font-family:Montserrat,sans-serif;display:flex}#root{width:100%;max-width:600px;margin:0 auto}h1,h2,h3,h4,h5,h6{color:var(--text-dark);font-family:Cormorant Garamond,serif}.app-container{flex-direction:column;gap:2rem;animation:1s ease-out forwards fadeIn;display:flex}.header{text-align:center;margin-bottom:1rem}.top-bar{justify-content:flex-start;width:100%;margin-bottom:.5rem;display:flex}.home-button{background:var(--powder-blue);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--white);border:1px solid #ffffff80;border-radius:20px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex;box-shadow:0 4px 10px #afc2d54d}.home-button:hover{background:var(--powder-blue-dark);color:var(--white);transform:translateY(-2px);box-shadow:0 6px 15px #afc2d566}.wedding-date{color:var(--green);text-transform:uppercase;letter-spacing:2px;margin-bottom:.5rem;font-size:1rem;font-weight:600}.couple-container{flex-direction:column;align-items:center;margin:1.5rem 0 2rem;display:flex;position:relative}.couple-names{color:var(--navy-blue);text-shadow:2px 2px 4px #afc2d566;flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem;margin-bottom:.2rem;font-family:Great Vibes,cursive;font-size:4.5rem;font-weight:400;line-height:1.1;display:flex}.last-name{letter-spacing:12px;color:var(--green);text-transform:uppercase;margin-top:.5rem;margin-left:12px;font-family:Montserrat,sans-serif;font-size:1.2rem;font-weight:500}.heart-icon{color:var(--powder-blue);margin:0 .5rem;animation:2s infinite pulse}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.couple-portrait{object-fit:cover;border:6px solid var(--white);border-radius:120px 120px 20px 20px;width:200px;height:260px;margin-bottom:1.5rem;animation:1.2s ease-out fadeIn;box-shadow:0 15px 35px #8bacc166}.doors-open{color:var(--text-light);margin-bottom:1.5rem;font-size:1rem;font-weight:500}.subtitle{color:var(--text-dark);letter-spacing:1px;padding-bottom:.5rem;font-family:Montserrat,sans-serif;font-size:1.8rem;font-weight:500;display:inline-block;position:relative}.subtitle:after{content:"";background-color:var(--powder-blue);width:50px;height:2px;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.search-container{z-index:10;width:100%;position:relative}.search-input-wrapper{-webkit-backdrop-filter:blur(10px);background:#ffffffb3;border:1px solid #ffffff80;border-radius:30px;align-items:center;width:100%;padding:.5rem 1.5rem;transition:all .3s;display:flex;position:relative;box-shadow:0 8px 32px #8bacc133}.search-input-wrapper:focus-within{box-shadow:0 12px 40px #afc2d54d, 0 0 0 2px var(--powder-blue);background:#ffffffe6}.search-icon{color:var(--powder-blue-dark);flex-shrink:0;margin-right:10px}.search-input{width:100%;color:var(--text-dark);background:0 0;border:none;outline:none;padding:.8rem 0;font-family:Montserrat,sans-serif;font-size:1.1rem}.search-input::placeholder{color:var(--text-light);font-weight:500}.retro-shutter-btn:disabled{cursor:not-allowed;opacity:.6;background:#444;border-color:#666}.retro-gallery-label.disabled{opacity:.5;cursor:not-allowed;background:#ffffff0d}.retro-stats{flex-direction:column;align-items:flex-end;gap:.2rem;display:flex}.retro-stat{color:#ffb347;text-shadow:0 0 8px #ffb34766;align-items:center;gap:.4rem;font-family:Courier New,monospace;font-size:.85rem;font-weight:700;display:flex}.retro-stat.limit-reached{color:#ff4d4d;text-shadow:0 0 8px #ff4d4d66}.clear-btn{color:var(--text-light);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:.5rem;transition:color .2s;display:flex}.clear-btn:hover{color:var(--text-dark)}.results-container{flex-direction:column;gap:1rem;display:flex}.guest-card{-webkit-backdrop-filter:blur(12px);opacity:0;background:#fff9;border:1px solid #fffc;border-radius:20px;justify-content:space-between;align-items:center;padding:1.2rem 1.5rem;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .3s;animation:.5s ease-out forwards slideUp;display:flex;box-shadow:0 4px 16px #8bacc126}.guest-card:hover{background:#fffc;transform:translateY(-5px)scale(1.02);box-shadow:0 12px 24px #8bacc140}.guest-info{flex-direction:column;display:flex}.guest-name{color:var(--text-dark);font-size:1.3rem;font-weight:500}.guest-role{color:var(--text-light);margin-top:.2rem;font-family:Cormorant Garamond,serif;font-size:.9rem;font-style:italic}.table-info{background:var(--white);border:2px solid var(--powder-blue);width:65px;height:65px;box-shadow:0 4px 10px var(--powder-blue-light);border-radius:50%;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;display:flex}.table-label{text-transform:uppercase;letter-spacing:1px;color:var(--text-light);margin-bottom:-2px;font-size:.65rem;font-weight:600}.table-number{color:var(--navy-blue);font-family:Cormorant Garamond,serif;font-size:2rem;font-weight:700;line-height:1}.empty-state{text-align:center;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text-light);background:#fff6;border:1px dashed #8bacc180;border-radius:20px;padding:3rem 1rem;animation:.5s ease-out forwards fadeIn}.empty-state-icon{color:var(--powder-blue-dark);opacity:.7;margin-bottom:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUpFadeIn{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.welcome-screen{animation:.8s ease-in-out forwards fadeIn}.welcome-heart{animation:1.5s ease-in-out infinite pulse,1s ease-out fadeIn}.welcome-title{opacity:0;animation:.8s cubic-bezier(.2,.8,.2,1) .3s forwards slideUpFadeIn}.welcome-subtitle{opacity:0;animation:.8s cubic-bezier(.2,.8,.2,1) .9s forwards slideUpFadeIn}.guest-card:first-child{animation-delay:50ms}.guest-card:nth-child(2){animation-delay:.1s}.guest-card:nth-child(3){animation-delay:.15s}.guest-card:nth-child(4){animation-delay:.2s}.guest-card:nth-child(5){animation-delay:.25s}.guest-card:nth-child(n+6){animation-delay:.3s}@media (width<=480px){body{padding:1.5rem 1rem}.couple-names{font-size:3.5rem}.last-name{letter-spacing:8px;margin-left:8px;font-size:1rem}.header h1{font-size:2.5rem}.search-input-wrapper{padding:.4rem 1.2rem}.guest-card{padding:1rem 1.2rem}.guest-name{font-size:1.2rem}.table-info{width:55px;height:55px}.table-number{font-size:1.6rem}}.landing-links{flex-direction:column;gap:1.5rem;width:100%;display:flex}.landing-action-card{-webkit-backdrop-filter:blur(12px);color:var(--text-dark);opacity:0;background:#ffffffb3;border:1px solid #fffc;border-radius:20px;align-items:center;padding:1.5rem;text-decoration:none;transition:transform .3s cubic-bezier(.175,.885,.32,1.275),box-shadow .3s,background .3s;animation:.5s ease-out forwards slideUp;display:flex;box-shadow:0 4px 16px #8bacc126}.landing-action-card:hover{background:#ffffffe6;transform:translateY(-5px)scale(1.02);box-shadow:0 12px 24px #8bacc140}.landing-action-card:first-child{animation-delay:.1s}.landing-action-card:nth-child(2){animation-delay:.2s}.landing-action-card:nth-child(3){animation-delay:.3s}.action-icon-wrapper{background:var(--powder-blue);border:2px solid var(--white);width:60px;height:60px;color:var(--white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-right:1.5rem;display:flex;box-shadow:inset 0 2px 5px #afc2d533}.action-icon{color:var(--white)}.action-text h3{color:var(--text-dark);margin-bottom:.3rem;font-family:Montserrat,sans-serif;font-size:1.2rem;font-weight:600}.action-text p{color:var(--text-light);margin:0;font-size:.95rem}.retro-camera-page{z-index:100;background:#1a1a1a;flex-direction:column;font-family:Montserrat,sans-serif;display:flex;position:fixed;inset:0;overflow:hidden}.retro-top-bar{z-index:10;background:#0009;justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.retro-back-btn{color:#e0d5c8;background:#ffffff14;border:1px solid #ffffff1f;border-radius:20px;align-items:center;gap:.4rem;padding:.4rem .8rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:background .2s;display:flex}.retro-back-btn:hover{color:#e0d5c8;background:#ffffff26}.retro-counter{color:#ffb347;text-shadow:0 0 8px #ffb34766;align-items:center;gap:.4rem;font-family:Courier New,monospace;font-size:.95rem;font-weight:700;display:flex}.retro-body{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:1.25rem;padding:1rem;display:flex}.retro-viewfinder{aspect-ratio:3/4;background:#0d0d0d;border:3px solid #333;border-radius:8px;width:100%;max-width:500px;position:relative;overflow:hidden;box-shadow:0 0 0 4px #1a1a1a,0 0 0 6px #444,0 8px 32px #0009}.retro-video{object-fit:cover;filter:sepia(.25)contrast(1.08)saturate(1.25)brightness(.92);width:100%;height:100%}.retro-preview-img{object-fit:cover;width:100%;height:100%}.retro-grain-overlay{pointer-events:none;opacity:.35;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");background-size:128px 128px;animation:.5s steps(4,end) infinite grain;position:absolute;inset:0}@keyframes grain{0%,to{transform:translate(0)}25%{transform:translate(-2px,2px)}50%{transform:translate(2px,-1px)}75%{transform:translate(-1px,-2px)}}.retro-vignette-overlay{pointer-events:none;background:radial-gradient(#0000 40%,#00000080 100%);position:absolute;inset:0}.retro-date-stamp{color:#ffa032cc;text-shadow:0 0 6px #ffa03266;pointer-events:none;letter-spacing:1px;font-family:Courier New,monospace;font-size:.85rem;font-weight:700;position:absolute;bottom:12px;right:14px}.retro-flash-overlay{z-index:20;pointer-events:none;background:#fff;animation:.3s ease-out forwards flashPop;position:absolute;inset:0}@keyframes flashPop{0%{opacity:1}to{opacity:0}}.retro-placeholder{color:#666;flex-direction:column;justify-content:center;align-items:center;gap:1rem;height:100%;display:flex}.retro-placeholder p{color:#555;font-size:.9rem;font-style:italic}.retro-controls{flex-direction:column;align-items:center;gap:1rem;width:100%;max-width:500px;display:flex}.retro-controls-row{justify-content:center;align-items:center;gap:2rem;width:100%;display:flex}.retro-shutter-btn{color:#fff;cursor:pointer;background:linear-gradient(145deg,#c0392b,#e74c3c);border:4px solid #e0d5c8;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;transition:transform .1s,box-shadow .1s;display:flex;box-shadow:0 0 0 4px #0000004d,0 4px 16px #0006,inset 0 2px 4px #fff3}.retro-shutter-btn:active{transform:scale(.92);box-shadow:0 0 0 4px #0000004d,0 2px 8px #0006}.retro-shutter-inner{background:#ffffff4d;border:2px solid #ffffff80;border-radius:50%;width:28px;height:28px}.retro-btn{cursor:pointer;border:none;border-radius:30px;align-items:center;gap:.5rem;padding:.7rem 1.4rem;font-family:Montserrat,sans-serif;font-size:.9rem;font-weight:500;transition:transform .2s,background .2s;display:flex}.retro-btn:active{transform:scale(.96)}.retro-btn-primary{background:var(--green);color:#fff;box-shadow:0 4px 12px #5c725f66}.retro-btn-secondary{color:#e0d5c8;background:#ffffff1a;border:1px solid #ffffff26}.retro-btn-icon{color:#e0d5c8;background:#ffffff14;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;padding:0;display:flex}.retro-gallery-label{cursor:pointer}.retro-progress-bar-container{background:#ffffff1a;border-radius:4px;width:100%;max-width:500px;height:8px;position:relative;overflow:hidden}.retro-progress-bar{background:linear-gradient(90deg,#ffb347,#ff6b35);border-radius:4px;height:100%;transition:width .3s}.retro-progress-text{color:#ffb347;font-family:Courier New,monospace;font-size:.75rem;font-weight:700;position:absolute;top:-22px;right:0}.retro-success-msg{color:var(--green);align-items:center;gap:.5rem;font-size:1.1rem;font-weight:600;animation:.4s ease-out fadeIn;display:flex}.retro-error-msg{color:#e74c3c;align-items:center;gap:.4rem;font-size:.85rem;font-weight:500;display:flex}
