@import"https://fonts.googleapis.com/css2?family=Preahvihear&family=Poppins:wght@400;700;900&display=swap";.download-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background-size:100% 100%;padding:20px;font-family:Poppins,sans-serif;box-sizing:border-box}.download-container.loading,.download-container.error{flex-direction:column;text-align:center}.download-container.loading p{margin-top:20px;color:#2d4b42;font-size:1.5rem;font-weight:700}.spinner{animation:spin 1s linear infinite;color:#2d4b42}.spinner-small{animation:spin 1s linear infinite}.error-content{background:#ffffffe6;padding:40px;border-radius:30px;box-shadow:0 10px 30px #0000001a;max-width:400px}.error-content h2{margin:0 0 15px;font-size:2.5rem;color:#2d4b42;font-weight:700}.error-content p{margin:10px 0;color:#5a8b7d;font-size:1.2rem;font-weight:500}.error-content .hint{font-size:1rem;color:#666}.download-content{background-color:#ffffffe6;border-radius:30px;padding:40px;box-shadow:0 10px 30px #0000001a;max-width:900px;width:100%;display:flex;flex-direction:column;align-items:center;gap:30px}.title-text{font-size:2.2rem;color:#2d4b42;font-weight:700;margin:0;text-align:center}.subtitle-text{font-size:1.2rem;color:#5a8b7d;font-weight:500;margin:0 0 5px;text-align:center}.photo-frame{background:#fff;padding:15px;border-radius:20px;box-shadow:0 15px 40px #0000001a;width:100%;position:relative;min-height:300px}.composite-photo{width:100%;height:auto;border-radius:10px;display:block}.image-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fffffff2;border-radius:10px;z-index:10}.image-loading-overlay p{margin-top:15px;color:#2d4b42;font-size:1.1rem;font-weight:600}.image-error-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fef2f2f2;border-radius:10px;z-index:10;padding:20px;text-align:center}.image-error-overlay p{margin:0 0 15px;color:#dc2626;font-size:1.1rem;font-weight:600}.retry-btn{padding:10px 20px;background:#2d4b42;color:#fff;border:none;border-radius:10px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.retry-btn:hover{background:#1a2e29;transform:scale(1.05)}.retry-btn:active{transform:scale(.95)}.action-buttons{display:flex;gap:15px;width:100%;margin-top:10px}.action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;padding:15px 20px;border-radius:50px;font-size:1.4rem;font-weight:700;font-family:Poppins,sans-serif;cursor:pointer;transition:all .3s ease}.action-btn:disabled{opacity:.6;cursor:not-allowed}.action-btn.primary{background:#fff;color:#000;border:3px solid black;box-shadow:0 5px #000}.action-btn.primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 7px #000}.action-btn.primary:active:not(:disabled){transform:translateY(2px);box-shadow:0 3px #000}.footer-text{color:#2d4b42;font-size:1rem;font-weight:600;text-align:center;margin:0}.photo-section{width:100%;background:#fff;padding:20px;border-radius:20px;box-shadow:0 5px 20px #00000014}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #f0f0f0}.section-title{display:flex;align-items:center;gap:10px}.section-title h3{margin:0;font-size:1.3rem;color:#2d4b42;font-weight:700}.download-section-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#2d4b42;color:#fff;border:none;border-radius:50px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;font-family:Poppins,sans-serif}.download-section-btn:hover:not(:disabled){background:#1a2e29;transform:scale(1.05)}.download-section-btn:disabled{opacity:.6;cursor:not-allowed}.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px;width:100%}.photo-item{position:relative;aspect-ratio:1;background:#f5f5f5;border-radius:15px;overflow:hidden;box-shadow:0 3px 10px #0000001a}.photo-thumbnail{width:100%;height:100%;object-fit:cover;display:block}.photo-loading,.photo-error{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:#ffffffe6}.photo-error p{color:#dc2626;font-size:.9rem;font-weight:600}.photo-download-btn{position:absolute;bottom:10px;right:10px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#2d4b42e6;color:#fff;border:none;border-radius:50%;cursor:pointer;transition:all .3s ease;box-shadow:0 3px 10px #0003}.photo-download-btn:hover:not(:disabled){background:#2d4b42;transform:scale(1.1)}.photo-download-btn:disabled{opacity:.6;cursor:not-allowed}.composite-wrapper{position:relative;width:100%;min-height:200px;background:#f5f5f5;border-radius:15px;overflow:hidden;box-shadow:0 5px 20px #0000001a}.composite-loading,.composite-error{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fffffff2}.composite-loading p,.composite-error p{margin-top:15px;color:#2d4b42;font-size:1.1rem;font-weight:600}.composite-error p{color:#dc2626}.composite-error .retry-btn{margin-top:15px}.composite-photo-large{width:100%;height:auto;display:block}.gif-wrapper{position:relative;width:100%;max-width:400px;min-height:200px;background:#f5f5f5;border-radius:15px;overflow:hidden;box-shadow:0 5px 20px #0000001a;margin:0 auto}.gif-loading,.gif-error{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#fffffff2}.gif-loading p,.gif-error p{margin-top:15px;color:#2d4b42;font-size:1.1rem;font-weight:600}.gif-error p{color:#dc2626}.gif-error .retry-btn{margin-top:15px}.gif-photo{width:100%;height:auto;display:block}.video-wrapper{position:relative;width:100%;max-width:600px;min-height:200px;background:#000;border-radius:15px;overflow:hidden;box-shadow:0 5px 20px #0003;margin:0 auto}.video-loading,.video-error{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000000e6;z-index:10}.video-loading p,.video-error p{margin-top:15px;color:#fff;font-size:1.1rem;font-weight:600}.video-error p{color:#ff6b6b}.video-error .retry-btn{margin-top:15px;background:#fff;color:#dc2626}.video-player{width:100%;height:auto;display:block}.download-all-section{width:100%;padding-top:10px;border-top:2px solid #f0f0f0}.download-all-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:18px 30px;background:linear-gradient(135deg,#2d4b42,#1a2e29);color:#fff;border:none;border-radius:50px;font-size:1.3rem;font-weight:700;font-family:Poppins,sans-serif;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 25px #2d4b424d}.download-all-btn:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 12px 35px #2d4b4266}.download-all-btn:active:not(:disabled){transform:translateY(-1px)}.download-all-btn:disabled{opacity:.7;cursor:not-allowed}@media (max-width: 600px){.download-content{padding:25px;max-width:100%}.section-header{flex-direction:column;gap:15px;align-items:flex-start}.photo-grid{grid-template-columns:repeat(2,1fr);gap:10px}.download-all-btn{font-size:1.1rem;padding:15px 20px}.photo-frame{padding:10px}}.cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;width:100%;margin:20px 0}.download-card{background:#fff;border-radius:20px;padding:25px 20px;display:flex;flex-direction:column;align-items:center;gap:15px;box-shadow:0 5px 20px #00000014;transition:all .3s ease;cursor:pointer}.download-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #00000026}.card-icon{width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2d4b42,#1a2e29);border-radius:15px;color:#fff}.download-card h3{margin:0;font-size:1.1rem;color:#2d4b42;font-weight:700;text-align:center}.card-count{margin:0;font-size:.9rem;color:#5a8b7d;font-weight:500}.card-buttons{display:flex;gap:10px;width:100%}.card-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 15px;border:none;border-radius:12px;font-size:.9rem;font-weight:600;font-family:Poppins,sans-serif;cursor:pointer;transition:all .3s ease}.card-btn:disabled{opacity:.6;cursor:not-allowed}.card-btn-view{background:#f0f0f0;color:#2d4b42}.card-btn-view:hover:not(:disabled){background:#e0e0e0;transform:scale(1.05)}.card-btn-download{background:#2d4b42;color:#fff}.card-btn-download:hover:not(:disabled){background:#1a2e29;transform:scale(1.05)}.card-btn-download .spinner-small{animation:spin 1s linear infinite;color:#fff}.card-btn:disabled .spinner-small{display:inline-block}.preview-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.preview-modal-content{background:#fff;border-radius:20px;max-width:90vw;max-height:90vh;width:600px;display:flex;flex-direction:column;overflow:hidden}.preview-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 25px;border-bottom:1px solid #f0f0f0}.preview-modal-header h3{margin:0;font-size:1.3rem;color:#2d4b42;font-weight:700}.preview-close-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#f0f0f0;border:none;border-radius:50%;cursor:pointer;transition:all .3s ease;color:#2d4b42}.preview-close-btn:hover{background:#e0e0e0;transform:scale(1.1)}.preview-modal-body{padding:20px 25px;display:flex;align-items:flex-start;justify-content:center;background:#f5f5f5;min-height:300px;max-height:70vh;overflow-y:auto;overflow-x:hidden}.preview-modal-body img,.preview-modal-body video{max-width:100%;max-height:none;width:auto;height:auto;object-fit:contain;display:block;margin:0 auto}.preview-media{max-width:100%;border-radius:10px;box-shadow:0 5px 20px #0000001a}.preview-image,.preview-video{width:100%;height:auto;display:block;max-width:100%}.preview-individual-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px;width:100%}.preview-individual-photo{width:100%;height:auto;border-radius:10px;box-shadow:0 3px 10px #0000001a}.preview-modal-footer{padding:15px 25px;border-top:1px solid #f0f0f0;display:flex;justify-content:flex-end}.preview-modal-btn{padding:12px 30px;background:#2d4b42;color:#fff;border:none;border-radius:50px;font-size:1rem;font-weight:600;font-family:Poppins,sans-serif;cursor:pointer;transition:all .3s ease}.preview-modal-btn:hover{background:#1a2e29;transform:scale(1.05)}@media (max-width: 600px){.cards-grid{grid-template-columns:1fr;gap:15px}.download-card{padding:20px 15px}.card-icon{width:50px;height:50px}.download-card h3{font-size:1rem}.card-count{font-size:.85rem}.preview-modal-content{width:95vw}.preview-individual-grid{grid-template-columns:1fr}}.session-status-message{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#000;overflow-x:hidden;overflow-y:auto}#root{width:100vw;min-height:100vh;display:flex;align-items:center;justify-content:center}.screen{width:100vw;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;color:#fff;text-align:center}.screen.scrollable{height:auto;min-height:100vh;justify-content:flex-start;overflow-y:auto;padding:3rem 2rem}.screen h1{font-size:4rem;margin-bottom:1rem;text-shadow:2px 2px 8px rgba(0,0,0,.3)}.screen h2{font-size:2.5rem;margin-bottom:2rem;text-shadow:2px 2px 6px rgba(0,0,0,.2)}.screen p{font-size:1.5rem;margin-bottom:1rem;opacity:.9}button{background:#fff;color:#667eea;border:none;padding:1.5rem 4rem;font-size:1.8rem;font-weight:700;border-radius:50px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 20px #0003;margin:1rem}button:hover{transform:translateY(-4px);box-shadow:0 12px 30px #0000004d}button:active{transform:translateY(-2px)}button.secondary{background:transparent;color:#fff;border:3px solid white}button.secondary:hover{background:#ffffff1a}.qr-container{background:#fff;padding:2rem;border-radius:20px;box-shadow:0 10px 40px #0000004d;margin:2rem 0}.qr-container img{width:300px;height:300px;display:block}.countdown{font-size:15rem;font-weight:700;text-shadow:4px 4px 15px rgba(0,0,0,.5);animation:pulse 1s ease-in-out}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.camera-preview{width:80vw;max-width:1000px;height:60vh;background:#000;border-radius:20px;overflow:hidden;box-shadow:0 15px 50px #00000080;margin:2rem 0;position:relative}.camera-preview img{width:100%;height:100%;object-fit:contain}.progress-bar{width:60%;height:30px;background:#fff3;border-radius:15px;overflow:hidden;margin:2rem 0}.progress-fill{height:100%;background:#fff;transition:width .3s ease;border-radius:15px}.photo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;max-width:600px;margin:2rem 0}.photo-slot{width:280px;height:200px;background:#ffffff1a;border:3px dashed rgba(255,255,255,.3);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:3rem;position:relative}.photo-slot.captured{background:#fff3;border:3px solid rgba(255,255,255,.8)}.photo-slot.active{border-color:gold;animation:blink .5s ease-in-out infinite}@keyframes blink{0%,to{border-color:gold}50%{border-color:#ffd7004d}}.package-card{background:#fff;color:#667eea;padding:2rem;border-radius:20px;margin:1rem;min-width:300px;cursor:pointer;transition:all .3s ease;box-shadow:0 8px 20px #0003}.package-card:hover{transform:translateY(-8px);box-shadow:0 15px 40px #0000004d}.package-card.selected{border:4px solid #ffd700;background:#fff8dc}.package-card h3{font-size:2rem;margin-bottom:1rem}.package-card .price{font-size:1.8rem;font-weight:700;color:#764ba2}.tutorial-steps{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem;max-width:1000px;margin:2rem 0}.tutorial-step{background:#ffffff1a;padding:2rem;border-radius:15px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tutorial-step .number{font-size:3rem;font-weight:700;color:gold;margin-bottom:1rem}.tutorial-step h3{font-size:1.8rem;margin-bottom:.5rem}.tutorial-step p{font-size:1.2rem}.camera-animation{width:200px;height:200px;margin:2rem 0;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.loading-spinner{width:100px;height:100px;border:10px solid rgba(255,255,255,.3);border-top:10px solid white;border-radius:50%;animation:spin 1s linear infinite;margin:2rem 0}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{background:#f44;color:#fff;padding:1rem 2rem;border-radius:10px;margin:1rem 0;font-size:1.2rem}.success-message{background:#4f4;color:#333;padding:1rem 2rem;border-radius:10px;margin:1rem 0;font-size:1.2rem;font-weight:700}.bypass-input{padding:1rem 2rem;font-size:1.5rem;border:3px solid white;border-radius:10px;background:#ffffffe6;margin:1rem 0;text-align:center;width:300px}.timer{font-size:2rem;background:#0000004d;padding:1rem 2rem;border-radius:10px;margin:1rem 0;font-weight:700}.result-image{max-width:90%;max-height:60vh;border-radius:15px;box-shadow:0 15px 50px #0006;margin:2rem 0}.pulse-green{width:10px;height:10px;background-color:#10b981;border-radius:50%;box-shadow:0 0 #10b98166;animation:pulse-green 2s infinite}.pulse-red{width:10px;height:10px;background-color:#ef4444;border-radius:50%;animation:pulse-red 2s infinite}@keyframes pulse-green{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 10px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}@keyframes pulse-red{0%{transform:scale(.95);box-shadow:0 0 #ef4444b3}70%{transform:scale(1);box-shadow:0 0 0 10px #ef444400}to{transform:scale(.95);box-shadow:0 0 #ef444400}}@keyframes spinning{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinning{animation:spinning 2s linear infinite}
