.app{background:linear-gradient(135deg,#667eea,#764ba2);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh}.main-content{margin:0 auto;max-width:1200px;padding:20px}.container{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;margin-top:20px;padding:30px}.page-title{color:#2d3748;font-size:2.5rem;font-weight:700;margin-bottom:10px;text-align:center}.page-subtitle{color:#718096;font-size:1.1rem;text-align:center}.form-section,.generate-section,.page-subtitle{margin-bottom:30px}.preview-section{border-top:2px solid #e2e8f0;margin-top:30px;padding-top:30px}.loading-container{color:#fff;min-height:100vh}.loading-container p{font-size:1.2rem;margin-top:20px}.spinner{border:4px solid #ffffff4d;border-top-color:#fff}@media (max-width:768px){.main-content{padding:10px}.container{margin-top:10px;padding:20px}.page-title{font-size:2rem}}.product-form{margin:0 auto;max-width:800px}.form{display:flex;flex-direction:column;gap:30px}.form-section{background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;padding:24px}.form-section h3{align-items:center;color:#2d3748;display:flex;font-size:1.25rem;font-weight:600;gap:8px;margin:0 0 20px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{color:#4a5568;font-size:.9rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:12px 16px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background:#f7fafc;cursor:not-allowed;opacity:.6}.form-group textarea{min-height:80px;resize:vertical}.form-actions{display:flex;justify-content:center;margin-top:20px}.generate-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;min-width:200px;padding:16px 32px;transition:transform .2s ease,box-shadow .2s ease}.generate-button:hover:not(:disabled){box-shadow:0 8px 25px #667eea4d;transform:translateY(-2px)}.generate-button:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.form-row{gap:16px;grid-template-columns:1fr}.form-section{padding:20px}.generate-button{min-width:auto;width:100%}}.qr-preview{background:#f0fff4;border:2px solid #68d391;border-radius:12px;margin-bottom:30px;padding:24px}.qr-preview h3{color:#22543d;font-size:1.5rem;font-weight:700;margin:0 0 20px;text-align:center}.preview-container{grid-gap:30px;align-items:start;display:grid;gap:30px;grid-template-columns:1fr 1fr}.qr-code-section{align-items:center;flex-direction:column;gap:20px}.qr-code-wrapper{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 12px #0000001a;padding:20px}.qr-code-image{display:block;height:200px;width:200px}.qr-info{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px;text-align:center;width:100%}.qr-info h4{color:#2d3748;font-size:1.2rem;font-weight:600;margin:0 0 15px}.qr-info p{color:#4a5568;font-size:.9rem;margin:8px 0}.qr-url{border-radius:4px;font-family:monospace;font-size:.8rem;padding:4px 8px;word-break:break-all}.copy-button{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;margin-top:15px;padding:10px 20px;transition:background .3s ease}.copy-button:hover{background:#5a67d8}.product-details{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px}.product-details h4{color:#2d3748;font-size:1.2rem;font-weight:600;margin:0 0 20px}.details-grid{grid-gap:16px;gap:16px}.detail-item{border-radius:8px;padding:12px}@media (max-width:768px){.preview-container{gap:20px;grid-template-columns:1fr}.qr-code-image{height:150px;width:150px}.detail-item{gap:5px;grid-template-columns:1fr}}.map-modal-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.map-modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-height:90vh;max-width:800px;overflow-y:auto;width:100%}.map-modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px}.map-modal-header h3{color:#2d3748;font-size:1.25rem;margin:0}.map-modal-close{align-items:center;background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;display:flex;font-size:2rem;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.map-modal-close:hover{background:#f7fafc;color:#2d3748}.map-modal-body{padding:20px}.map-address,.map-coordinates{background:#f7fafc;border-radius:6px;color:#4a5568;font-size:.95rem;margin-bottom:15px;padding:12px}.map-address strong,.map-coordinates strong{color:#2d3748;margin-right:8px}.map-container{border:1px solid #e2e8f0;border-radius:8px;margin:20px 0;overflow:hidden}.map-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:15px}.map-external-link{align-items:center;background:#667eea;border-radius:6px;color:#fff;display:inline-flex;font-size:.9rem;padding:10px 16px;text-decoration:none;transition:all .2s ease}.map-external-link:hover{background:#5a67d8;box-shadow:0 4px 12px #667eea4d;transform:translateY(-1px)}@media (max-width:768px){.map-modal-content{margin:10px;max-width:100%}.map-actions{flex-direction:column}.map-external-link{justify-content:center;width:100%}}.print-layout{background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;padding:24px}.print-layout h3{color:#2d3748;font-size:1.25rem;font-weight:600;margin:0 0 20px}.print-controls{background:#fff}.print-preview{margin-bottom:30px}.print-preview h4{color:#2d3748;font-size:1.1rem;font-weight:600;margin:0 0 15px}.preview-container{max-height:500px}.print-actions{text-align:center}.print-button{border-radius:12px;font-size:1.1rem;margin-bottom:10px;padding:16px 32px;transition:transform .2s ease,box-shadow .2s ease}.print-button:hover{box-shadow:0 8px 25px #48bb784d;transform:translateY(-2px)}.print-note{color:#718096;font-size:.9rem;margin:0}@media print{.print-actions,.print-controls,.print-layout h3,.print-preview h4{display:none!important}.print-content{margin:0!important;padding:0!important;width:100%!important}.qr-grid{gap:10px!important;padding:10px!important}.qr-item{background:#fff!important;border:1px solid #000!important;page-break-inside:avoid}.preview-container{background:#fff!important;border:none!important;padding:0!important}}@media (max-width:768px){.print-controls{gap:15px;grid-template-columns:1fr 1fr}.qr-grid{gap:15px;padding:15px}.qr-size-small .qr-image{height:60px;width:60px}.qr-size-medium .qr-image{height:80px;width:80px}.qr-size-large .qr-image{height:100px;width:100px}}.qr-management{margin:0 auto;max-width:1200px}.management-header{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:30px}.search-controls{flex:1 1;min-width:300px}.search-input{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;padding:12px 16px;width:100%}.search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.sort-controls{display:flex;gap:10px}.sort-controls select{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:.9rem;padding:10px 12px}.sort-controls select:focus{border-color:#667eea;outline:none}.qr-codes-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.qr-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 4px 12px #0000001a;box-sizing:border-box;cursor:pointer;overflow:hidden;padding:20px;transition:transform .2s ease,box-shadow .2s ease;width:100%}.qr-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.qr-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:15px}.product-name{flex:1 1;font-size:1.2rem;font-weight:700;margin:0}.qr-actions{display:flex;gap:8px}.action-button{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:1rem;padding:8px;transition:all .2s ease}.action-button:hover{background:#edf2f7;border-color:#cbd5e0}.action-button.copy:hover{background:#e6fffa;border-color:#4fd1c7}.action-button.delete:hover{background:#fed7d7;border-color:#feb2b2}.qr-card-content{box-sizing:border-box}.qr-card-content,.qr-code-section{margin-bottom:15px;min-width:0;width:100%}.qr-code-section{align-items:flex-start;display:flex;flex-direction:row;gap:15px}.qr-code-image{border:1px solid #e2e8f0;border-radius:8px;flex-shrink:0;height:80px;width:80px}.qr-info{flex:1 1;overflow:hidden;text-align:left}.qr-dates,.qr-info,.qr-notes{margin-bottom:12px;min-width:0}.qr-dates,.qr-notes{width:100%}.qr-dates p,.qr-info p,.qr-notes p{word-wrap:break-word;color:#4a5568;font-size:.9rem;margin:4px 0;overflow-wrap:break-word}.qr-dates strong,.qr-info strong,.qr-notes strong{color:#2d3748;font-weight:600}.qr-card-footer{border-top:1px solid #e2e8f0;padding-top:15px}.qr-stats{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.scan-count{color:#667eea;font-size:.9rem;font-weight:600}.created-date{color:#718096;font-size:.8rem}.qr-url{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:10px;padding:8px}.url-text{color:#4a5568;font-family:monospace;font-size:.8rem;word-break:break-all}.click-hint{text-align:center}.hint-text{color:#667eea;font-size:.8rem;font-style:italic}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000004d;max-height:90vh;max-width:800px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:20px}.modal-header h2{color:#2d3748;font-size:1.5rem;margin:0}.close-button{background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;font-size:1.5rem;padding:5px}.close-button:hover{background:#f7fafc;color:#2d3748}.modal-body{padding:20px}.qr-detail-section{grid-gap:30px;display:grid;gap:30px;grid-template-columns:1fr 1fr}.qr-code-large{text-align:center}.large-qr-image{border:2px solid #e2e8f0;border-radius:12px;height:200px;margin-bottom:20px;width:200px}.qr-url-section{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:15px}.qr-url-section p{color:#2d3748;font-weight:600;margin:0 0 10px}.url-container{align-items:center;display:flex;gap:10px}.qr-url-text{color:#4a5568;flex:1 1;font-family:monospace;font-size:.9rem;word-break:break-all}.copy-url-button{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.8rem;padding:8px 12px;white-space:nowrap}.copy-url-button:hover{background:#5a67d8}.product-details-section h3{color:#2d3748;font-size:1.2rem;margin:0 0 20px}.details-grid{grid-gap:12px;display:grid;gap:12px}.detail-item{grid-gap:10px;background:#f7fafc;border-radius:6px;display:grid;gap:10px;grid-template-columns:1fr 1fr;padding:10px}.detail-item.full-width{grid-template-columns:1fr}.detail-item .label{color:#4a5568;font-size:.9rem;font-weight:600}.detail-item .value{color:#2d3748;font-size:.9rem}.modal-footer{border-top:1px solid #e2e8f0;display:flex;gap:15px;justify-content:space-between;padding:20px}.print-button{background:linear-gradient(135deg,#48bb78,#38a169);border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-weight:600;padding:12px 24px}.print-button:hover{box-shadow:0 4px 12px #48bb784d;transform:translateY(-1px)}.delete-button{background:#e53e3e;border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-weight:600;padding:12px 24px}.delete-button:hover{background:#c53030;transform:translateY(-1px)}.print-config-section{border-top:2px solid #e2e8f0;margin-top:30px;padding-top:30px}.print-config-section h3{color:#2d3748;font-size:1.25rem;font-weight:600;margin:0 0 20px}.print-controls{grid-gap:20px;background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:30px;padding:20px}.control-group{display:flex;flex-direction:column;gap:8px}.control-group label{color:#4a5568;font-size:.9rem;font-weight:600}.control-group select{background:#fff;border:2px solid #e2e8f0;border-radius:6px;font-size:.9rem;padding:8px 12px}.control-group select:focus{border-color:#667eea;outline:none}.control-group input[type=checkbox]{margin-right:8px}.print-preview-section{margin-bottom:20px}.print-preview-section h4{color:#2d3748;font-size:1.1rem;font-weight:600;margin:0 0 15px}.preview-container{background:#fff;border:2px solid #e2e8f0;border-radius:8px;max-height:400px;overflow:auto;padding:20px}.print-content{width:100%}.qr-grid{grid-gap:20px;background:#fff;display:grid;gap:20px;padding:20px}.qr-item{align-items:center;background:#fafafa;border:1px solid #e2e8f0;border-radius:8px;display:flex;flex-direction:column;justify-content:center;padding:15px}.qr-image{display:block;margin-bottom:10px}.qr-size-small .qr-image{height:80px;width:80px}.qr-size-medium .qr-image{height:120px;width:120px}.qr-size-large .qr-image{height:160px;width:160px}.qr-label{font-size:.8rem;text-align:center}.product-name{color:#2d3748;font-weight:600;margin-bottom:4px}.brand-sku{color:#718096;font-size:.7rem}@media print{.modal-overlay{background:none;padding:0;position:static}.modal-content{border-radius:0;box-shadow:none;max-height:none}.modal-footer,.modal-header,.print-config-section{display:none!important}.qr-detail-section{gap:20px;grid-template-columns:1fr}.large-qr-image{height:150px;width:150px}.qr-grid{gap:10px!important;padding:10px!important}.qr-item{background:#fff!important;border:1px solid #000!important;page-break-inside:avoid}.preview-container{background:#fff!important;border:none!important;padding:0!important}}.empty-state{background:#f7fafc;border:2px dashed #cbd5e0;border-radius:12px;grid-column:1/-1;padding:60px 20px;text-align:center}.empty-icon{font-size:4rem;margin-bottom:20px}.empty-state h3{color:#2d3748;font-size:1.5rem;font-weight:700;margin:0 0 10px}.empty-state p{color:#718096;font-size:1rem;margin:0}.loading-container{align-items:center;color:#718096;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.loading-container .spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;height:40px;margin-bottom:20px;width:40px}.error-message{background:#fed7d7;border:1px solid #feb2b2;border-radius:8px;margin-bottom:20px;padding:16px;text-align:center}.error-message p{color:#c53030;font-weight:600;margin:0}@media (max-width:768px){.management-header{align-items:stretch;flex-direction:column}.search-controls{min-width:auto}.sort-controls{justify-content:center}.qr-codes-grid{grid-template-columns:1fr}.qr-stats{align-items:flex-start;flex-direction:column;gap:8px}}.app-header{background:#fff;box-shadow:0 2px 10px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-container{height:70px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 20px}.header-container,.header-left{align-items:center;display:flex}.header-left{gap:20px}.back-button{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;color:#4a5568;cursor:pointer;font-weight:500;padding:8px 16px;transition:all .3s ease}.back-button:hover{background:#edf2f7;border-color:#cbd5e0}.app-logo{align-items:center;display:flex;gap:12px}.logo-icon{font-size:1.5rem}.logo-text{color:#2d3748;font-size:1.25rem;font-weight:700}.header-center{display:flex;flex:1 1;justify-content:center}.tab-navigation{background:#f7fafc;border-radius:12px;display:flex;gap:4px;padding:4px}.tab-button{background:#0000;border:none;border-radius:8px;color:#718096;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease}.tab-button.active{background:#fff;box-shadow:0 2px 8px #0000001a;color:#2d3748}.tab-button:hover:not(.active){color:#2d3748}.header-right{align-items:center;display:flex;gap:20px}.user-info{align-items:flex-end;display:flex;flex-direction:column}.user-name{color:#2d3748;font-size:.9rem;font-weight:600}.user-email{color:#718096;font-size:.8rem}.logout-button{background:#e53e3e;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:600;padding:8px 16px;transition:background .3s ease}.logout-button:hover{background:#c53030}@media (max-width:768px){.header-container{height:60px;padding:0 15px}.header-left{gap:10px}.back-button{font-size:.9rem;padding:6px 12px}.logo-text{font-size:1.1rem}.tab-navigation{padding:2px}.tab-button{font-size:.9rem;padding:8px 16px}.user-info{display:none}.logout-button{font-size:.9rem;padding:6px 12px}}.oauth2-container{align-items:center;display:flex;justify-content:center;min-height:400px;padding:2rem}.auth-container{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:400px;padding:2rem;text-align:center;width:100%}.auth-container h3{color:#2d3748;font-size:1.5rem;font-weight:600;margin-bottom:1rem}.auth-container p{color:#718096;line-height:1.5;margin-bottom:2rem}.auth-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:all .3s ease;width:100%}.auth-button:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.auth-button:active{transform:translateY(0)}.loading-container{padding:2rem;text-align:center}.spinner{height:40px;margin:0 auto 1rem;width:40px}.error-container{background:#fed7d7;border:1px solid #feb2b2;border-radius:8px;padding:1.5rem;text-align:center}.error-container h3{color:#c53030;margin-bottom:1rem}.error-container p{color:#742a2a;margin-bottom:1rem}.retry-button{background:#e53e3e;border-radius:6px;font-size:.9rem;font-weight:500;padding:8px 16px}.retry-button:hover{background:#c53030}.oauth2-callback-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.callback-content{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;max-width:400px;padding:3rem;text-align:center;width:100%}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:50px;margin:0 auto 2rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-icon,.success-icon{font-size:3rem;margin-bottom:1.5rem}.callback-content h2{color:#2d3748;font-size:1.5rem;font-weight:600;margin-bottom:1rem}.callback-content p{color:#718096;line-height:1.5;margin-bottom:2rem}.retry-button{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:12px 24px;transition:background-color .2s ease}.retry-button:hover{background:#5a67d8}
/*# sourceMappingURL=main.39057ffa.css.map*/