:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#d0052a;text-decoration:inherit}a:hover{color:#a00420}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#a00420}button{background-color:#f9f9f9}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:SF Pro Display,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#fff;min-height:100vh;color:#1f2937;position:relative;overflow-x:hidden}.app{min-height:100vh;width:100vw;display:grid;grid-template-columns:1fr;align-items:center;justify-items:center;padding:2rem;position:relative;overflow-x:hidden}.container{background:#fff;border-radius:24px;padding:1rem 3rem 3rem;box-shadow:0 32px 64px #00000014,0 0 0 1px #dc26261a;width:100%;max-width:600px;position:relative;border:1px solid rgba(220,38,38,.1)}.container:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(220,38,38,.2),transparent)}.header{text-align:center;margin-bottom:2rem}.teacher-june-logo{margin:0 auto 2rem;border-radius:100px;box-shadow:0 20px 40px #dc262633,0 0 0 1px #ffffff1a;animation:float 6s ease-in-out infinite;transform-style:preserve-3d;overflow:hidden}.teacher-june-logo svg{border-radius:24px;display:block}@keyframes float{0%,to{transform:translateY(0) rotateX(0)}25%{transform:translateY(-8px) rotateX(10deg)}50%{transform:translateY(-12px) rotateX(0)}75%{transform:translateY(-8px) rotateX(-10deg)}}.header h1{font-size:2.75rem;font-weight:800;background:linear-gradient(135deg,#1f2937,#d0052a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:1rem;letter-spacing:-.025em;line-height:1.1}.header p{color:#6b7280;font-size:1.125rem;font-weight:500;line-height:1.6;max-width:400px;margin:0 auto}.form-container{position:relative;z-index:1}.preorder-form{display:flex;flex-direction:column;gap:2rem}.form-group{display:flex;flex-direction:column;position:relative;margin-bottom:20px}.form-group label{display:flex;align-items:center;gap:.625rem;font-weight:600;color:#374151;margin-bottom:.75rem;font-size:.875rem;letter-spacing:.025em}.form-group input,.form-group textarea{padding:1.125rem 1.5rem;border:2px solid #e5e7eb;border-radius:16px;font-size:1rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#1f2937;line-height:1.5;width:100%}.form-group input::placeholder,.form-group textarea::placeholder{color:#9ca3af;font-weight:400}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#343434;box-shadow:0 0 0 4px #34343414,0 4px 12px #3434341f;transform:translateY(-1px);background:#fff}.form-group input:hover:not(:focus),.form-group textarea:hover:not(:focus){border-color:#d1d5db;box-shadow:0 2px 8px #00000014}.form-group input.error,.form-group textarea.error{border-color:#d0052a;box-shadow:0 0 0 4px #d0052a1a,0 4px 12px #d0052a26}.form-group textarea{resize:vertical;min-height:110px;font-family:inherit}.error-message{color:#ef4444;font-size:.875rem;margin-top:.5rem;font-weight:500;display:flex;align-items:center;gap:.375rem}.address-section{background:#f8fafc80;border:2px solid rgba(226,232,240,.8);border-radius:20px;padding:1.5rem;margin:.5rem 0;transition:all .3s cubic-bezier(.4,0,.2,1)}.address-section:hover{border-color:#cbd5e1e6;background:#f8fafcb3}.address-header{display:flex;align-items:center;justify-content:space-between;font-weight:600;color:#374151;margin-bottom:20px;font-size:.875rem;letter-spacing:.025em}.address-title{display:flex;align-items:center;gap:.625rem}.location-button{background:#d0052a;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:.5rem;margin-top:.5rem;box-shadow:0 2px 8px #d0052a1a}.location-button:hover:not(:disabled){background:#a00420;box-shadow:0 4px 12px #d0052a29;transform:translateY(-1px)}.location-button:active:not(:disabled){background:#7a0318;transform:translateY(0)}.location-button:disabled{background:#f3f4f6;color:#d1d5db;cursor:not-allowed;box-shadow:none}.location-spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.address-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}@media (max-width: 640px){.address-grid{grid-template-columns:1fr;gap:1.25rem}}.form-group select{padding:1.125rem 1.5rem;border:2px solid #e5e7eb;border-radius:16px;font-size:1rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:#1f2937;line-height:1.5;width:100%;appearance:none;background-image:linear-gradient(45deg,transparent 50%,#6b7280 50%),linear-gradient(135deg,#6b7280 50%,transparent 50%);background-position:calc(100% - 20px) calc(1em + 2px),calc(100% - 15px) calc(1em + 2px);background-size:5px 5px,5px 5px;background-repeat:no-repeat}.form-group select:focus{outline:none;border-color:#343434;box-shadow:0 0 0 4px #34343414,0 4px 12px #3434341f;transform:translateY(-1px);background:#fff}.form-group select:hover:not(:focus){border-color:#d1d5db;box-shadow:0 2px 8px #00000014}.form-group select.error{border-color:#d0052a;box-shadow:0 0 0 4px #d0052a1a,0 4px 12px #d0052a26}.form-group select:disabled{background:#f8fafccc;color:#9ca3af;cursor:not-allowed;border-color:#e5e7eb;opacity:.7}.form-group input:read-only{background:#f8fafccc;color:#6b7280;cursor:default;border-color:#e5e7eb}.qr-container{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#f8fafccc;border:2px dashed #d1d5db;border-radius:16px;padding:2rem;transition:all .3s cubic-bezier(.4,0,.2,1);min-height:200px}.qr-container:hover{border-color:#d0052a;background:#f8fafce6}.qr-image{max-width:100%;max-height:160px;width:auto;height:auto;border-radius:12px;box-shadow:0 8px 24px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1)}.qr-image:hover{transform:scale(1.05);box-shadow:0 12px 32px #00000026}.qr-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:#6b7280;font-size:.875rem;font-weight:500;text-align:center}.qr-placeholder-icon{width:48px;height:48px;color:#9ca3af;opacity:.7}.qr-placeholder-text{max-width:200px;line-height:1.4}.download-button{background:#d0052a;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:.5rem;margin-top:1rem;box-shadow:0 4px 12px #d0052a26}.download-button:hover{background:#a00420;box-shadow:0 6px 16px #d0052a38;transform:translateY(-1px)}.download-button:active{background:#7a0318;transform:translateY(0)}.file-upload-container{display:flex;flex-direction:column;align-items:center;gap:1rem}.file-upload-area{width:100%;padding:2rem;border:2px dashed #d1d5db;border-radius:16px;background:#f8fafccc;text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.file-upload-area:hover{border-color:#d0052a;background:#f8fafce6}.file-upload-area.drag-over{border-color:#d0052a;background:#d0052a0d}.file-upload-input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer}.file-upload-content{display:flex;flex-direction:column;align-items:center;gap:1rem;pointer-events:none}.file-upload-icon{width:48px;height:48px;color:#6b7280;opacity:.7}.file-upload-text{font-size:.875rem;font-weight:500;color:#6b7280;line-height:1.4}.file-upload-text strong{color:#d0052a;font-weight:600}.file-upload-hint{font-size:.75rem;color:#9ca3af;margin-top:.5rem}.file-preview{width:100%;max-width:300px;border-radius:12px;box-shadow:0 8px 24px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1)}.file-preview:hover{transform:scale(1.02);box-shadow:0 12px 32px #00000026}.file-info{background:#ffffffe6;border:1px solid #e5e7eb;border-radius:12px;padding:1rem;margin-top:1rem;display:flex;align-items:center;gap:.75rem;font-size:.875rem;color:#374151}.file-info-icon{width:20px;height:20px;color:#10b981}.file-info-text{flex:1;font-weight:500}.file-size{font-size:.75rem;color:#6b7280}.remove-file-button{background:#d0052a;color:#fff;border:none;padding:.375rem;border-radius:8px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center}.remove-file-button:hover{background:#a00420;transform:scale(1.05)}.remove-file-icon{width:16px;height:16px}.spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.success-message{display:flex;align-items:center;justify-content:center;gap:.625rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:1.25rem;border-radius:16px;margin-top:1.5rem;font-weight:600;font-size:.95rem;box-shadow:0 20px 40px #10b9814d,0 0 0 1px #ffffff1a;animation:slideIn .6s cubic-bezier(.4,0,.2,1);letter-spacing:.025em}@keyframes slideIn{0%{opacity:0;transform:translateY(24px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.stepper{display:flex;align-items:center;justify-content:center;margin-bottom:2rem;gap:.5rem;position:relative;z-index:2}.step{display:flex;align-items:center;position:relative;transition:color .3s cubic-bezier(.4,0,.2,1)}.step-circle{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#d0052a,#e94a6a);color:#fff;font-weight:700;font-size:1.25rem;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px #6366f114;border:2px solid #d0052a;transition:background .4s,color .4s,border .4s,box-shadow .4s;z-index:1;position:relative;animation:stepperPop .5s cubic-bezier(.4,0,.2,1)}@keyframes stepperPop{0%{transform:scale(.7);opacity:.5}60%{transform:scale(1.15);opacity:1}to{transform:scale(1);opacity:1}}.step.active .step-circle{background:linear-gradient(135deg,#d0052a,#a00420);border:2px solid #d0052a;box-shadow:0 4px 16px #d0052a2e;animation:stepperActive .5s cubic-bezier(.4,0,.2,1)}@keyframes stepperActive{0%{box-shadow:0 0 #d0052a}70%{box-shadow:0 0 0 8px #d0052a33}to{box-shadow:0 4px 16px #d0052a2e}}.step.completed .step-circle{background:#d0052a;color:#fff;border:2px solid #d0052a;box-shadow:0 2px 8px #10b9811f}.step-label{margin-left:.75rem;margin-right:.75rem;font-size:1rem;font-weight:600;color:#d0052a;letter-spacing:.01em;min-width:70px;text-align:center;opacity:.7;transition:color .3s,opacity .3s}.step.active .step-label{color:#1f2937;opacity:1}.step.completed .step-label{color:#10b981;opacity:1}.step-line{width:48px;height:4px;background:linear-gradient(90deg,#fef2f2,#fee2e2);border-radius:2px;margin-left:-.5rem;margin-right:-.5rem;z-index:0;transition:background .4s}.step.completed .step-line{background:linear-gradient(90deg,#10b981,#34d399)}.step.active .step-line{background:linear-gradient(90deg,#d0052a,#a00420)}@media (max-width: 615px){.stepper{flex-direction:row;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:2rem;padding:0 .5rem}.step{flex-direction:column;align-items:center;flex:1;position:relative}.step-circle{width:28px;height:28px;font-size:.875rem;margin-bottom:.5rem;border-radius:50%;position:relative;z-index:2}.step-label{margin:0;min-width:0;font-size:.75rem;text-align:center;font-weight:500;line-height:1.2;max-width:80px}.step-line{position:absolute;top:14px;left:50%;width:100%;height:2px;background:linear-gradient(90deg,#fef2f2,#fee2e2);z-index:1}.step:last-child .step-line{display:none}.step.active .step-circle{transform:scale(1.1);box-shadow:0 4px 12px #d0052a40}.step.completed .step-circle{transform:scale(1.05)}}@media (min-width: 1200px){.app{padding:3rem}.container{max-width:700px;padding:2rem 4rem 4rem}.header h1{font-size:3.5rem}.header p{font-size:1.25rem}.preorder-form{gap:2.5rem}.form-group input,.form-group textarea{padding:1.5rem 2rem;font-size:1.125rem}.submit-button{padding:1.5rem 3rem;font-size:1.25rem;min-height:72px}}@media (max-width: 1024px){.app{padding:2rem 1.5rem}.container{max-width:550px;padding:2.5rem}.header h1{font-size:2.5rem}.header p{font-size:1.125rem}}@media (max-width: 768px){.app{padding:1.5rem 1rem;min-height:100vh;display:flex;flex-direction:column;justify-content:center}.container{padding:2rem;max-width:480px;width:100%}.header{margin-bottom:2.5rem}.header h1{font-size:2.25rem}.header p{font-size:1rem}.preorder-form{gap:1.75rem}.address-grid{grid-template-columns:1fr;gap:1.25rem}.address-section{padding:1.25rem}.form-group input,.form-group textarea,.form-group select{padding:1rem 1.25rem;font-size:1rem}.submit-button{padding:1.125rem 2rem;font-size:1rem;min-height:56px}}@media (max-width: 480px){.app{padding:1rem;min-height:100vh;width:100vw}.container{padding:1.5rem;border-radius:20px;max-width:100%;width:100%;margin:0}.header{margin-bottom:2rem}.header h1{font-size:2rem;line-height:1.2}.header p{font-size:.95rem}.teacher-june-logo{margin-bottom:1.5rem}.preorder-form{gap:1.5rem}.address-grid{grid-template-columns:1fr;gap:1rem}.address-section{padding:1rem;border-radius:16px}.address-header{margin-bottom:1rem;font-size:.8rem;flex-direction:column;align-items:flex-start;gap:1rem}.location-button{font-size:.7rem;padding:.375rem .75rem}.form-group{width:100%}.form-group label{font-size:.875rem;margin-bottom:.625rem}.form-group input,.form-group textarea,.form-group select{padding:1rem;font-size:1rem;border-radius:12px}.form-group textarea{min-height:100px}.submit-button{padding:1rem 1.5rem;font-size:1rem;min-height:52px;margin-top:1.5rem}.success-message{padding:1rem;font-size:.9rem}}@media (max-width: 360px){.app{padding:.75rem}.container{padding:1.25rem;border-radius:16px}.header h1{font-size:1.75rem}.address-section{padding:.875rem}.form-group input,.form-group textarea,.form-group select{padding:.875rem;font-size:.95rem}.submit-button{padding:.875rem 1.25rem;font-size:.95rem;min-height:48px}}@media (max-height: 600px) and (orientation: landscape){.app{padding:2rem 1rem 1rem;align-items:flex-start}.container{margin:0 auto}.header{margin-bottom:1.5rem}.header h1{font-size:2rem}.teacher-june-logo{margin-bottom:1rem}.preorder-form{gap:1.25rem}.submit-button{margin-top:1rem}}.payment-section{text-align:center}.qr-code-image{width:200px;height:200px;border-radius:12px;box-shadow:0 10px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border:3px solid #ffffff}.qr-code-image:hover{transform:scale(1.05r);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.qr-code-placeholder{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem;color:#64748b;background:#fff;border-radius:12px;border:2px dashed #cbd5e1;width:200px;height:200px;justify-content:center}.qr-code-placeholder p{margin:0;font-weight:500;color:#475569}.qr-code-placeholder small{font-size:.75rem;color:#94a3b8}.qr-download-button{background:#d0052a;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:12px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:.5rem;margin-top:1rem;box-shadow:0 4px 12px #d0052a26}.qr-download-button:hover{background:#a00420;box-shadow:0 6px 16px #d0052a38;transform:translateY(-1px)}.qr-download-button:active{background:#7a0318;transform:translateY(0)}.proof-payment-section{padding:2rem;background:linear-gradient(135deg,#fef2f2,#fee2e2);border-radius:16px;border:1px solid #fecaca}.file-upload-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin-top:1rem}.file-input{display:none}.file-upload-label{display:flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:linear-gradient(135deg,#d0052a,#a00420);color:#fff!important;border:none;border-radius:12px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 6px -1px #d0052a4d;border:2px solid transparent}.file-upload-label:hover{background:linear-gradient(135deg,#a00420,#7a0318);transform:translateY(-2px) scale(1.03);box-shadow:0 8px 15px -3px #d0052a66;border-color:#f87171}.file-upload-label:active{transform:translateY(0) scale(1)}.image-preview{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-radius:12px;border:2px solid #fecaca;box-shadow:0 4px 6px -1px #0000001a;max-width:300px;width:100%}.preview-image{width:120px;height:120px;object-fit:cover;border-radius:8px;border:2px solid #fee2e2;box-shadow:0 2px 4px #0000001a}.preview-info{text-align:center;width:100%}.file-name{margin:0 0 .25rem;font-weight:600;color:#374151;font-size:.875rem;word-break:break-word}.file-size{margin:0;color:#6b7280;font-size:.75rem}.form-help{display:block;margin-top:.75rem;color:#6b7280;font-size:.75rem;text-align:center}.payment-step{display:flex;flex-direction:column;gap:2rem}@media (max-width: 768px){.qr-code-container{padding:1.5rem;margin:1.5rem 0}.qr-code-image,.qr-code-placeholder{width:160px;height:160px}.proof-payment-section{padding:1.5rem}.image-preview{max-width:250px;padding:1rem}.preview-image{width:100px;height:100px}}.stepper-nav{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;position:relative}.next-button{background:#d0052a;color:#fff;border:none;padding:1rem 2rem;border-radius:16px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1.5rem;box-shadow:0 8px 24px #d0052a1f;width:100%}.next-button:hover{background:#a00420;box-shadow:0 12px 32px #d0052a2e;transform:translateY(-2px)}.next-button:active{background:#7a0318;transform:translateY(0)}.submit-button.loading{background:linear-gradient(135deg,#6b7280,#4b5563);cursor:not-allowed;transform:none;box-shadow:0 4px 6px -1px #6b72804d}.back-button{background:#fff;color:#343434;border:2px solid #343434;padding:.85rem 2rem;border-radius:16px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:.75rem;margin-top:1.5rem;box-shadow:0 2px 8px #34343414}.status-step{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1%}.success-message{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:3rem 2rem;background:linear-gradient(135deg,#ecfdf5,#d1fae5);border-radius:20px;border:2px solid #10b981;box-shadow:0 20px 25px -5px #10b9811a,0 10px 10px -5px #10b9810a;animation:successSlideIn .6s ease-out;max-width:500px;width:100%}.success-message svg{color:#10b981;animation:successIconPop .8s ease-out .3s both}.success-message span{font-size:1.25rem;font-weight:700;color:#065f46;animation:successTextFade .8s ease-out .5s both}.success-details{margin-top:1rem;padding:1.5rem;background:#fff;border-radius:12px;border:1px solid #d1fae5;animation:successDetailsSlide .8s ease-out .7s both}.success-details h3{margin:0 0 1rem;color:#065f46;font-size:1.125rem;font-weight:600}.success-details p{margin:0 0 .75rem;color:#374151;font-size:.875rem;line-height:1.5}.success-details .order-id{background:#f3f4f6;padding:.5rem 1rem;border-radius:8px;font-family:Courier New,monospace;font-weight:600;color:#1f2937;margin-top:.5rem;display:inline-block}.status-message{display:flex;align-items:center;gap:1rem;padding:2rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:16px;border:2px solid #f59e0b;animation:statusPulse 2s ease-in-out infinite}.status-message span{font-size:1.125rem;font-weight:600;color:#92400e}@keyframes successSlideIn{0%{opacity:0;transform:translateY(30px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes successIconPop{0%{opacity:0;transform:scale(0) rotate(-180deg)}50%{transform:scale(1.2) rotate(0)}to{opacity:1;transform:scale(1) rotate(0)}}@keyframes successTextFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes successDetailsSlide{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes statusPulse{0%,to{transform:scale(1);box-shadow:0 4px 6px -1px #f59e0b33}50%{transform:scale(1.02);box-shadow:0 8px 15px -3px #f59e0b4d}}.info-step .stepper-nav{justify-content:center}.info-step .next-button{margin:0 auto}.payment-step .stepper-nav{justify-content:center}.payment-step .submit-button{margin:0 auto}@media (max-width: 768px){.stepper-nav{flex-direction:column;gap:1rem}.back-button{position:static;transform:none;margin-top:1rem}.success-message{padding:2rem 1rem;margin:0 1rem}.success-details{padding:1rem}}.step.clickable{transition:box-shadow .2s,background .2s}.step.clickable:hover{box-shadow:0 2px 12px #3b82f61f;background:#f0f9ff}.full-width{width:100%;display:block;margin-left:0;margin-right:0;box-sizing:border-box}.download-button,.qr-download-button,.next-button,.location-button,.submit-button{background:#343434;color:#fff;border:none;box-shadow:0 4px 12px #34343426}.download-button:hover,.qr-download-button:hover,.next-button:hover,.location-button:hover:not(:disabled),.submit-button:hover:not(:disabled){background:#232323;box-shadow:0 6px 16px #34343438}.download-button:active,.qr-download-button:active,.next-button:active,.location-button:active:not(:disabled),.submit-button:active:not(:disabled){background:#111}.back-button{background:#fff;color:#343434;border:2px solid #343434;box-shadow:0 2px 8px #34343414}.back-button:hover{background:#343434;color:#fff;box-shadow:0 6px 16px #3434341f}.back-button:active{background:#232323;color:#fff}.form-input,.form-group select,.form-group textarea{height:48px;padding:0 1.25rem;border:2px solid #e5e7eb;border-radius:16px;font-size:1rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);background:#ffffffe6;color:#1f2937;line-height:1.5;width:100%;box-sizing:border-box}.form-group textarea.form-input{height:auto;min-height:48px;padding-top:1.125rem;padding-bottom:1.125rem}.quantity-input-wrapper{display:flex;align-items:center;gap:.5rem;width:100%}.quantity-btn{flex:0 0 40px}.quantity-input{flex:1 1 auto;width:100%;min-width:0;max-width:none;text-align:center;font-size:1.125rem;font-weight:600;border:2px solid #e5e7eb;border-radius:12px;background:#fff;color:#343434;height:40px;padding:0}.form-input.readonly{height:48px;padding:1.125rem 1.5rem;background:#ffffffe6;color:#1f2937;font-size:1rem;font-weight:500;border-radius:16px;border:2px solid #e5e7eb;box-sizing:border-box}.form-group #postalCode.form-input{width:100%;min-width:0;max-width:none}.address-grid .form-group#postalCode-group{grid-column:1 / -1}@keyframes confetti-fall{0%{transform:translateY(-100vh) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(360deg);opacity:.7}}.confetti{position:fixed;left:0;top:0;width:100vw;height:100vh;pointer-events:none;z-index:9999}.confetti-piece{position:absolute;width:12px;height:18px;border-radius:4px;opacity:.85;animation:confetti-fall 2.2s cubic-bezier(.6,.2,.4,1) forwards}.success-message{background:linear-gradient(135deg,#fff 60%,#f3f4f6);border-radius:24px;box-shadow:0 8px 32px #3434341a;padding:2.5rem 2rem 2rem;display:flex;flex-direction:column;align-items:center;position:relative;animation:popIn .7s cubic-bezier(.4,0,.2,1)}@keyframes popIn{0%{transform:scale(.7) translateY(40px);opacity:0}80%{transform:scale(1.05) translateY(-8px);opacity:1}to{transform:scale(1) translateY(0);opacity:1}}.success-message .logo-pop{animation:popIn .8s cubic-bezier(.4,0,.2,1)}.success-message .check-pop{animation:popIn .9s cubic-bezier(.4,0,.2,1)}.copy-order-id{cursor:pointer;-webkit-user-select:all;user-select:all;position:relative;transition:background .2s}.copy-order-id:hover{background:#fee2e2}.copy-tooltip{position:absolute;left:50%;top:-2.2rem;transform:translate(-50%);background:#343434;color:#fff;font-size:.85rem;padding:.25rem .75rem;border-radius:8px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;z-index:10}.copy-order-id.copied .copy-tooltip{opacity:1}.success-message .order-again-btn{margin-top:2rem;background:#d0052a;color:#fff;border:none;border-radius:16px;padding:1rem 2.5rem;font-size:1.1rem;font-weight:700;box-shadow:0 4px 16px #d0052a1a;cursor:pointer;transition:background .2s,transform .2s}.success-message .order-again-btn:hover{background:#a00420;transform:translateY(-2px) scale(1.04)}.check-order-btn:hover{background:#a00420!important;transform:translateY(-1px);box-shadow:0 4px 12px #d0052a4d}.order-status{padding:20px;background:#f9fafb;border-radius:12px;margin-bottom:20px}.status-header{text-align:center;margin-bottom:24px}.status-header h3{color:#374151;margin-bottom:8px;font-size:1.25rem;font-weight:700}.current-status{font-size:1.1rem;font-weight:600}.status-timeline{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;position:relative}.status-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}.step-icon-container{display:flex;flex-direction:column;align-items:center;width:100%}.step-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:8px;transition:all .3s ease;position:relative;z-index:2}.step-icon.completed{animation:statusPop .3s ease-out}.step-icon.current{animation:statusPulse 2s infinite}.step-circle,.step.completed .step-circle{background:#343434;color:#fff;border:2px solid #343434}.step.active .step-circle{box-shadow:0 0 #343434;animation:stepperActive 1s cubic-bezier(.4,0,.2,1) infinite alternate}@keyframes stepperActive{0%{box-shadow:0 0 #343434}70%{box-shadow:0 0 0 8px #34343433}to{box-shadow:0 4px 16px #3434342e}}.step-line,.step.completed .step-line,.step.active .step-line{background:#343434}.order-details{background:#fff;border-radius:8px;padding:16px;border:1px solid #e5e7eb}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f3f4f6}.detail-row:last-child{border-bottom:none}.detail-label{font-weight:600;color:#374151;font-size:.875rem}.detail-value{color:#6b7280;font-size:.875rem;font-weight:500}@keyframes statusPop{0%{transform:scale(.8)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes statusPulse{0%,to{box-shadow:0 0 #3b82f666}50%{box-shadow:0 0 0 8px #3b82f600}}@media (max-width: 640px){.status-timeline{flex-direction:column;gap:16px}.status-step{flex-direction:row;align-items:center;gap:12px}.step-icon-container{flex-direction:row;width:auto}.step-line{width:3px;height:20px;margin-bottom:0;margin-right:8px}.step-label{text-align:left;max-width:none;flex:1}}.check-order-page{min-height:100vh;width:100vw;display:grid;grid-template-columns:1fr;align-items:center;justify-items:center;padding:2rem;position:relative;overflow-x:hidden}.check-order-content{max-width:600px;margin:0 auto;padding:0rem 0 3rem}.back-button{position:static;background:#fff;color:#d0052a;border:2px solid #d0052a;padding:10px 20px;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:14px;text-decoration:none;transition:all .3s ease;box-shadow:0 2px 8px #d0052a1a}.back-button:hover{background:#f9fafb;color:#a00420;border-color:#a00420}.header-content h1{font-size:2.5rem;font-weight:800;margin:1rem 0 0rem;letter-spacing:-.025em}.header-content p{font-size:1.125rem;opacity:.9;margin:0}.check-form-section{max-width:600px;margin:0 auto;padding:1rem}.form-card{background:#f9fafb;border-radius:16px;padding:2rem;margin-bottom:2rem;border:1px solid #e5e7eb}.form-card h2{color:#374151;font-size:1.5rem;font-weight:700;margin-bottom:.5rem;text-align:center}.form-description{color:#6b7280;text-align:center;margin-bottom:2rem;line-height:1.6}.check-order-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:600;color:#374151;margin-bottom:.5rem;font-size:.875rem}.form-input{padding:1rem 1.25rem;border:2px solid #e5e7eb;border-radius:12px;font-size:1rem;transition:all .3s ease;background:#fff}.form-input:focus{outline:none;border-color:#d0052a;box-shadow:0 0 0 3px #d0052a1a}.form-input.error{border-color:#dc2626}.error-message{color:#dc2626;font-size:.875rem;margin-top:.25rem}.check-button{background:#d0052a;color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem}.check-button:hover:not(:disabled){background:#a00420;transform:translateY(-1px)}.check-button:disabled{opacity:.7;cursor:not-allowed}.spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sample-orders{background:#fff;border-radius:16px;padding:2rem;border:1px solid #e5e7eb}.sample-orders h3{color:#374151;font-size:1.25rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.sample-orders-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.sample-order{background:#f9fafb;border-radius:12px;padding:1.5rem;border:1px solid #e5e7eb;transition:transform .2s ease}.sample-order:hover{transform:translateY(-2px)}.sample-order h4{color:#d0052a;font-size:1rem;font-weight:700;margin-bottom:1rem}.sample-order p{color:#6b7280;font-size:.875rem;margin-bottom:.5rem;line-height:1.4}.sample-order strong{color:#374151}.result-section{max-width:600px;margin:0 auto}.success-result{text-align:center}.check-another-button{background:#6b7280;color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:2rem}.check-another-button:hover{background:#4b5563;transform:translateY(-1px)}.error-result{text-align:center;padding:3rem 2rem}.error-icon{color:#dc2626;margin-bottom:1rem}.error-result h3{color:#374151;font-size:1.5rem;font-weight:700;margin-bottom:1rem}.error-result p{color:#6b7280;margin-bottom:2rem;line-height:1.6}.try-again-button{background:#d0052a;color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.try-again-button:hover{background:#a00420;transform:translateY(-1px)}@media (max-width: 768px){.check-order-page{padding:1rem}.check-order-content{padding:0rem 1.5rem}.header-content h1{font-size:2rem}.back-button{position:static;display:inline-flex;margin-bottom:1rem}.sample-orders-grid{grid-template-columns:1fr}}@media (max-width: 480px){.check-order-content{padding:0rem 1rem}.form-card,.sample-orders{padding:1.5rem}.header-content h1{font-size:1.75rem}}.status-timeline{display:flex;justify-content:center;align-items:flex-start;margin:0 auto 32px;position:relative;border-radius:16px;padding:1rem 1.5rem}@media (max-width: 700px){.status-timeline{flex-direction:column;align-items:center;padding:.5rem .2rem;gap:1.2rem}.status-step{flex-direction:row;align-items:center;min-width:0;margin-bottom:.5rem;width:100%;justify-content:flex-start}.step-icon-container{flex-direction:row;align-items:center;width:auto;margin-right:.75rem}.step-icon{width:28px;height:28px;font-size:.95rem;margin-bottom:0;margin-right:.5rem}.step-line{display:none}.step-label{text-align:left;font-size:.92rem;max-width:none;margin-top:0;font-weight:600;flex:1}}
