*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}.skip-link{position:absolute;top:-100%;left:50%;transform:translateX(-50%);background:#2563eb;color:#fff;padding:.75rem 1.5rem;border-radius:0 0 8px 8px;z-index:9999;transition:top .3s}.skip-link:focus{top:0}.step-item{display:flex;flex-direction:column;align-items:center;gap:4px}.step-circle{width:32px;height:32px;border-radius:50%;background:#e2e8f0;color:#64748b;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;transition:.3s}.dark .step-circle{background:#334155;color:#94a3b8}.step-item.active .step-circle,.step-item.completed .step-circle{background:#2563eb;color:#fff}.step-item.completed .step-circle{background:#10b981}.step-label{font-size:12px;font-weight:500;color:#64748b;display:none}.step-item.active .step-label{color:#2563eb}.dark .step-item.active .step-label{color:#60a5fa}.step-line{width:40px;height:3px;background:#e2e8f0;border-radius:2px}.dark .step-line{background:#334155}@media (min-width:640px){.step-label{display:block}.step-line{width:60px}}.upload-zone{border:3px dashed #cbd5e1;border-radius:24px;padding:48px 32px;text-align:center;cursor:pointer;transition:.3s;background:linear-gradient(135deg,#fff 0,#f8fafc 100%);min-height:320px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 6px -1px rgba(0,0,0,.05)}.dark .upload-zone{background:linear-gradient(135deg,#1e293b 0,#0f172a 100%);border-color:#475569}.upload-zone:focus,.upload-zone:hover{border-color:#2563eb;background:linear-gradient(135deg,#eff6ff 0,#f8fafc 100%);transform:translateY(-2px);box-shadow:0 10px 25px -5px rgba(37,99,235,.15)}.dark .upload-zone:focus,.dark .upload-zone:hover{border-color:#3b82f6;background:linear-gradient(135deg,#1e293b 0,#1e3a5f 100%)}.upload-zone.drag-over{border-color:#2563eb;background:#eff6ff;transform:scale(1.02)}.dark .upload-zone.drag-over{background:#1e3a5f}.upload-zone:focus{outline:0;box-shadow:0 0 0 4px rgba(37,99,235,.2)}.step-section{animation:.3s fadeIn;padding-bottom:2rem}@media (max-width:768px){.step-section{padding-bottom:4rem}}.step-section.hidden{display:none}.crop-container{position:relative;width:100%;max-width:100%;aspect-ratio:1/1;height:auto;margin:0 auto;background:#f1f5f9;border-radius:12px;overflow:hidden}@media (max-width:380px){.crop-container{border-radius:8px;aspect-ratio:4/5}}@media (min-width:480px){.crop-container{border-radius:16px}}@media (min-width:640px){.crop-container{max-width:400px;height:400px;aspect-ratio:unset}}.crop-container.transparent-bg{background:repeating-conic-gradient(#d1d5db 0 25%,#f3f4f6 0 50%) 50%/16px 16px}.dark .crop-container{background:#0f172a}.dark .crop-container.transparent-bg{background:repeating-conic-gradient(#374151 0 25%,#1f2937 0 50%) 50%/16px 16px}.crop-container canvas{width:100%;height:100%;object-fit:contain}.canvas-wrapper{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;display:flex;align-items:center;justify-content:center}.canvas-wrapper canvas{max-width:100%;max-height:100%;width:auto;height:auto}.crop-guide{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border:2px dashed rgba(37,99,235,.7);border-radius:8px;pointer-events:none;box-shadow:0 0 0 9999px rgba(0,0,0,.3)}.face-guide-overlay{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:flex-start;justify-content:center;padding-top:5%;pointer-events:none;z-index:15}.face-guide-oval{width:80px;height:105px;border:2px dashed rgba(37,99,235,.7);border-radius:50%;position:relative;background:rgba(37,99,235,.03)}.face-guide-label{position:absolute;bottom:-25px;left:50%;transform:translateX(-50%);font-size:10px;color:rgba(37,99,235,.8);white-space:nowrap;background:rgba(255,255,255,.9);padding:2px 8px;border-radius:4px}.dark .face-guide-label{background:rgba(30,41,59,.9)}.eye-line{position:absolute;width:80%;left:10%;top:35%;border-top:1px dashed rgba(16,185,129,.5)}.chin-line{position:absolute;width:60%;left:20%;bottom:15%;border-top:1px dashed rgba(16,185,129,.5)}.bg-color-btn{width:32px;height:32px;border-radius:8px;border:2px solid #e2e8f0;cursor:pointer;transition:.2s}.dark .bg-color-btn{border-color:#475569}.bg-color-btn:hover{transform:scale(1.1)}.bg-color-btn.active{border-color:#2563eb;box-shadow:0 0 0 2px rgba(37,99,235,.3)}.slider{width:100%;height:4px;border-radius:2px;background:#e2e8f0;outline:0;-webkit-appearance:none;appearance:none}.dark .slider{background:#334155}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#2563eb;cursor:pointer;transition:transform .2s}.slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#2563eb;cursor:pointer;border:none}.size-card{background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:20px;text-align:center;cursor:pointer;transition:.2s}.dark .size-card{background:#1e293b;border-color:#334155}.size-card:hover{border-color:#2563eb;transform:translateY(-2px);box-shadow:0 10px 25px -5px rgba(37,99,235,.15)}.size-card.active{border-color:#2563eb;background:#eff6ff}.dark .size-card.active{background:#1e3a5f;border-color:#3b82f6}.size-card .flag{font-size:32px;margin-bottom:8px}.size-card .name{font-weight:600;color:#0f172a;margin-bottom:4px}.dark .size-card .name{color:#f8fafc}.size-card .dimensions{font-size:13px;color:#64748b}.download-option-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;border:2px solid #e2e8f0;border-radius:16px;background:#fff;transition:.2s;cursor:pointer;color:#0f172a}.dark .download-option-btn{background:#1e293b;border-color:#334155;color:#f8fafc}.download-option-btn:hover{border-color:#2563eb;transform:translateY(-2px);box-shadow:0 10px 25px -5px rgba(37,99,235,.15)}.dl-badge{position:absolute;top:-1px;right:-1px;padding:2px 10px;font-size:10px;font-weight:700;letter-spacing:.05em;border-radius:0 14px 0 10px;line-height:1.6;text-transform:uppercase}.dl-badge-free{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.dl-badge-premium{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.dl-badge-best{background:linear-gradient(135deg,#f59e0b,#ea580c);color:#fff;animation:2s ease-in-out infinite dl-badge-glow}@keyframes dl-badge-glow{0%,100%{box-shadow:0 0 6px rgba(245,158,11,.3)}50%{box-shadow:0 0 14px rgba(245,158,11,.5)}}.dl-premium-btn{border-color:#fbbf24;background:linear-gradient(135deg,#fffbeb,#fef3c7)}.dark .dl-premium-btn{background:linear-gradient(135deg,rgba(245,158,11,.08),rgba(217,119,6,.12));border-color:#92400e}.dl-premium-btn:hover{border-color:#f59e0b!important;box-shadow:0 10px 25px -5px rgba(245,158,11,.2)}.dl-best-value{border-width:2px;border-color:#f59e0b}.pm-card{max-height:90vh;overflow-y:auto}.pm-loading-spinner{width:32px;height:32px;border:3px solid #e2e8f0;border-top-color:#f59e0b;border-radius:50%;animation:.7s linear infinite pm-spin;margin:16px auto}@keyframes pm-spin{to{transform:rotate(360deg)}}.quality-btn{padding:8px 16px;font-size:14px;font-weight:500;color:#64748b;border-radius:6px;transition:.2s;background:0 0;border:none;cursor:pointer}.quality-btn:hover{color:#0f172a}.dark .quality-btn:hover{color:#f8fafc}.quality-btn.active{background:#2563eb;color:#fff}.format-btn{padding:8px 14px;font-size:13px;font-weight:700;color:#64748b;border-radius:6px;transition:.2s;background:0 0;border:none;cursor:pointer}.format-btn:hover{color:#0f172a}.dark .format-btn:hover{color:#f8fafc}.format-btn.active{background:#2563eb;color:#fff}.input-field{width:100%;padding:10px 14px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;transition:.2s;background:#fff;color:#0f172a}.dark .input-field{background:#0f172a;border-color:#334155;color:#f8fafc}.input-field:focus{outline:0;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.15)}.modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px}.modal.hidden{display:none}.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);z-index:9998}.modal-content{position:relative;background:#fff;border-radius:20px;padding:24px;max-width:500px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 25px 50px -12px rgba(0,0,0,.25);z-index:10000}.dark .modal-content{background:#1e293b}.modal-close{color:#64748b;border:none;background:0 0;cursor:pointer}.print-preview-frame{width:100%;border:1px solid transparent;cursor:zoom-in;transition:border-color .2s,box-shadow .2s,transform .2s}.print-preview-frame:focus,.print-preview-frame:hover{border-color:#2563eb;box-shadow:0 12px 30px -18px rgba(37,99,235,.5);outline:0}.print-preview-frame canvas{max-width:92%;max-height:92%}.preview-tool-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid #cbd5e1;background:#fff;color:#334155;border-radius:8px;min-height:36px;padding:0 12px;font-size:13px;font-weight:600;cursor:pointer;transition:border-color .2s,background .2s,color .2s}.preview-tool-btn:focus,.preview-tool-btn:hover{border-color:#2563eb;background:#eff6ff;color:#1d4ed8;outline:0}.dark .preview-tool-btn{border-color:#334155;background:#0f172a;color:#cbd5e1}.dark .preview-tool-btn:focus,.dark .preview-tool-btn:hover{border-color:#60a5fa;background:#1e3a8a;color:#fff}.print-preview-modal-content{max-width:min(1120px,96vw);width:96vw;max-height:92vh;padding:0;overflow:hidden}.print-preview-modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:18px 20px;border-bottom:1px solid #e2e8f0}.dark .print-preview-modal-header{border-color:#334155}.print-preview-toolbar{display:flex;align-items:center;gap:8px;padding:12px 20px;border-bottom:1px solid #e2e8f0;background:#f8fafc}.dark .print-preview-toolbar{border-color:#334155;background:#0f172a}.preview-zoom-label{min-width:52px;text-align:center;font-size:13px;font-weight:700;color:#475569}.dark .preview-zoom-label{color:#cbd5e1}.preview-tool-text{min-width:64px}.large-preview-viewport{height:min(70vh,760px);overflow:auto;background:linear-gradient(45deg,#e2e8f0 25%,transparent 25%),linear-gradient(-45deg,#e2e8f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e2e8f0 75%),linear-gradient(-45deg,transparent 75%,#e2e8f0 75%);background-position:0 0,0 10px,10px -10px,-10px 0;background-size:20px 20px;padding:28px;text-align:center}.dark .large-preview-viewport{background:linear-gradient(45deg,#1e293b 25%,transparent 25%),linear-gradient(-45deg,#1e293b 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#1e293b 75%),linear-gradient(-45deg,transparent 75%,#1e293b 75%);background-color:#0f172a;background-position:0 0,0 10px,10px -10px,-10px 0;background-size:20px 20px}#largePrintCanvas{display:inline-block;background:#fff;box-shadow:0 24px 60px -28px rgba(15,23,42,.65);transform-origin:top center;transition:transform .15s}#printCanvas{display:block;background:#fff;box-shadow:0 8px 20px -16px rgba(15,23,42,.55)}@media (max-width:640px){.print-preview-toolbar{flex-wrap:wrap}.large-preview-viewport{height:62vh;padding:16px}}.faq-item{border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.dark .faq-item{border-color:#334155}.faq-question{padding:16px;font-weight:600;cursor:pointer;color:#0f172a;list-style:none}.dark .faq-question{color:#f8fafc}.faq-question::-webkit-details-marker{display:none}.faq-question::before{content:'+';margin-right:12px;font-size:18px;color:#2563eb}details[open] .faq-question::before{content:'−'}.faq-answer{padding:0 16px 16px;color:#64748b;font-size:14px;line-height:1.6}.loading-overlay{position:fixed;inset:0;z-index:200;background:rgba(15,23,42,.9);display:flex;align-items:center;justify-content:center}.loading-overlay.hidden{display:none}.loading-content{text-align:center}.loading-spinner{width:48px;height:48px;border:4px solid rgba(255,255,255,.2);border-top-color:#2563eb;border-radius:50%;animation:1s linear infinite spin;margin:0 auto}.success-overlay{position:fixed;inset:0;z-index:200;background:rgba(16,185,129,.95);display:flex;align-items:center;justify-content:center}.success-overlay.hidden{display:none}.success-checkmark{width:80px;height:80px;background:rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;animation:.3s scaleIn}.toast{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-radius:12px;box-shadow:0 10px 25px -5px rgba(0,0,0,.2);max-width:350px;animation:.3s slideInRight}.dark .toast{background:#1e293b}.toast.success{border-left:4px solid #10b981}.toast.error{border-left:4px solid #ef4444}.toast.warning{border-left:4px solid #f59e0b}.toast-message{flex:1;font-size:14px;color:#0f172a}.dark .toast-message{color:#f8fafc}.status-dot{width:8px;height:8px;border-radius:50%;background:#f59e0b;animation:2s infinite pulse}.status-dot.success{background:#10b981;animation:none}.status-dot.error{background:#ef4444;animation:none}@media (max-width:768px){.upload-zone{padding:40px 20px;min-height:300px}.crop-container{max-width:100%}}@media print{.modal,.privacy-notice,.step-indicator,.toast,button,header{display:none!important}main{padding:0!important}}::selection{background:#2563eb;color:#fff}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f5f9}.dark ::-webkit-scrollbar-track{background:#1e293b}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.dark ::-webkit-scrollbar-thumb{background:#475569}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.tool-btn{transition:.2s}.tool-btn.active{box-shadow:0 0 0 3px rgba(59,130,246,.5)}#cleanupCanvasContainer{position:relative}#cleanupCanvas{display:block;transform-origin:0 0}.brush-cursor{position:fixed;pointer-events:none;border:2px solid #ef4444;border-radius:50%;z-index:9999;transform:translate(-50%,-50%)}.brush-cursor.restore{border-color:#22c55e}.dress-thumb{transition:.2s;aspect-ratio:1;display:flex;align-items:center;justify-content:center}.dress-thumb:hover{transform:scale(1.05)}.dress-thumb.border-primary{border-color:#2563eb!important;box-shadow:0 0 0 2px rgba(37,99,235,.3)}.dress-thumb img{max-width:100%;max-height:100%;object-fit:contain}#dressOverlayContainer{transition:none}#dressDragHandle{z-index:10;pointer-events:auto}#dressDragHandle:hover{background:rgba(37,99,235,.1)}.dress-pos-btn{transition:.15s}.dress-pos-btn:active{transform:scale(.95)}