@import"https://fonts.googleapis.com/css2?family=Caveat:wght@400;700&family=Quicksand:wght@300;400;500;600;700&display=swap";*{margin:0;padding:0;box-sizing:border-box}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#faf3f0,#f8e8f5,#e8f3f8);padding:20px;font-family:Quicksand,sans-serif;position:relative;overflow:hidden}.login-card{background:#fffffff2;border-radius:30px;padding:50px 40px;box-shadow:0 20px 60px #ffb6c14d;max-width:420px;width:100%;position:relative;animation:fadeInUp .6s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:2px solid rgba(255,255,255,.8)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:35px}.login-title{font-family:Caveat,cursive;font-size:42px;font-weight:700;color:#d88c9a;margin-bottom:8px;animation:bounce .8s ease-in-out}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.login-subtitle{font-size:16px;color:#b8a0c4;font-weight:400;opacity:0;animation:fadeIn .8s ease-out .3s forwards}@keyframes fadeIn{to{opacity:1}}.login-form{display:flex;flex-direction:column;gap:25px}.input-group{display:flex;flex-direction:column;gap:10px}.input-label{font-size:14px;font-weight:600;color:#9d7e97;letter-spacing:.5px}.label-with-hint{display:flex;align-items:center;gap:8px}.hint-trigger{font-size:11px;color:#c9b3c9;cursor:help;padding:2px 6px;background:#d88c9a1a;border-radius:8px;transition:all .2s ease;position:relative}.hint-trigger:hover{background:#d88c9a40;color:#d88c9a}.hint-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);background:#d88c9a;color:#fff;padding:8px 12px;border-radius:10px;font-size:12px;font-weight:500;white-space:nowrap;opacity:0;visibility:hidden;transition:all .2s ease;box-shadow:0 4px 15px #d88c9a4d;z-index:10}.hint-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#d88c9a}.hint-trigger:hover .hint-tooltip{opacity:1;visibility:visible}.input-field{padding:15px 20px;border:2px solid #f5e6f0;border-radius:15px;font-size:15px;font-family:Quicksand,sans-serif;background:#fef9fc;color:#7d6c80;transition:all .3s ease;outline:none}.input-field::placeholder{color:#d5b8ce;font-style:italic}.input-field:focus{border-color:#e6a4c3;background:#fff;transform:translateY(-2px);box-shadow:0 8px 20px #e6a4c333}.error-message{background:#ffe4f0;color:#c76b8a;padding:15px 20px;border-radius:15px;font-size:14px;text-align:center;border:2px solid #ffcce0;font-weight:500}.error-potacho{width:100px;height:100px;object-fit:cover;border-radius:10px;margin-top:10px;border:2px solid #ffcce0}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-message.shake{animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.submit-button{margin-top:10px;padding:16px;background:linear-gradient(135deg,#e6a4c3,#d88c9a);color:#fff;border:none;border-radius:15px;font-size:17px;font-weight:600;font-family:Quicksand,sans-serif;cursor:pointer;transition:all .3s ease;box-shadow:0 6px 20px #d88c9a4d;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;gap:8px}.submit-button:hover{transform:translateY(-3px);box-shadow:0 10px 30px #d88c9a66}.submit-button:active{transform:translateY(-1px)}.button-sparkle{animation:sparkle 1.5s ease-in-out infinite}@keyframes sparkle{0%,to{transform:scale(1) rotate(0);opacity:1}50%{transform:scale(1.3) rotate(180deg);opacity:.8}}.login-footer{margin-top:25px;text-align:center}.footer-link{color:#b8a0c4;text-decoration:none;font-size:14px;transition:color .3s ease;font-weight:500}.footer-link:hover{color:#d88c9a}.floating-hearts{position:absolute;width:100%;height:100%;top:0;left:0;pointer-events:none;overflow:hidden}.heart{position:absolute;font-size:24px;opacity:.3;animation:float 8s ease-in-out infinite;top:100vh}.heart:nth-child(odd){font-size:28px}.heart:nth-child(2n){font-size:20px}.heart:nth-child(1){left:10%;animation-delay:0s;animation-duration:7s}.heart:nth-child(2){left:30%;animation-delay:2s;animation-duration:9s}.heart:nth-child(3){left:70%;animation-delay:4s;animation-duration:8s}.heart:nth-child(4){left:90%;animation-delay:1s;animation-duration:10s}.heart:nth-child(5){left:20%;animation-delay:3s;animation-duration:8s}.heart:nth-child(6){left:50%;animation-delay:5s;animation-duration:9s}.heart:nth-child(7){left:80%;animation-delay:1.5s;animation-duration:7.5s}.heart:nth-child(8){left:40%;animation-delay:6s;animation-duration:10s}.heart:nth-child(9){left:15%;animation-delay:4.5s;animation-duration:8.5s}.heart:nth-child(10){left:60%;animation-delay:2.5s;animation-duration:9.5s}.heart:nth-child(11){left:85%;animation-delay:3.5s;animation-duration:7s}.heart:nth-child(12){left:25%;animation-delay:5.5s;animation-duration:8s}.heart:nth-child(13){left:5%;animation-delay:1.2s;animation-duration:9s}.heart:nth-child(14){left:35%;animation-delay:3.8s;animation-duration:7.5s}.heart:nth-child(15){left:55%;animation-delay:6.5s;animation-duration:8.5s}.heart:nth-child(16){left:75%;animation-delay:2.2s;animation-duration:9.5s}.heart:nth-child(17){left:95%;animation-delay:4.8s;animation-duration:7s}.heart:nth-child(18){left:45%;animation-delay:.5s;animation-duration:8.8s}.heart:nth-child(19){left:65%;animation-delay:5.2s;animation-duration:10s}.heart:nth-child(20){left:12%;animation-delay:3.2s;animation-duration:7.8s}@keyframes float{0%{transform:translateY(0) rotate(0);opacity:0}10%{opacity:.3}90%{opacity:.3}to{transform:translateY(-110vh) rotate(360deg);opacity:0}}@media(max-width:480px){.login-card{padding:40px 30px}.login-title{font-size:36px}.input-field{padding:13px 18px}}.login-footer{position:absolute;bottom:20px;left:0;right:0;text-align:center;font-size:13px;font-family:Quicksand,sans-serif;color:#b8a0c4;font-weight:400;opacity:.8;z-index:10}@media(max-width:600px){.login-footer{font-size:11px;bottom:15px}}.dashboard-container{min-height:100vh;background:#fdfbf7;padding:40px 20px;font-family:Quicksand,sans-serif;display:flex;flex-direction:column;align-items:center;position:relative}.logout-button{position:absolute;top:20px;left:20px;width:50px;height:50px;padding:0;background:#fff;border:2px solid #e6a4c3;border-radius:50%;color:#d88c9a;font-size:24px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 10px #0000000d;z-index:100;display:flex;align-items:center;justify-content:center}.logout-button:hover{background:#fef9fc;border-color:#d88c9a;transform:scale(1.1);box-shadow:0 4px 15px #d88c9a33}.dashboard-title{font-family:Caveat,cursive;font-size:52px;color:#d88c9a;margin-bottom:20px}.photobooth-screen{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;max-width:600px}.camera-container{position:relative;width:100%;aspect-ratio:1;background:#000;border-radius:20px;overflow:hidden;box-shadow:0 10px 40px #00000014;border:4px solid #fff}.video-feed{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.countdown-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out;z-index:10}.countdown-number{font-size:120px;font-weight:700;color:#fff;font-family:Caveat,cursive;text-shadow:0 4px 10px rgba(0,0,0,.5);animation:scaleIn .3s ease-out}.flash-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#fff;z-index:20;animation:flash .1s ease-out;pointer-events:none}.camera-permission-error{width:100%;max-width:600px;aspect-ratio:1;background:#fff;border-radius:20px;padding:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 10px 40px #00000014;border:4px solid #fff}.error-icon{font-size:80px;margin-bottom:20px;opacity:.3}.error-title{font-family:Caveat,cursive;font-size:32px;color:#d88c9a;margin-bottom:15px}.error-message{font-size:16px;color:#666;margin-bottom:25px;line-height:1.6;max-width:400px}.retry-button{padding:15px 40px;background:linear-gradient(135deg,#e6a4c3,#d88c9a);color:#fff;border:none;border-radius:20px;font-size:16px;font-weight:600;font-family:Quicksand,sans-serif;cursor:pointer;transition:all .3s ease;box-shadow:0 6px 20px #d88c9a4d}.retry-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #d88c9a66}.error-hint{font-size:13px;color:#999;margin-top:20px;font-style:italic}.camera-loading{width:100%;max-width:600px;aspect-ratio:1;background:#fff;border-radius:20px;padding:40px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:0 10px 40px #00000014;border:4px solid #fff}.loading-spinner{width:60px;height:60px;border:4px solid #f3f3f3;border-top:4px solid #d88c9a;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-text{font-size:16px;color:#9d7e97;font-weight:600}.controls-area{width:100%;display:flex;flex-direction:column;align-items:center;gap:20px}.filter-buttons{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;background:#fff;padding:12px;border-radius:25px;box-shadow:0 4px 15px #d88c9a26;max-width:480px}.filter-buttons button{padding:8px 16px;border:none;border-radius:20px;background:transparent;color:#9d7e97;font-family:Quicksand,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;flex:0 0 auto;min-width:85px}.filter-buttons button:hover{color:#d88c9a}.filter-buttons button.active{background:#e6a4c3;color:#fff;box-shadow:0 2px 10px #e6a4c366}.filter-buttons button:disabled{opacity:.5;cursor:not-allowed}.countdown-selector{display:flex;align-items:center;gap:12px;background:#fff;padding:8px 16px;border-radius:20px;box-shadow:0 2px 10px #d88c9a26}.countdown-label{font-size:14px;font-weight:600;color:#9d7e97;margin:0}.countdown-buttons{display:flex;gap:8px}.countdown-btn{padding:6px 14px;border:2px solid #e6a4c3;border-radius:12px;background:#fff;color:#9d7e97;font-family:Quicksand,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:40px}.countdown-btn.active{background:linear-gradient(135deg,#e6a4c3,#d88c9a);color:#fff;border-color:#d88c9a}.countdown-btn:disabled{opacity:.5;cursor:not-allowed}.photo-progress{background:#ffffffe6;padding:8px 20px;border-radius:20px;font-weight:600;color:#9d7e97;font-size:14px;box-shadow:0 2px 10px #d88c9a26}.capture-button{width:100%;padding:18px;background:linear-gradient(135deg,#e6a4c3,#d88c9a);color:#fff;border:none;border-radius:20px;font-size:18px;font-weight:600;font-family:Quicksand,sans-serif;cursor:pointer;margin-top:10px;transition:all .3s ease;box-shadow:0 6px 20px #d88c9a4d}.capture-button:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 30px #d88c9a66}.capture-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.filter-normal{-webkit-filter:none;filter:none}.filter-vintage{-webkit-filter:sepia(.4) contrast(1.1) brightness(.9) saturate(.8);filter:sepia(.4) contrast(1.1) brightness(.9) saturate(.8)}.filter-bw{-webkit-filter:grayscale(1) contrast(1.1);filter:grayscale(1) contrast(1.1)}.filter-soft{filter:brightness(1.1) contrast(.9) saturate(.95) blur(.3px)}.filter-romantic{filter:sepia(.15) saturate(1.2) brightness(1.1) contrast(.95) hue-rotate(-5deg)}.filter-film{-webkit-filter:contrast(1.15) brightness(.95) saturate(.85) sepia(.1);filter:contrast(1.15) brightness(.95) saturate(.85) sepia(.1)}.filter-golden{filter:sepia(.3) saturate(1.4) brightness(1.1) contrast(1.05) hue-rotate(-10deg)}.strip-screen{display:flex;flex-direction:column;align-items:center;gap:20px;width:100%;animation:fadeIn .6s ease-out}.strip-title{font-family:Caveat,cursive;font-size:36px;font-weight:700;color:#d88c9a;text-align:center;margin-bottom:10px;width:100%}@media(min-width:1024px){.strip-screen{flex-direction:row;align-items:flex-start;flex-wrap:wrap;max-width:1200px;justify-content:center;gap:40px}.strip-title{flex-basis:100%}.flip-card-container{flex-shrink:0}.customization-controls{flex:1;max-width:500px;min-width:400px}}.customization-controls{display:flex;flex-direction:column;align-items:center;gap:30px;width:100%}.strip-preview-container{display:flex;justify-content:center;margin-bottom:10px}.add-notes-toggle-container{margin-bottom:20px}.add-notes-toggle-container .toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;justify-content:center}.flip-card-container{perspective:1000px;margin-bottom:20px;position:relative}.flip-toggle-button{position:absolute;top:-15px;right:-15px;width:46px;height:46px;background:#fff;border:3px solid #d88c9a;border-radius:50%;font-size:20px;cursor:pointer;z-index:100;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #d88c9a4d;transition:all .3s ease}.flip-toggle-button:hover{transform:rotate(180deg) scale(1.1);background:linear-gradient(135deg,#e6a4c3,#d88c9a);box-shadow:0 6px 20px #d88c9a80}.flip-card{position:relative;width:320px;aspect-ratio:1 / 3.6;transition:transform .8s;transform-style:preserve-3d}.flip-card-container.flipped .flip-card{transform:rotateY(180deg)}.flip-card-front,.flip-card-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;-webkit-backface-visibility:hidden}.flip-card-front{z-index:2}.flip-card-back{transform:rotateY(180deg)}.photo-strip{position:relative;padding:30px;display:flex;flex-direction:column;gap:25px;box-shadow:0 20px 50px #0000001a;transition:background-color .3s ease;max-width:320px;border:none}.strip-photo{width:260px;height:260px;background:transparent}.strip-photo img{width:100%;height:100%;object-fit:cover;display:block}.color-picker{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:20px}.color-picker p{color:#9d7e97;font-weight:600}.color-picker.disabled{opacity:.5;pointer-events:none}.color-picker.disabled p{color:#bbb}.colors-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;max-width:400px}.color-dot{width:40px;height:40px;border-radius:50%;border:2px solid white;box-shadow:0 4px 10px #0000001a;cursor:pointer;transition:transform .2s}.color-dot:hover{transform:scale(1.1)}.color-dot.selected{transform:scale(1.2);border:3px solid #d88c9a;box-shadow:0 4px 15px #d88c9a4d}.color-dot[style*="#ffffff"]{border:1px solid #eee}.color-dot:disabled{cursor:not-allowed;opacity:.5}.pattern-picker{display:flex;flex-direction:column;align-items:center;gap:10px;margin-top:20px}.pattern-picker p{color:#9d7e97;font-weight:600}.pattern-loading-hint{font-size:12px!important;color:#bbb!important;font-style:italic;margin:0}.patterns-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;max-width:400px}.pattern-dot{width:50px;height:50px;border-radius:8px;border:2px solid white;box-shadow:0 4px 10px #0000001a;cursor:pointer;transition:transform .2s;overflow:hidden}.pattern-dot:hover{transform:scale(1.1)}.pattern-dot.selected{transform:scale(1.2);border:3px solid #d88c9a;box-shadow:0 4px 15px #d88c9a4d}.pattern-dot.loading{opacity:.4;position:relative;cursor:wait}.pattern-dot.loading:after{content:"⟳";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:20px;color:#d88c9a;animation:spin 1s linear infinite}.text-customization{display:flex;flex-direction:column;align-items:center;gap:20px;margin-top:25px;width:100%;max-width:400px}.toggle-section{width:100%}.toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;justify-content:center}.toggle-checkbox{width:20px;height:20px;cursor:pointer;accent-color:#d88c9a}.toggle-text{color:#9d7e97;font-weight:600;font-size:15px}.location-section{width:100%}.location-label{display:flex;flex-direction:column;gap:8px;width:100%}.location-label-text{color:#9d7e97;font-weight:600;font-size:14px;text-align:center}.location-input{width:100%;padding:12px 16px;border:2px solid #e6a4c3;border-radius:12px;font-family:Quicksand,sans-serif;font-size:14px;color:#4a4a4a;text-align:center;transition:all .3s ease;background:#fff}.location-input:focus{outline:none;border-color:#d88c9a;box-shadow:0 0 0 3px #d88c9a1a}.location-input::placeholder{color:#bbb;font-style:italic}.alignment-section{width:100%;display:flex;flex-direction:column;align-items:center;gap:10px}.alignment-label{color:#9d7e97;font-weight:600;font-size:14px;margin:0}.alignment-buttons{display:flex;gap:10px}.alignment-btn{padding:10px 24px;border:2px solid #e6a4c3;border-radius:12px;background:#fff;color:#9d7e97;font-family:Quicksand,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease}.alignment-btn:hover{background:#fef9fc;border-color:#d88c9a}.alignment-btn.active{background:linear-gradient(135deg,#e6a4c3,#d88c9a);color:#fff;border-color:#d88c9a}.strip-footer{display:flex;flex-direction:column;gap:12px;margin-top:10px}.strip-footer.text-right{align-items:flex-end;padding-right:5px}.strip-footer.text-center{align-items:center}.strip-location,.strip-date{font-family:Georgia,serif;font-style:italic;font-size:14px;letter-spacing:.5px;margin:0}.strip-notes-back{padding:30px;display:flex;flex-direction:column;gap:20px;box-shadow:0 20px 50px #0000001a;max-width:320px;width:320px;min-height:100%;background:#fff9f5;border-radius:8px}.notes-header{text-align:center;border-bottom:2px solid #f0e8e0;padding-bottom:15px}.notes-title{font-family:Caveat,cursive;font-size:28px;color:#d88c9a;margin:0 0 5px}.notes-subtitle{font-size:20px;color:#999;font-style:italic;margin:0}.notes-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:80px;flex:1;width:100%}.note-item{display:flex;flex-direction:column;gap:100px;position:relative;width:100%;max-width:240px}.textarea-with-quotes{position:relative;width:100%}.quote-mark{position:absolute;font-family:Georgia,serif;font-size:40px;color:#d88c9a;opacity:.6;line-height:1;pointer-events:none}.quote-left{top:-5px;left:0}.quote-right{top:-5px;right:0}.remove-highlight-btn{position:absolute;top:-30px;right:-15px;background:#fff;border:2px solid #d88c9a;color:#d88c9a;font-size:18px;cursor:pointer;padding:0;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease;line-height:1;box-shadow:0 2px 8px #0000001a}.remove-highlight-btn:hover{background:#d88c9a;color:#fff;transform:scale(1.05)}.note-textarea{width:100%;padding:10px 12px;border:none;border-bottom:2px solid #e6a4c3;background:transparent;font-family:Quicksand,sans-serif;font-size:16px;font-weight:600;color:#666;resize:none;overflow:hidden;min-height:35px;transition:border-color .3s ease;line-height:1.4;text-align:center}.note-textarea:focus{outline:none;border-bottom-color:#d88c9a}.note-textarea::placeholder{color:#bbb;font-style:italic}.add-highlight-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;background:#fff;border:2px dashed #e6a4c3;border-radius:12px;color:#9d7e97;font-family:Quicksand,sans-serif;font-size:13px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.add-highlight-btn:hover{background:#fef9fc;border-color:#d88c9a;color:#d88c9a}.add-icon{font-size:18px;font-weight:700}.notes-footer{display:flex;flex-direction:column;align-items:center;gap:5px;margin-top:auto;padding-top:15px;border-top:2px solid #f0e8e0}.notes-location,.notes-date{font-family:Georgia,serif;font-style:italic;font-size:13px;color:#666;margin:0;text-align:center}.strip-actions{display:flex;gap:15px;margin-top:20px;flex-wrap:wrap;justify-content:center}.download-button,.retake-button{padding:15px 30px;border-radius:12px;border:none;font-weight:600;font-family:Quicksand,sans-serif;font-size:16px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0000001a}.download-button{background:linear-gradient(135deg,#e6a4c3,#d88c9a);color:#fff;display:flex;align-items:center;justify-content:center;gap:8px}.download-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #d88c9a66}.download-button:disabled,.retake-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.loading-spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.retake-button{background:#fff;color:#d88c9a;border:2px solid #e6a4c3}.retake-button:hover:not(:disabled){transform:translateY(-2px);background:#fef9fc;box-shadow:0 6px 20px #d88c9a33}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.5)}to{transform:scale(1)}}@keyframes flash{0%{opacity:0}50%{opacity:1}to{opacity:0}}
