.container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;background:#fff;position:relative}.home-cart-icon-button{position:fixed;top:30px;right:30px;background:transparent;border:none;cursor:pointer;padding:12px;display:flex;align-items:center;justify-content:center;z-index:100;transition:transform .2s ease;color:#000}.home-cart-icon-button:hover{transform:scale(1.1)}.home-cart-icon-button svg{width:28px;height:28px}.home-cart-badge{position:absolute;top:-4px;right:-4px;background:red;color:#fff;border-radius:12px;min-width:22px;height:22px;padding:0 6px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;border:2px solid #ffffff}.content{width:100%;max-width:600px;padding:40px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(224,224,224,.5);box-shadow:0 8px 32px #00000026;flex:1;display:flex;flex-direction:column;justify-content:center}.face-selection-content{max-width:900px}.event-title{font-size:1.5rem;font-weight:300;letter-spacing:.05em;text-transform:uppercase;margin-bottom:30px;color:#000;text-align:center;padding-bottom:20px;border-bottom:1px solid #e0e0e0}.title{font-size:2.5rem;font-weight:300;letter-spacing:-.02em;margin-bottom:12px;color:#000;text-align:center}.subtitle{font-size:1rem;color:#666;text-align:center;margin-bottom:32px;line-height:1.5}.loading,.no-data{text-align:center;padding:60px 20px;font-size:1.1rem;color:#666}.faces-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:20px;margin-bottom:32px;padding:20px 0;min-width:0}.face-circle{position:relative;width:120px;height:120px;border-radius:50%;overflow:hidden;border:3px solid #e0e0e0;transition:all .4s cubic-bezier(.34,1.56,.64,1);margin:0 auto;opacity:1;transform:scale(1);background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;animation:skeletonPulse 1.5s ease-in-out infinite}.face-circle.loaded{animation:revealFace .5s ease forwards;background:#fff}@keyframes revealFace{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.face-circle:hover{transform:scale(1);border-color:#e0e0e0;box-shadow:none}.face-circle.loaded:hover{transform:scale(1.15);border-color:#000;box-shadow:0 8px 24px #00000040,0 0 0 4px #0000001a}.face-circle.loaded:hover img{filter:brightness(1.1) contrast(1.05)}.face-circle.selected{border-color:#000;border-width:4px;box-shadow:0 4px 16px #0003}.face-circle img{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .5s ease,filter .3s ease}.face-circle.loaded img{opacity:1}.face-circle:not(.loaded):before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);animation:shimmer 1.5s infinite;z-index:1}.face-circle.loaded:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle,transparent 40%,rgba(0,0,0,.6) 100%);opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:2}.face-circle.loaded:hover:after{opacity:1}.face-circle.skeleton{cursor:default;background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;animation:skeletonPulse 1.5s ease-in-out infinite;pointer-events:none;border-color:#e0e0e0;opacity:1;transform:scale(1)}@keyframes skeletonPulse{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-shimmer{width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.face-checkmark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;background:#000c;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:300;animation:checkmarkPop .3s ease}@keyframes checkmarkPop{0%{transform:translate(-50%,-50%) scale(0)}50%{transform:translate(-50%,-50%) scale(1.2)}to{transform:translate(-50%,-50%) scale(1)}}.upload-area{border:2px dashed #cccccc;padding:60px 20px;text-align:center;cursor:pointer;transition:all .3s ease;margin-bottom:24px;background:#fafafa}.upload-area:hover{border-color:#000;background:#f5f5f5}.upload-area.dragging{border-color:#000;background:#f0f0f0}.upload-area.has-image{padding:20px;cursor:default;background:#fff}.upload-area.has-image:hover{background:#fff}.upload-label{cursor:pointer;display:block}.upload-icon{color:#000;margin-bottom:20px;display:flex;justify-content:center}.upload-text{font-size:1.1rem;color:#000;margin-bottom:8px;font-weight:400}.upload-hint{font-size:.9rem;color:#999}.file-input{display:none}.preview-container{position:relative;display:flex;flex-direction:column;align-items:center;gap:12px;width:100%}.preview-image{max-width:100%;max-height:200px;object-fit:contain;border:1px solid #e0e0e0}.remove-button{position:absolute;top:8px;right:8px;padding:8px 16px;background:#fffffff2;color:#000;border:1px solid #000000;font-size:.85rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em;box-shadow:0 2px 8px #00000026}.remove-button:hover{background:#000;color:#fff}.form{display:flex;flex-direction:column;gap:20px}.input-group{display:flex;flex-direction:column;gap:8px}.label{font-size:.95rem;color:#000;font-weight:400;letter-spacing:.02em}.email-input{padding:14px 16px;font-size:1rem;border:1px solid #cccccc;background:#fff;color:#000;transition:all .2s ease;font-family:inherit}.email-input:focus{outline:none;border-color:#000}.email-input::placeholder{color:#999}.submit-button{padding:16px 32px;background:#000;color:#fff;border:none;font-size:1rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em}.submit-button:hover{background:#333}.submit-button:active{transform:translateY(1px)}.success-container{text-align:center;padding:60px 40px;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(224,224,224,.5);box-shadow:0 8px 32px #00000026}.success-icon{width:80px;height:80px;border-radius:50%;background:#000;color:#fff;font-size:3rem;display:flex;align-items:center;justify-content:center;margin:0 auto 30px;font-weight:300}.success-message{color:#666;font-size:1.1rem;line-height:1.6;margin-bottom:0;max-width:400px;margin-left:auto;margin-right:auto}.reset-button{padding:14px 32px;background:#fff;color:#000;border:1px solid #000000;font-size:1rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em}.reset-button:hover{background:#000;color:#fff}@media (max-width: 768px){.container{padding:16px}.home-cart-icon-button{top:16px;right:16px}.home-cart-icon-button svg{width:22px;height:22px}.content{padding:28px 24px}.faces-grid{grid-template-columns:repeat(auto-fill,minmax(95px,1fr));gap:14px}.face-circle{width:95px;height:95px}.face-checkmark{width:35px;height:35px;font-size:1.3rem}.event-title{font-size:1.2rem;margin-bottom:20px;padding-bottom:14px}.title{font-size:2rem}.subtitle{font-size:.95rem;margin-bottom:24px}.upload-area{padding:40px 16px;margin-bottom:20px}.preview-image{max-height:180px}.success-container{padding:48px 24px}.success-icon{width:64px;height:64px;font-size:2.5rem}.success-message{font-size:1rem}}@media (max-width: 480px){.home-cart-icon-button{top:12px;right:12px}.home-cart-icon-button svg{width:20px;height:20px}.content{padding:20px 16px}.faces-grid{grid-template-columns:repeat(auto-fill,minmax(75px,1fr));gap:10px}.face-circle{width:75px;height:75px}.face-checkmark{width:30px;height:30px;font-size:1.1rem}.event-title{font-size:1rem;margin-bottom:16px;padding-bottom:12px}.title{font-size:1.75rem}.subtitle{font-size:.9rem;margin-bottom:20px}.upload-area{padding:32px 12px;margin-bottom:16px}.upload-text{font-size:1rem}.upload-hint{font-size:.85rem}.preview-image{max-height:150px}.form{gap:16px}.submit-button,.reset-button{padding:14px 24px;font-size:.95rem}.success-container{padding:40px 20px}}.store-container{min-height:100vh;background:#fff;padding:20px;position:relative;animation:fadeInPage .4s ease}.store-container .back-button{position:fixed;top:20px;left:20px;display:flex;align-items:center;gap:8px;padding:10px 20px;background:#fff;color:#000;border:1px solid #000000;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em;z-index:100;box-shadow:0 2px 8px #00000026}.store-container .back-button:hover{background:#000;color:#fff}.store-container .back-button svg{transition:transform .2s ease}.store-container .back-button:hover svg{transform:translate(-3px)}@keyframes fadeInPage{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.cart-icon-button{position:fixed;top:20px;right:20px;width:auto;height:auto;background:transparent;color:#000;border:none;cursor:pointer;transition:all .2s ease;z-index:100;display:flex;align-items:center;justify-content:center;padding:8px}.cart-icon-button:hover{transform:scale(1.1)}.cart-icon-button.vibrate{animation:cartVibrate .25s ease}@keyframes cartVibrate{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-3px)}20%,40%,60%,80%{transform:translate(3px)}}.cart-badge{position:absolute;top:-4px;right:-4px;background:red;color:#fff;border-radius:12px;min-width:24px;height:24px;padding:0 6px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;border:2px solid #ffffff}.back-button{position:fixed;top:20px;left:20px;display:flex;align-items:center;gap:8px;padding:10px 20px;background:#fff;color:#000;border:1px solid #000000;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em;z-index:100;box-shadow:0 2px 8px #00000026}.back-button:hover{background:#000;color:#fff}.back-button svg{transition:transform .2s ease}.back-button:hover svg{transform:translate(-3px)}.store-content{max-width:1400px;margin:0 auto;padding-top:80px}.store-container .loading,.store-container .no-data{text-align:center;padding:80px 20px;font-size:1.1rem;color:#666}.store-title{font-size:3rem;font-weight:300;letter-spacing:-.02em;margin-bottom:12px;color:#000;text-align:center}.store-subtitle{font-size:1.1rem;color:#666;text-align:center;margin-bottom:50px}.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;padding:20px 0}.gallery-item{position:relative;overflow:hidden;background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;border:1px solid #e0e0e0;box-shadow:0 4px 12px #0000001a;transition:all .3s ease;aspect-ratio:1;opacity:1;transform:scale(1);animation:skeletonPulseGallery 1.5s ease-in-out infinite}.gallery-item.loaded{animation:revealGalleryItem .5s ease forwards;background:#fff}@keyframes revealGalleryItem{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.gallery-item:hover{transform:translateY(0);box-shadow:0 4px 12px #0000001a}.gallery-item.loaded:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 8px 20px #0003}.gallery-item img{width:100%;height:100%;object-fit:cover;display:block;opacity:0;transition:opacity .5s ease}.gallery-item.loaded img{opacity:1}.gallery-item:not(.loaded):before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);animation:shimmerGallery 1.5s infinite;z-index:1}.gallery-item.skeleton{cursor:default;background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;animation:skeletonPulseGallery 1.5s ease-in-out infinite;pointer-events:none;opacity:1;transform:scale(1)}@keyframes skeletonPulseGallery{0%{background-position:200% 0}to{background-position:-200% 0}}.gallery-item.skeleton .skeleton-shimmer{width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);animation:shimmerGallery 1.5s infinite}@keyframes shimmerGallery{0%{transform:translate(-100%)}to{transform:translate(100%)}}.gallery-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease;z-index:2}.gallery-item.loaded:hover .gallery-overlay{opacity:1}.gallery-overlay span{color:#fff;font-size:1.2rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase}@media (max-width: 768px){.store-container{padding:16px}.store-container .back-button{top:16px;left:16px;padding:8px 16px;font-size:.9rem}.cart-icon-button{top:16px;right:16px}.cart-icon-button svg{width:22px;height:22px}.cart-badge{min-width:22px;height:22px;font-size:.7rem}.back-button{top:16px;left:16px;padding:8px 16px;font-size:.9rem}.store-content{padding-top:70px}.store-title{font-size:2.2rem}.store-subtitle{font-size:1rem;margin-bottom:30px}.gallery{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px}}@media (max-width: 480px){.store-container{padding:12px}.store-container .back-button{top:12px;left:12px;padding:8px 14px;font-size:.85rem}.cart-icon-button{top:12px;right:12px}.cart-icon-button svg{width:20px;height:20px}.cart-badge{min-width:20px;height:20px;font-size:.65rem}.back-button{top:12px;left:12px;padding:8px 14px;font-size:.85rem}.store-content{padding-top:60px}.store-title{font-size:1.8rem}.store-subtitle{font-size:.9rem;margin-bottom:24px}.gallery{grid-template-columns:1fr;gap:12px}}.detail-container{min-height:100vh;background:#fff;padding:20px;position:relative}.detail-container .cart-icon-button{position:fixed;top:20px;right:20px;width:auto;height:auto;background:transparent;color:#000;border:none;cursor:pointer;transition:all .2s ease;z-index:100;display:flex;align-items:center;justify-content:center;padding:8px}.detail-container .cart-icon-button:hover{transform:scale(1.1)}.detail-container .cart-badge{position:absolute;top:-4px;right:-4px;background:red;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;border:2px solid #ffffff}.detail-content{max-width:1400px;margin:0 auto;padding-top:80px}.image-section{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(224,224,224,.5);box-shadow:0 8px 32px #00000026;padding:40px;margin-bottom:40px;text-align:center;transition:all .4s ease}.image-section.collapsed{padding:30px 40px}.image-wrapper{max-width:800px;margin:0 auto 30px;position:relative;min-height:300px;display:flex;align-items:center;justify-content:center}.image-wrapper img{max-width:100%;max-height:600px;object-fit:contain;border:1px solid #e0e0e0;transition:opacity .5s ease}.image-skeleton{position:absolute;top:0;left:50%;transform:translate(-50%);width:100%;max-width:800px;height:300px;background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;animation:skeletonPulseDetail 1.5s ease-in-out infinite;border:1px solid #e0e0e0}@keyframes skeletonPulseDetail{0%{background-position:200% 0}to{background-position:-200% 0}}.image-skeleton .skeleton-shimmer{width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);animation:shimmerDetail 1.5s infinite}@keyframes shimmerDetail{0%{transform:translate(-100%)}to{transform:translate(100%)}}.image-wrapper.loaded .image-skeleton{display:none}.product-card.loading{pointer-events:none}.product-image.skeleton{position:relative;background:#f0f0f0;aspect-ratio:1;overflow:hidden}.product-image.skeleton .skeleton-shimmer{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.6) 50%,transparent 100%);animation:shimmer 1.5s infinite}.skeleton-text{height:16px;background:#f0f0f0;border-radius:4px;margin:8px 0;position:relative;overflow:hidden}.skeleton-text.short{width:60%;height:14px}.skeleton-text:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.6) 50%,transparent 100%);animation:shimmer 1.5s infinite}.product-image.frame-preview-container{position:relative;width:100%;aspect-ratio:1 / 1!important;background:#fff;overflow:visible!important}.frame-preview-container .user-photo-preview{position:absolute!important;object-fit:cover!important;z-index:2}.frame-preview-container .frame-image-base{position:absolute!important;top:0!important;left:0!important;right:0!important;bottom:0!important;width:100%!important;height:100%!important;object-fit:contain!important;display:block;z-index:1;pointer-events:none}.frame-preview-container .product-colors{position:absolute;bottom:8px;left:50%;transform:translate(-50%);display:flex;gap:6px;z-index:3}.download-button{display:inline-flex;align-items:center;gap:10px;padding:14px 32px;background:#000;color:#fff;border:none;font-size:1rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em}.download-button:hover{background:#333}.download-button:disabled{opacity:.7;cursor:not-allowed}.download-button:disabled:hover{background:#000}.dots:after{content:"";animation:dots 1.5s steps(4,end) infinite}@keyframes dots{0%,20%{content:""}40%{content:"."}60%{content:".."}80%,to{content:"..."}}.download-success{text-align:center;padding:20px 0;animation:fadeInSuccess .5s ease}@keyframes fadeInSuccess{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.success-icon{margin:0 auto 16px;width:64px;height:64px;background:#4caf50;border-radius:50%;display:flex;align-items:center;justify-content:center;animation:scaleIn .4s cubic-bezier(.175,.885,.32,1.275)}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.success-icon svg{color:#fff}.success-title{font-size:1.5rem;font-weight:500;color:#000;margin:0 0 8px;letter-spacing:-.01em}.success-subtitle{font-size:1rem;color:#666;margin:0}.products-section{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(224,224,224,.5);box-shadow:0 8px 32px #00000026;padding:40px}.products-title{font-size:2rem;font-weight:300;letter-spacing:-.02em;margin-bottom:8px;color:#000;text-align:center}.products-subtitle{font-size:1rem;color:#666;text-align:center;margin-bottom:40px}.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}.product-card{background:#fff;border:1px solid #e0e0e0;cursor:pointer;transition:all .3s ease;overflow:hidden}.product-card:hover{transform:translateY(-5px);box-shadow:0 8px 20px #00000026}.product-image{width:100%;aspect-ratio:3/4;overflow:hidden;background:#f5f5f5;position:relative}.product-image img{width:100%;height:100%;object-fit:cover}.product-colors{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;gap:8px;background:#ffffffe6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:8px 12px;border-radius:20px;box-shadow:0 2px 8px #00000026}.product-color-circle{width:20px;height:20px;border-radius:50%;display:inline-block;cursor:pointer;transition:transform .2s ease;box-shadow:0 1px 3px #0003}.product-color-circle:hover{transform:scale(1.15)}.product-info{padding:20px;text-align:center}.product-name{font-size:1.1rem;font-weight:400;margin-bottom:8px;color:#000}.product-price{font-size:1.3rem;font-weight:300;color:#000;margin-bottom:16px}.product-button{width:100%;padding:12px;background:#fff;color:#000;border:1px solid #000000;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em}.product-card:hover .product-button{background:#000;color:#fff}@media (max-width: 768px){.detail-container .cart-icon-button{top:16px;right:16px}.detail-container .cart-icon-button svg{width:22px;height:22px}.detail-container .cart-badge{width:22px;height:22px;font-size:.7rem}.detail-content{padding-top:70px}.image-section{padding:24px;margin-bottom:24px}.image-wrapper img{max-height:400px}.download-button{padding:12px 24px;font-size:.95rem}.products-section{padding:24px}.products-title{font-size:1.8rem}.products-subtitle{margin-bottom:30px}.products-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px}}@media (max-width: 480px){.detail-container .cart-icon-button{top:12px;right:12px}.detail-container .cart-icon-button svg{width:20px;height:20px}.detail-container .cart-badge{width:20px;height:20px;font-size:.65rem}.detail-content{padding-top:60px}.image-section{padding:20px;margin-bottom:20px}.image-wrapper{margin-bottom:20px}.image-wrapper img{max-height:300px}.download-button{padding:12px 20px;font-size:.9rem}.products-section{padding:20px}.products-title{font-size:1.5rem}.products-subtitle{font-size:.9rem;margin-bottom:24px}.products-grid{grid-template-columns:1fr;gap:16px}}.checkout-container{min-height:100vh;background:#fff;padding:20px;position:relative;animation:fadeInPage .3s ease}@keyframes fadeInPage{0%{opacity:0}to{opacity:1}}.checkout-container .cart-icon-button{position:fixed;top:20px;right:20px;width:auto;height:auto;background:transparent;color:#000;border:none;cursor:pointer;transition:all .2s ease;z-index:100;display:flex;align-items:center;justify-content:center;padding:8px}.checkout-container .cart-icon-button:hover{transform:scale(1.1)}.checkout-container .cart-badge{position:absolute;top:-4px;right:-4px;background:red;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;border:2px solid #ffffff}.checkout-content{margin:0 auto;padding:80px 40px 40px;max-width:100%}.checkout-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(224,224,224,.5);box-shadow:0 8px 32px #00000026;padding:50px;max-width:1200px;margin:0 auto}.checkout-title{font-size:2.5rem;font-weight:300;letter-spacing:-.02em;margin-bottom:40px;color:#000;text-align:center}.checkout-grid{display:grid;grid-template-columns:1fr;gap:40px;max-width:900px;margin:0 auto}.skeleton{position:relative;background:#f0f0f0;overflow:hidden}.skeleton-shimmer{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.6) 50%,transparent 100%);animation:shimmer 1.5s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}@media (min-width: 1024px){.checkout-grid{grid-template-columns:500px 1fr;max-width:1400px;gap:60px;align-items:start}.preview-section{position:sticky;top:20px}.preview-image-wrapper{background:#f5f5f5;border:1px solid #e0e0e0;padding:20px}}.preview-section{text-align:center}.preview-image-wrapper{background:#f5f5f5;border:1px solid #e0e0e0;padding:20px;margin-bottom:20px}.preview-image-wrapper img{max-width:100%;height:auto;max-height:500px;object-fit:contain}.product-name-large{font-size:1.3rem;font-weight:400;color:#000}.checkout-form{display:flex;flex-direction:column;gap:30px}.form-section{display:flex;flex-direction:column;gap:12px}.section-title{font-size:1.1rem;font-weight:400;color:#000;letter-spacing:.02em}.size-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:10px;max-height:350px;overflow-y:auto;padding:4px;scrollbar-width:thin;scrollbar-color:#d4a574 #f0f0f0}.size-options::-webkit-scrollbar{width:8px}.size-options::-webkit-scrollbar-track{background:#f0f0f0;border-radius:4px}.size-options::-webkit-scrollbar-thumb{background:#d4a574;border-radius:4px}.size-options::-webkit-scrollbar-thumb:hover{background:#c49563}.option-button{padding:12px 24px;background:#fff;color:#000;border:1px solid #cccccc;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em}.option-button:hover{border-color:#000}.option-button.selected{background:#000;color:#fff;border-color:#000}.color-options{display:flex;flex-direction:column;gap:12px}.color-button{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;color:#000;border:1px solid #cccccc;font-size:.95rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em;text-align:left}.color-button:hover{border-color:#000}.color-button.selected{background:#f5f5f5;border-color:#000;border-width:2px}.color-swatch{width:30px;height:30px;border-radius:50%;display:inline-block}.quantity-selector{display:flex;align-items:center;gap:20px}.quantity-button{width:40px;height:40px;background:#fff;color:#000;border:1px solid #000000;font-size:1.2rem;cursor:pointer;transition:all .2s ease;font-weight:300}.quantity-button:hover{background:#000;color:#fff}.quantity-display{font-size:1.2rem;font-weight:400;min-width:40px;text-align:center}.price-summary{background:#f5f5f5;border:1px solid #e0e0e0;padding:20px;display:flex;flex-direction:column;gap:12px;max-height:600px;overflow-y:auto}.summary-title{font-size:1.2rem;font-weight:500;margin:0 0 12px;color:#000;text-align:center;padding-bottom:12px;border-bottom:2px solid #d0d0d0}.summary-section-title{font-size:.95rem;font-weight:500;margin:8px 0;color:#666}.summary-divider{height:1px;background:#d0d0d0;margin:8px 0}.summary-item{display:flex;gap:12px;padding:12px;background:#fff;border:1px solid #d0d0d0;border-radius:6px;margin-bottom:8px;position:relative}.summary-item-image{width:60px;height:60px;object-fit:cover;border-radius:4px;border:1px solid #d0d0d0;flex-shrink:0}.summary-item-details{flex:1;display:flex;flex-direction:column;gap:4px}.summary-item-details h4{font-size:.95rem;font-weight:500;margin:0;color:#000}.summary-item-details p{font-size:.85rem;color:#666;margin:0}.summary-item-price{font-weight:500;color:#000!important;margin-top:4px!important}.summary-item-remove{position:absolute;top:8px;right:8px;background:none;border:none;color:#999;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s ease}.summary-item-remove:hover{background:#ffebee;color:red}.summary-item-remove svg{width:16px;height:16px}.price-row{display:flex;justify-content:space-between;font-size:1rem;color:#000}.price-row.cart-total{font-size:.9rem;color:#666;border-top:1px solid #d0d0d0;border-bottom:1px solid #d0d0d0;margin:4px 0;background:#fafafa;padding:8px;border-radius:4px}.shipping-container{border:2px solid #4caf50;border-radius:8px;padding:12px;margin:8px 0;background:linear-gradient(135deg,#4caf500d,#4caf5005)}.price-row.shipping-row{font-weight:500;padding:0;margin:0}.free-shipping-badge{background:#4caf50;color:#fff;font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:12px;margin-left:8px;letter-spacing:.5px}.shipping-notice{background:#fff;color:#4caf50;padding:8px;border-radius:4px;text-align:center;font-size:.85rem;font-weight:600;margin-top:8px;border:1px dashed #4caf50;animation:pulse 2s ease-in-out infinite;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@keyframes pulse{0%,to{opacity:1}50%{opacity:.85}}.price-row.total{font-size:1.3rem;font-weight:400;padding-top:12px;border-top:2px solid #000000;margin-top:8px}.checkout-button{width:100%;padding:16px 32px;background:#635bff;color:#fff;border:none;font-size:1.1rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em;box-shadow:0 2px 8px #635bff4d}.checkout-button:hover:not(:disabled){background:#5048e5;box-shadow:0 4px 12px #635bff66;transform:translateY(-1px)}.checkout-button:disabled{background:#666;cursor:not-allowed;opacity:.7}.stripe-badge{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 0;font-size:.85rem;color:#666}.stripe-badge svg{color:#635bff}.stripe-badge span{color:#666}.stripe-link{color:#635bff;text-decoration:none;font-weight:500;border-bottom:1px solid transparent;transition:border-bottom-color .2s ease}.stripe-link:hover{border-bottom-color:#635bff}.add-to-cart-button{padding:16px 32px;background:#fff;color:#000;border:1px solid #000000;font-size:1.1rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em}.add-to-cart-button:hover{background:#f5f5f5}@media (max-width: 968px){.checkout-container .cart-icon-button{top:16px;right:16px}.checkout-container .cart-icon-button svg{width:22px;height:22px}.checkout-container .cart-badge{width:22px;height:22px;font-size:.7rem}.checkout-grid{gap:30px}.ratio-sizes{grid-template-columns:repeat(auto-fill,minmax(75px,1fr));gap:8px}.preview-image-wrapper img{max-height:400px}}@media (max-width: 768px){.checkout-content{padding-top:70px}.checkout-card{padding:32px 24px}.checkout-title{font-size:2rem;margin-bottom:30px}.checkout-grid{gap:30px}.size-options{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}.ratio-sizes{grid-template-columns:repeat(auto-fill,minmax(70px,1fr))}.preview-image-wrapper img{max-height:350px}}@media (max-width: 480px){.checkout-container .cart-icon-button{top:12px;right:12px}.checkout-container .cart-icon-button svg{width:20px;height:20px}.checkout-container .cart-badge{width:20px;height:20px;font-size:.65rem}.checkout-content{padding-top:60px;padding-left:0;padding-right:0}.checkout-card{padding:0;margin:0;border-radius:0;box-shadow:none}.checkout-title{font-size:1.75rem;margin-bottom:24px;padding:0 20px}.checkout-grid{gap:0;max-width:100%}.ratio-sizes{grid-template-columns:repeat(auto-fill,minmax(65px,1fr));gap:6px}.size-ratios-container{max-height:250px}.preview-section{padding:0 20px 24px}.preview-image-wrapper{padding:12px}.preview-image-wrapper img{max-height:300px}.product-name-large{font-size:1.1rem}.checkout-form{gap:24px;padding:0 20px}.section-title{font-size:1rem}.size-options{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px}.option-button{padding:10px 18px;font-size:.9rem}.color-button{padding:10px 14px;font-size:.9rem}.color-swatch{width:25px;height:25px}.price-summary{padding:20px;margin:24px 0 0;border-radius:0;border-left:none;border-right:none}.summary-item,.summary-cart-item{padding:16px}.summary-cart-item-image{width:60px;height:60px}.price-row{font-size:.95rem}.price-row.total{font-size:1.15rem}.checkout-button,.add-to-cart-button{padding:14px 24px;font-size:1rem}}.frame-color-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.frame-color-card{border:2px solid #e0e0e0;border-radius:6px;padding:0;cursor:pointer;transition:all .2s ease;background:#fff;overflow:hidden}.frame-color-card:hover{border-color:#000;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.frame-color-card.selected{border-color:#000;background:#f9f9f9;box-shadow:0 0 0 3px #0000001a}.frame-color-image{width:100%;aspect-ratio:1;overflow:hidden;background:#f5f5f5}.frame-color-image img{width:100%;height:100%;object-fit:cover;display:block}.paper-options{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.toggle-container{display:grid;grid-template-columns:1fr 1fr;gap:12px}.toggle-option{padding:16px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:.9rem;font-weight:500}.toggle-option:hover{border-color:#000;background:#f9f9f9}.toggle-option.selected{border-color:#000;background:#000;color:#fff}.toggle-option.selected svg{stroke:#fff}.toggle-option svg{stroke:#000}.custom-dropdown{position:relative;width:100%}.custom-dropdown-header{width:100%;padding:14px 16px;font-size:1rem;font-weight:500;color:#000;border:2px solid #d4a574;border-radius:8px;background:#fff;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .2s ease}.custom-dropdown-header:hover{border-color:#000;box-shadow:0 2px 8px #0000001a}.custom-dropdown-header svg{flex-shrink:0;color:#000}.custom-dropdown-list{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #00000026;max-height:240px;overflow-y:auto;z-index:1000;scrollbar-width:thin;scrollbar-color:#d4a574 #f0f0f0}.custom-dropdown-list::-webkit-scrollbar{width:6px}.custom-dropdown-list::-webkit-scrollbar-track{background:#f0f0f0}.custom-dropdown-list::-webkit-scrollbar-thumb{background:#d4a574;border-radius:3px}.custom-dropdown-option{padding:12px 16px;font-size:1rem;color:#000;cursor:pointer;transition:background .2s ease}.custom-dropdown-option:hover{background:#f5f5f5}.custom-dropdown-option.selected{background:#f0f0f0;font-weight:600}.custom-dropdown-option:first-child{border-radius:8px 8px 0 0}.custom-dropdown-option:last-child{border-radius:0 0 8px 8px}.mobile-only{display:none}.desktop-only{display:block}.size-options.desktop-only,.paper-options.desktop-only{display:grid}.size-ratios-container{display:flex;flex-direction:column;gap:28px;max-height:500px;overflow-y:auto;padding:8px 4px;scrollbar-width:thin;scrollbar-color:#d4a574 #f0f0f0}.size-ratios-container::-webkit-scrollbar{width:6px}.size-ratios-container::-webkit-scrollbar-track{background:#f0f0f0;border-radius:3px}.size-ratios-container::-webkit-scrollbar-thumb{background:#d4a574;border-radius:3px}.size-ratios-container::-webkit-scrollbar-thumb:hover{background:#c49563}.ratio-group{display:flex;flex-direction:column;gap:14px}.ratio-title{font-size:1rem;font-weight:600;color:#333;margin:0;padding-bottom:8px;border-bottom:2px solid #e0e0e0;letter-spacing:.02em}.ratio-sizes{display:grid;grid-template-columns:repeat(auto-fill,minmax(85px,1fr));gap:10px}.size-button{padding:12px 8px;background:#fff;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.9rem;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease;text-align:center}.size-button:hover{border-color:#000;color:#000;background:#f8f8f8}.size-button.selected{background:#d94f30;border-color:#d94f30;color:#fff;font-weight:600}.frame-color-sections{display:flex;flex-direction:column;gap:20px;scrollbar-width:thin;scrollbar-color:#d4a574 #f0f0f0}.frame-color-sections::-webkit-scrollbar{width:8px;height:8px}.frame-color-sections::-webkit-scrollbar-track{background:#f0f0f0;border-radius:4px}.frame-color-sections::-webkit-scrollbar-thumb{background:#d4a574;border-radius:4px}.frame-color-sections::-webkit-scrollbar-thumb:hover{background:#c49563}.frame-material-section{display:flex;flex-direction:column;gap:10px}.material-label{font-size:.95rem;font-weight:600;color:#666;margin:0;text-transform:uppercase;letter-spacing:.5px}.framing-service-container{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.framing-service-option{position:relative;display:flex;align-items:flex-start;padding:16px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s ease;background:#fff}.framing-service-option:hover{border-color:#000;box-shadow:0 2px 8px #0000001a}.framing-service-option.selected{border-color:#000;background:#f9f9f9;box-shadow:0 0 0 3px #0000001a}.framing-service-option input[type=radio]{margin-right:12px;margin-top:2px;cursor:pointer;width:18px;height:18px;accent-color:#000000}.framing-service-content{display:flex;flex-direction:column;gap:4px;flex:1}.framing-service-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.framing-service-title{font-size:1rem;font-weight:600;color:#000}.framing-service-badge{font-size:.75rem;font-weight:700;color:#4caf50;background:#e8f5e9;padding:3px 8px;border-radius:4px;white-space:nowrap;text-transform:lowercase}.framing-service-desc{font-size:.875rem;color:#666;line-height:1.4}.addons-container{display:flex;flex-direction:column;gap:12px}.addon-checkbox{display:flex;align-items:center;gap:10px;padding:14px;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s ease;background:#fff}.addon-checkbox:hover{border-color:#000;background:#f9f9f9}.addon-checkbox input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:#000000}.addon-checkbox span{flex:1;font-size:1rem;font-weight:500}.info-icon{width:20px;height:20px;border-radius:50%;border:1px solid #999999;background:none;color:#999;font-size:.8rem;cursor:help;display:flex;align-items:center;justify-content:center;padding:0;transition:all .2s ease}.info-icon:hover{border-color:#000;color:#000;background:#f0f0f0}@media (max-width: 768px){.mobile-only{display:block!important}.desktop-only{display:none!important}.framing-service-container{grid-template-columns:1fr}}.price-summary::-webkit-scrollbar,.checkout-form::-webkit-scrollbar{width:8px}.price-summary::-webkit-scrollbar-track,.checkout-form::-webkit-scrollbar-track{background:#f0f0f0;border-radius:10px}.price-summary::-webkit-scrollbar-thumb,.checkout-form::-webkit-scrollbar-thumb{background:silver;border-radius:10px;transition:background .2s ease}.price-summary::-webkit-scrollbar-thumb:hover,.checkout-form::-webkit-scrollbar-thumb:hover{background:#a0a0a0}.price-summary,.checkout-form{scrollbar-width:thin;scrollbar-color:#c0c0c0 #f0f0f0}.cart-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1000;animation:fadeIn .2s ease}.cart-panel{position:absolute;right:0;top:0;height:100%;width:400px;max-width:90vw;background:#fff;box-shadow:-2px 0 10px #0000001a;display:flex;flex-direction:column;animation:slideIn .3s ease}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.cart-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0;background:#fafafa}.cart-header h2{margin:0;font-size:1.3rem;font-weight:600;color:#000}.cart-close{background:none;border:none;font-size:2rem;cursor:pointer;color:#666;transition:color .2s ease;line-height:1;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.cart-close:hover{color:#000}.cart-items{flex:1;overflow-y:auto;padding:16px}.cart-item{display:flex;gap:15px;padding:16px;background:#fff;margin-bottom:12px;border:1px solid #e0e0e0;border-radius:8px;transition:all .2s ease;position:relative}.cart-item:hover{box-shadow:0 2px 8px #00000014;border-color:#d0d0d0}.cart-item-image-container{flex-shrink:0;width:90px;height:90px;border-radius:6px;overflow:hidden;background:#f5f5f5;border:1px solid #e0e0e0}.cart-item-frame-image{width:100%;height:100%;object-fit:cover}.cart-item-info{flex:1;display:flex;flex-direction:column;gap:10px;min-width:0}.cart-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;padding-bottom:8px;border-bottom:1px solid #f0f0f0}.cart-item-title{font-size:1rem;font-weight:600;margin:0;color:#000;line-height:1.3;flex:1;min-width:0}.cart-item-price{font-size:1.125rem;font-weight:700;color:#000;white-space:nowrap;flex-shrink:0}.cart-item-specs{display:flex;flex-direction:column;gap:4px}.cart-spec-row{display:flex;align-items:center;gap:8px;font-size:.875rem}.spec-label{color:#666;font-weight:500;min-width:75px}.spec-value{color:#000;display:flex;align-items:center;gap:6px;font-weight:500;flex-wrap:wrap}.color-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.cart-item-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:auto;padding-top:8px;border-top:1px solid #f0f0f0}.cart-item-quantity{display:flex;align-items:center;gap:10px}.quantity-label{color:#666;font-size:.875rem;font-weight:500}.quantity-controls{display:flex;align-items:center;gap:8px;padding:4px 8px;background:#f8f8f8;border-radius:6px;border:1px solid #e0e0e0}.quantity-btn{width:24px;height:24px;background:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;font-weight:600;color:#000;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.quantity-btn:hover{background:#000;color:#fff}.quantity-value{font-size:.875rem;font-weight:600;min-width:28px;text-align:center;color:#000}.cart-item-remove-icon{display:flex;align-items:center;justify-content:center;padding:6px;border:1px solid #e0e0e0;background:#fff;color:#999;border-radius:6px;cursor:pointer;transition:all .2s ease;flex-shrink:0;width:32px;height:32px;position:absolute;top:16px;right:16px;z-index:10}.cart-item-remove-icon:hover{background:#fff5f5;border-color:#f44;color:#f44}.cart-item-remove-icon svg{stroke:currentColor;flex-shrink:0}.cart-footer{border-top:2px solid #e0e0e0;padding:20px;background:#fafafa}.cart-pricing{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.cart-subtotal,.cart-shipping-row{display:flex;justify-content:space-between;align-items:center;font-size:1rem;font-weight:500}.cart-shipping-notice{background:#fff;color:#4caf50;padding:8px;border-radius:4px;text-align:center;font-size:.85rem;font-weight:600;margin-top:8px;border:1px dashed #4caf50;animation:pulse 2s ease-in-out infinite;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-total{display:flex;justify-content:space-between;align-items:center;font-size:1.3rem;font-weight:700;padding-top:12px;border-top:2px solid #d0d0d0;color:#000}.cart-shipping-container{background:#e8f5e9;padding:12px;border-radius:6px;border:1px solid #4caf50}.free-shipping{color:#999;font-weight:400;text-decoration:line-through}.checkout-button-wrapper{display:flex;flex-direction:column;gap:0}.cart-checkout-btn{width:100%;padding:16px 32px;background:#635bff;color:#fff;border:none;font-size:1.1rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em;box-shadow:0 2px 8px #635bff4d}.cart-checkout-btn:hover:not(:disabled){background:#5048e5;box-shadow:0 4px 12px #635bff66;transform:translateY(-1px)}.cart-checkout-btn:disabled{background:#666;cursor:not-allowed;opacity:.7}.stripe-badge{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:12px;font-size:.85rem;color:#6b7c93}.stripe-badge svg{stroke:#635bff}.stripe-link{color:#635bff;text-decoration:none;font-weight:600}.stripe-link:hover{text-decoration:underline}.cart-empty{padding:40px 20px;text-align:center;color:#666}.cart-empty p{font-size:1.1rem;margin:0}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@media (max-width: 480px){.cart-item{flex-direction:column;gap:12px;padding:12px}.cart-item-image-container{width:100%;height:120px}.cart-item-info{gap:8px}.cart-item-header{flex-direction:column;align-items:flex-start;gap:4px;padding-bottom:6px}.cart-item-price{font-size:1.25rem}.cart-item-remove-icon{top:20px;right:20px;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 8px #00000026}.cart-item-specs{gap:3px}.cart-spec-row{font-size:.8rem}.spec-label{min-width:70px}.cart-item-actions{flex-direction:column;align-items:stretch;gap:8px;padding-top:6px}.cart-item-quantity{justify-content:space-between}.quantity-label{font-size:.8rem}.cart-item-remove-icon{width:28px;height:28px;padding:4px}.cart-checkout-btn{padding:14px 24px;font-size:1rem}.stripe-badge{font-size:.8rem;margin-top:14px}}.page-footer{padding:20px;text-align:center;margin-top:auto}.footer-email{font-size:.75rem;color:#999;text-decoration:none;transition:color .2s ease}.footer-email:hover{color:#666}@media (max-width: 768px){.page-footer{padding:16px}.footer-email{font-size:.7rem}}.toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000e6;color:#fff;padding:24px 48px;border-radius:12px;font-size:1.2rem;z-index:10000;box-shadow:0 8px 32px #0006;animation:toastAnimationDesktop 1s ease-in-out}@keyframes toastAnimationDesktop{0%{opacity:0;transform:translate(-50%,-50%) scale(.8) translateY(20px)}15%{opacity:1;transform:translate(-50%,-50%) scale(1.05) translateY(0)}25%{transform:translate(-50%,-50%) scale(1) translateY(0)}70%{opacity:1;transform:translate(-50%,-50%) scale(1) translateY(0)}to{opacity:0;transform:translate(calc(50vw - 70px),calc(-50vh + 40px)) scale(.3)}}.toast:before{content:"✓";display:inline-block;margin-right:12px;font-size:1.4rem;animation:checkMark .5s ease .1s both}@keyframes checkMark{0%{opacity:0;transform:scale(0) rotate(-45deg)}50%{transform:scale(1.2) rotate(0)}to{opacity:1;transform:scale(1) rotate(0)}}@media (max-width: 768px){.toast{padding:18px 36px;font-size:1.05rem;max-width:90%;width:auto}.toast:before{font-size:1.3rem;margin-right:10px}@keyframes toastAnimationDesktop{0%{opacity:0;transform:translate(-50%,-50%) scale(.8) translateY(20px)}15%{opacity:1;transform:translate(-50%,-50%) scale(1.05) translateY(0)}25%{transform:translate(-50%,-50%) scale(1) translateY(0)}70%{opacity:1;transform:translate(-50%,-50%) scale(1) translateY(0)}to{opacity:0;transform:translate(calc(50vw - 60px),calc(-50vh + 36px)) scale(.3)}}}@media (max-width: 480px){.toast{padding:16px 28px;font-size:.95rem;max-width:85%;border-radius:10px}.toast:before{font-size:1.1rem;margin-right:8px}@keyframes toastAnimationDesktop{0%{opacity:0;transform:translate(-50%,-50%) scale(.8) translateY(20px)}15%{opacity:1;transform:translate(-50%,-50%) scale(1.05) translateY(0)}25%{transform:translate(-50%,-50%) scale(1) translateY(0)}70%{opacity:1;transform:translate(-50%,-50%) scale(1) translateY(0)}to{opacity:0;transform:translate(calc(50vw - 52px),calc(-50vh + 32px)) scale(.3)}}}.success-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;background:#fff;animation:fadeIn .5s ease}.success-content{width:100%;max-width:600px;flex:1;display:flex;align-items:center;justify-content:center}.success-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(224,224,224,.5);box-shadow:0 8px 32px #00000026;padding:60px 40px;text-align:center;animation:slideUp .6s ease}.success-icon-wrapper{margin:0 auto 30px;width:100px;height:100px}.success-icon{width:100%;height:100%}.success-circle{stroke:#4caf50;stroke-width:2;fill:#4caf50;stroke-dasharray:166;stroke-dashoffset:166;animation:drawCircle .6s ease forwards}.success-check{stroke:#fff;stroke-width:3;stroke-linecap:round;stroke-dasharray:48;stroke-dashoffset:48;animation:drawCheck .4s .4s ease forwards}@keyframes drawCheck{to{stroke-dashoffset:0}}.success-title{font-size:2.5rem;font-weight:300;letter-spacing:-.02em;margin-bottom:20px;color:#000;animation:fadeInText .8s .5s ease both}.success-message{font-size:1.2rem;color:#666;margin-bottom:30px;line-height:1.6;animation:fadeInText .8s .6s ease both}.success-info-box{background:#f9f9f9;border:1px solid #e0e0e0;padding:24px;margin-bottom:30px;animation:fadeInText .8s .7s ease both}.success-email-message{font-size:1rem;color:#333;margin:0 0 16px;line-height:1.6}.success-support{font-size:.95rem;color:#666;margin:0;line-height:1.6}.success-session{font-size:.85rem;color:#999;margin-bottom:30px;animation:fadeInText .8s .8s ease both}.success-session span{font-family:monospace;font-weight:500;color:#666}.success-button{width:100%;padding:18px 48px;background:#000;color:#fff;border:none;font-size:1.1rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em;margin-top:10px;animation:fadeInText .8s .9s ease both;position:relative;z-index:10}.success-button:hover{background:#333;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.success-button:active{transform:translateY(0)}@media (max-width: 768px){.success-card{padding:48px 28px}.success-icon-wrapper{width:80px;height:80px;margin-bottom:24px}.success-title{font-size:2rem;margin-bottom:16px}.success-message{font-size:1.1rem;margin-bottom:24px}.success-info-box{padding:20px;margin-bottom:24px}.success-email-message{font-size:.95rem}.success-support{font-size:.9rem}.success-button{padding:14px 40px;font-size:.95rem}}@media (max-width: 480px){.success-container{padding:16px}.success-card{padding:40px 20px}.success-icon-wrapper{width:70px;height:70px;margin-bottom:20px}.success-title{font-size:1.75rem}.success-message{font-size:1rem;margin-bottom:20px}.success-info-box{padding:16px;margin-bottom:20px}.success-email-message{font-size:.9rem;margin-bottom:12px}.success-support{font-size:.85rem}.success-button{padding:12px 32px;font-size:.9rem;width:100%}}.cancel-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;background:#fff;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.cancel-content{width:100%;max-width:600px;flex:1;display:flex;align-items:center;justify-content:center}.cancel-card{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(224,224,224,.5);box-shadow:0 8px 32px #00000026;padding:60px 40px;text-align:center;animation:slideUp .6s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.cancel-icon-wrapper{margin:0 auto 30px;width:100px;height:100px}.cancel-icon{width:100%;height:100%}.cancel-circle{stroke:#f44;stroke-width:2;fill:#f44;stroke-dasharray:166;stroke-dashoffset:166;animation:drawCircle .6s ease forwards}@keyframes drawCircle{to{stroke-dashoffset:0}}.cancel-x{stroke:#fff;stroke-width:3;stroke-linecap:round;stroke-dasharray:56;stroke-dashoffset:56;animation:drawX .4s .4s ease forwards}@keyframes drawX{to{stroke-dashoffset:0}}.cancel-title{font-size:2.5rem;font-weight:300;letter-spacing:-.02em;margin-bottom:20px;color:#000;animation:fadeInText .8s .5s ease both}@keyframes fadeInText{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.cancel-message{font-size:1.2rem;color:#666;margin-bottom:30px;line-height:1.6;animation:fadeInText .8s .6s ease both}.cancel-info-box{background:#f9f9f9;border:1px solid #e0e0e0;padding:24px;margin-bottom:30px;animation:fadeInText .8s .7s ease both}.cancel-text{font-size:.95rem;color:#666;margin:0;line-height:1.6}.support-link{color:#000;font-weight:500;text-decoration:none;border-bottom:1px solid #000000;transition:all .2s ease}.support-link:hover{color:#333;border-bottom-color:#333}.cancel-actions{display:flex;flex-direction:column;gap:12px;animation:fadeInText .8s .8s ease both}.cancel-return-button{padding:16px 48px;background:#000;color:#fff;border:none;font-size:1rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em;width:100%}.cancel-return-button:hover{background:#333;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.cancel-home-button{padding:16px 48px;background:#fff;color:#000;border:1px solid #000000;font-size:1rem;cursor:pointer;transition:all .2s ease;font-weight:400;letter-spacing:.02em;width:100%}.cancel-home-button:hover{background:#f5f5f5;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.cancel-return-button:active,.cancel-home-button:active{transform:translateY(0)}@media (max-width: 768px){.cancel-card{padding:48px 28px}.cancel-icon-wrapper{width:80px;height:80px;margin-bottom:24px}.cancel-title{font-size:2rem;margin-bottom:16px}.cancel-message{font-size:1.1rem;margin-bottom:24px}.cancel-info-box{padding:20px;margin-bottom:24px}.cancel-text{font-size:.9rem}.cancel-return-button,.cancel-home-button{padding:14px 40px;font-size:.95rem}}@media (max-width: 480px){.cancel-container{padding:16px}.cancel-card{padding:40px 20px}.cancel-icon-wrapper{width:70px;height:70px;margin-bottom:20px}.cancel-title{font-size:1.75rem}.cancel-message{font-size:1rem;margin-bottom:20px}.cancel-info-box{padding:16px;margin-bottom:20px}.cancel-text{font-size:.85rem}.cancel-return-button,.cancel-home-button{padding:12px 32px;font-size:.9rem}}*{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:#fff;color:#000}
