.image-cropper-modal{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1000;display:flex;align-items:center;justify-content:center}.cropper-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000c}.cropper-container{position:relative;background:#fff;border-radius:8px;max-width:90vw;max-height:90vh;width:800px;z-index:1001;display:flex;flex-direction:column}.cropper-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid #e5e7eb}.cropper-header h3{margin:0;font-size:1.25rem;font-weight:600}.close-btn{background:none;border:none;font-size:2rem;cursor:pointer;color:#6b7280;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-btn:hover{background:#f3f4f6;color:#1f2937}.cropper-content{padding:1.5rem;overflow:auto}.cropper-preview-container{position:relative;width:100%;max-height:500px;margin-bottom:1.5rem;border:1px solid #e5e7eb;border-radius:6px;overflow:hidden;background:#f9fafb}.cropper-canvas{display:block;max-width:100%;height:auto}.crop-overlay{position:absolute;top:0;left:0;background:#00000080;cursor:move}.crop-box{position:absolute;border:2px solid #3b82f6;background:transparent;cursor:move;box-shadow:0 0 0 9999px #00000080}.crop-handle{position:absolute;width:12px;height:12px;background:#3b82f6;border:2px solid white;border-radius:50%}.crop-handle-nw{top:-6px;left:-6px;cursor:nw-resize}.crop-handle-ne{top:-6px;right:-6px;cursor:ne-resize}.crop-handle-sw{bottom:-6px;left:-6px;cursor:sw-resize}.crop-handle-se{bottom:-6px;right:-6px;cursor:se-resize}.cropper-controls{margin-bottom:1.5rem}.control-group{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.control-group label{font-size:.875rem;color:#374151}.zoom-slider{flex:1;max-width:200px}.cropper-actions{display:flex;gap:1rem;justify-content:flex-end}.btn-cancel,.btn-confirm,.btn-use-original{padding:.75rem 1.5rem;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-cancel{background:#f3f4f6;color:#1f2937}.btn-cancel:hover{background:#e5e7eb}.btn-use-original{background:#10b981;color:#fff}.btn-use-original:hover{background:#059669}.btn-confirm{background:#3b82f6;color:#fff}.btn-confirm:hover{background:#2563eb}.qr-drawer{position:fixed;inset:0;z-index:1000;pointer-events:none;opacity:0;transition:opacity .3s ease}.qr-drawer.open{opacity:1;pointer-events:all}.drawer-overlay{position:absolute;inset:0;background-color:#00000080;backdrop-filter:blur(4px)}.drawer-content{position:absolute;top:0;right:0;bottom:0;width:100%;max-width:600px;background:#fff;box-shadow:-4px 0 12px #00000026;display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s ease;overflow-y:auto}.qr-drawer.open .drawer-content{transform:translate(0)}.drawer-header{padding:1.5rem;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;background:#fff;position:sticky;top:0;z-index:10}.drawer-header h2{font-size:1.5rem;font-weight:600;color:#1f2937;margin:0}.drawer-close{background:none;border:none;cursor:pointer;padding:.5rem;color:#6b7280;transition:color .2s;display:flex;align-items:center;justify-content:center}.drawer-close:hover{color:#1f2937}.drawer-body{padding:2rem;flex:1}.drawer-result{margin-top:2rem;padding-top:2rem;border-top:1px solid #e5e7eb}.drawer-success{text-align:center}.success-icon{font-size:3rem;margin-bottom:1rem}.drawer-success h3{font-size:1.25rem;color:#1f2937;margin-bottom:1.5rem}.qr-display-mini{background:#f9fafb;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem}.qr-image-mini{width:200px;height:200px;margin:0 auto 1rem;display:block}.qr-info-mini{text-align:center}.qr-code-text{color:#6b7280;font-size:.875rem;margin-bottom:.5rem}.qr-url{margin-top:.5rem}.qr-url a{color:#3b82f6;text-decoration:none;word-break:break-all;font-size:.875rem}.qr-url a:hover{text-decoration:underline}.drawer-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-primary{padding:.75rem 1.5rem;background-color:#3b82f6;color:#fff;text-decoration:none;border-radius:6px;font-weight:600;transition:background-color .2s;display:inline-block;border:none;cursor:pointer;font-size:1rem}.btn-primary:hover{background-color:#2563eb}.btn-secondary{padding:.75rem 1.5rem;background-color:#fff;color:#3b82f6;text-decoration:none;border-radius:6px;font-weight:600;border:2px solid #3b82f6;transition:all .2s;display:inline-block;cursor:pointer;font-size:1rem}.btn-secondary:hover{background-color:#3b82f6;color:#fff}.timer{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background-color:#eff6ff;border:1px solid #3b82f6;border-radius:6px;font-weight:600;margin-top:1rem}.timer-active{display:flex;align-items:center;gap:.5rem;color:#1e40af}.timer-expired{display:flex;align-items:center;gap:.5rem;color:#991b1b}.timer.expired{background-color:#fee2e2;border-color:#ef4444}.timer-icon{font-size:1.25rem}.timer-text{font-size:.875rem;white-space:nowrap}.module-selector{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #e5e7eb}.module-selector h3{font-size:1.125rem;font-weight:600;color:#1f2937;margin-bottom:1rem}.module-options{display:flex;flex-direction:column;gap:.75rem}.module-option{display:block;cursor:pointer}.module-option input[type=radio]{display:none}.module-option-content{display:flex;align-items:center;gap:1rem;padding:1rem;border:2px solid #e5e7eb;border-radius:8px;transition:all .2s;background-color:#fff}.module-option:hover .module-option-content{border-color:#3b82f6;background-color:#eff6ff}.module-option input[type=radio]:checked+.module-option-content{border-color:#3b82f6;background-color:#eff6ff;box-shadow:0 0 0 3px #3b82f61a}.module-icon{font-size:2rem;flex-shrink:0}.module-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.module-info strong{font-size:1rem;color:#1f2937;display:block}.module-info span{font-size:.875rem;color:#6b7280}.custom-slug-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #e5e7eb}.custom-slug-intro{font-size:.875rem;color:#6b7280;margin:0;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.custom-slug-toggle{background:none;border:none;color:#3b82f6;font-size:.875rem;font-weight:600;cursor:pointer;padding:0;text-decoration:underline;transition:color .2s;font-family:inherit}.custom-slug-toggle:hover{color:#2563eb}.custom-slug-panel{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.custom-slug-field{margin-bottom:1.5rem}.custom-slug-field:last-child{margin-bottom:0}.custom-slug-name-input{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:6px;font-size:.875rem;color:#1f2937;background-color:#fff;transition:border-color .2s;font-family:inherit}.custom-slug-name-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.custom-slug-label{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem}.custom-slug-label>span:first-child{font-size:1rem;font-weight:600;color:#1f2937}.custom-slug-hint{font-size:.875rem;color:#6b7280;font-weight:400}.custom-slug-input-wrapper{display:flex;align-items:center;border:2px solid #e5e7eb;border-radius:6px;background-color:#fff;transition:border-color .2s}.custom-slug-input-wrapper:focus-within{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.custom-slug-prefix{padding:.75rem .5rem .75rem .75rem;color:#6b7280;font-size:.875rem;white-space:nowrap;user-select:none}.custom-slug-input{flex:1;border:none;outline:none;padding:.75rem;font-size:.875rem;color:#1f2937;background:transparent}.custom-slug-help{margin-top:.5rem;font-size:.75rem;color:#6b7280}.custom-slug-error{margin-top:.5rem;padding:.75rem;background-color:#fee2e2;color:#991b1b;border-radius:6px;font-size:.875rem;border:1px solid #fecaca}.upload-zone{width:100%;max-width:600px;margin:2rem auto}.upload-area{border:2px dashed #e5e7eb;border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:all .2s;background-color:#f9fafb}.upload-area:hover{border-color:#3b82f6;background-color:#eff6ff}.upload-area.dragover{border-color:#3b82f6;background-color:#dbeafe}.upload-icon{color:#6b7280;margin-bottom:1rem}.upload-area h3{font-size:1.25rem;margin-bottom:.5rem;color:#1f2937}.upload-area p{color:#6b7280;margin-bottom:.5rem}.file-info{font-size:.875rem;margin-top:.5rem}.upload-progress{margin-top:1rem}.progress-bar{width:100%;height:8px;background-color:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background-color:#3b82f6;transition:width .3s;width:0%}.progress-text{text-align:center;color:#6b7280;font-size:.875rem}.error-message{margin-top:1rem;padding:1rem;background-color:#fee2e2;color:#991b1b;border-radius:4px;border:1px solid #fecaca}@media(max-width:768px){.cropper-container{width:95vw;max-height:95vh}.cropper-preview-container{max-height:300px}.drawer-content{max-width:100%}.drawer-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%}.custom-slug-prefix{font-size:.75rem;padding:.75rem .25rem .75rem .5rem}.custom-slug-input{font-size:.8125rem}}.drawer-content-advanced{max-width:700px}.drawer-body-advanced{padding:1.5rem}.step-container{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.step-header{text-align:center;margin-bottom:2rem;position:relative}.step-header h3{font-size:1.5rem;color:#1f2937;margin:.5rem 0}.step-header p{color:#6b7280;font-size:.875rem;margin-top:.5rem}.step-number{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.btn-back{position:absolute;top:0;left:0;background:#f3f4f6;border:none;padding:.5rem 1rem;border-radius:6px;color:#374151;font-weight:500;cursor:pointer;transition:all .2s;font-size:.875rem}.btn-back:hover{background:#e5e7eb;transform:translate(-2px)}.modules-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-top:1.5rem}.module-card{background:#fff;border:2px solid #e5e7eb;border-radius:8px;padding:1.25rem 1rem;text-align:center;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden}.module-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--module-color);transform:scaleX(0);transition:transform .3s ease}.module-card:hover{border-color:var(--module-color);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.module-card:hover:before{transform:scaleX(1)}.module-icon{font-size:2rem;margin-bottom:.5rem}.module-card h4{font-size:1rem;color:#1f2937;margin:.25rem 0;font-weight:600}.module-card p{color:#6b7280;font-size:.75rem;line-height:1.4;margin:0}.config-section{max-width:100%}.config-item{margin-bottom:1.5rem}.config-label{display:block;font-size:.875rem;font-weight:600;color:#374151;margin-bottom:.5rem}.config-hint{font-size:.75rem;color:#6b7280;margin-top:.25rem;line-height:1.4}.config-input{width:100%;padding:.625rem;border:2px solid #e5e7eb;border-radius:6px;font-size:.875rem;transition:border-color .2s;box-sizing:border-box}.config-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.config-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer}.config-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer}.file-upload-area{position:relative}.file-input{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden}.file-label{display:block;border:2px dashed #d1d5db;border-radius:8px;padding:1.5rem;text-align:center;cursor:pointer;transition:all .2s;background:#f9fafb}.file-label:hover{border-color:#667eea;background:#f3f4f6}.file-placeholder{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#6b7280;font-size:.875rem}.upload-icon{font-size:2rem}.file-selected{display:flex;align-items:center;gap:.5rem;background:#fff;padding:.75rem;border-radius:6px;border:1px solid #e5e7eb}.file-icon{font-size:1.25rem}.file-name{flex:1;color:#1f2937;font-weight:500;text-align:left;font-size:.875rem}.file-size{color:#6b7280;font-size:.75rem}.file-remove{background:#ef4444;color:#fff;border:none;width:20px;height:20px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:.625rem;transition:background .2s}.file-remove:hover{background:#dc2626}.files-list{margin-top:.75rem;display:flex;flex-direction:column;gap:.5rem}.file-item{display:flex;align-items:center;gap:.5rem;background:#f9fafb;padding:.5rem .75rem;border-radius:6px;border:1px solid #e5e7eb;font-size:.875rem}.btn-generate{width:100%;padding:.875rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;margin-top:.5rem}.btn-generate:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.btn-generate:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#fee2e2;color:#991b1b;padding:.75rem;border-radius:6px;margin-bottom:1rem;border:1px solid #fecaca;font-size:.875rem}.drawer-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap;margin-top:1.5rem}.btn-primary,.btn-secondary{padding:.625rem 1.25rem;border-radius:6px;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;transition:all .2s;border:none;cursor:pointer;font-size:.875rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.btn-secondary{background:#f3f4f6;color:#374151}.btn-secondary:hover{background:#e5e7eb}@media(max-width:768px){.modules-grid{grid-template-columns:repeat(2,1fr)}.drawer-actions{flex-direction:column}.btn-primary,.btn-secondary{width:100%;justify-content:center}}.upload-cta{text-align:center;padding:3rem 2rem;background:linear-gradient(135deg,#f9fafb,#f3f4f6);border-radius:12px;border:2px dashed #d1d5db}.upload-cta h2{font-size:2rem;color:#1f2937;margin-bottom:.5rem}.upload-cta p{color:#6b7280;font-size:1.125rem;margin-bottom:2rem}.btn-create-qr-large{display:inline-flex;align-items:center;gap:.75rem;padding:1.25rem 2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:1.25rem;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #667eea4d}.btn-create-qr-large:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.btn-icon-large{font-size:1.5rem}.btn-hero-primary{padding:1rem 2rem;background-color:#fff;color:#667eea;text-decoration:none;border:none;border-radius:8px;font-weight:600;font-size:1.125rem;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 6px #0000001a;cursor:pointer}.btn-hero-primary:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}
