: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}#app{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.vanilla:hover{filter:drop-shadow(0 0 2em #3178c6aa)}.card{padding:2em}.read-the-docs{color:#888}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:hover{border-color:#646cff}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:#747bff}button{background-color:#f9f9f9}}.data-layout{display:flex;gap:2rem;align-items:flex-start}.photo-preview-large{min-width:320px;max-width:480px;flex:0 0 320px;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;background:#ffffff08;border-radius:8px;padding:1rem;box-shadow:0 2px 12px #00000012}.photo-preview-large img.zoomable{max-width:100%;max-height:60vh;border-radius:8px;box-shadow:0 2px 8px #0000001f;cursor:zoom-in;transition:transform .2s;background:#222}.photo-preview-large img.zoomable:active{cursor:zoom-out}.photo-meta{margin-top:.5rem;color:#ccc;font-size:1rem;text-align:center}.data-form-table{flex:1 1 0%;min-width:0}@media (max-width: 900px){.data-layout{flex-direction:column;gap:1rem}.photo-preview-large{max-width:100%;min-width:0;width:100%;margin-bottom:1rem}}:root{font-family:Inter,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:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}#app{max-width:1200px;margin:0 auto;padding:2rem;width:100%}.container{display:flex;flex-direction:column;gap:2rem}.section{background:#ffffff0d;border-radius:8px;padding:1.5rem;border:1px solid rgba(255,255,255,.1)}.section h2{margin-top:0;color:#fff;font-size:1.5em}.upload-area{border:2px dashed #646cff;border-radius:8px;padding:2rem;text-align:center;transition:all .3s ease;cursor:pointer;position:relative;min-height:200px;display:flex;align-items:center;justify-content:center}.upload-area:hover{border-color:#535bf2;background-color:#646cff0d}.upload-area.drag-over{border-color:#535bf2;background-color:#535bf226;transform:scale(1.02);box-shadow:0 4px 20px #535bf24d}.upload-area.drag-over:before{content:"📎 Suelta la imagen aquí";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.2rem;font-weight:700;color:#535bf2;background:#535bf21a;padding:1rem 2rem;border-radius:8px;z-index:10}.upload-area.drag-over .upload-content{opacity:.3}.upload-content{transition:opacity .3s ease}.upload-hint{font-size:.9rem;color:#fff9;margin:.5rem 0}.upload-button{background:#646cff;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-size:1rem;transition:background-color .3s}.upload-button:hover{background:#535bf2}.upload-button:disabled{background:#444;cursor:not-allowed}.file-preview{margin-top:1rem;display:flex;align-items:center;gap:1rem}.file-preview img{max-width:200px;max-height:150px;border-radius:4px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500}.form-group input{padding:.75rem;border:1px solid rgba(255,255,255,.2);border-radius:4px;background:#ffffff0d;color:#fff;font-size:1rem}.form-group input:focus{outline:none;border-color:#646cff}.table-container{overflow-x:auto;margin:1rem 0}.data-table{width:100%;border-collapse:collapse;background:#ffffff05;border-radius:4px;overflow:hidden}.data-table th,.data-table td{padding:.75rem;text-align:left;border-bottom:1px solid rgba(255,255,255,.1)}.data-table th,.data-table td{padding:2px 6px;text-align:left;border-bottom:1px solid rgba(255,255,255,.1)}.data-table input:focus{outline:none;border-bottom-color:#646cff}.table-controls{display:flex;gap:.5rem;margin-bottom:.25rem}.btn{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .3s}.btn-secondary{background:#ffffff1a;color:#fff}.btn-secondary:hover{background:#fff3}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover{background:#c82333}.submit-section{text-align:center}.submit-button{background:#28a745;color:#fff;border:none;padding:1rem 2rem;border-radius:4px;cursor:pointer;font-size:1.1rem;font-weight:600;transition:background-color .3s}.submit-button:hover{background:#218838}.submit-button:disabled{background:#444;cursor:not-allowed}.loading{display:flex;align-items:center;justify-content:center;gap:.5rem;color:#646cff}.spinner{width:20px;height:20px;border:2px solid rgba(100,108,255,.3);border-radius:50%;border-top-color:#646cff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.error{background:#dc35451a;border:1px solid rgba(220,53,69,.3);color:#dc3545;padding:1rem;border-radius:4px;margin:1rem 0}.success{background:#28a7451a;border:1px solid rgba(40,167,69,.3);color:#28a745;padding:1rem;border-radius:4px;margin:1rem 0}@media (max-width: 768px){#app{padding:1rem}.form-grid{grid-template-columns:1fr}.table-controls{flex-direction:column}.data-table{font-size:.9rem}}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}.section{background:#00000005;border:1px solid rgba(0,0,0,.1)}.section h2{color:#213547}.upload-hint{color:#0009}.form-group input{background:#00000005;color:#213547;border:1px solid rgba(0,0,0,.1)}.data-table{background:#00000003}.data-table th{background:#0000000d}.data-table input{color:#213547}}.upload-area{position:relative;border:2px dashed #ccc;border-radius:8px;padding:2rem;text-align:center;background:#fafafa;transition:all .3s ease;cursor:pointer}.upload-area:hover{border-color:#1976d2;background:#f0f7ff}.upload-area.drag-over{border-color:#1976d2;background:#e3f2fd}.upload-area--disabled{opacity:.6;cursor:not-allowed;pointer-events:none}.upload-input{display:none}.upload-content{margin-bottom:1rem}.upload-hint{font-size:.9rem;color:#666;margin-top:.5rem}.upload-button{background:#1976d2;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:4px;cursor:pointer;font-weight:600;transition:background .3s ease}.upload-button:hover:not(:disabled){background:#1565c0}.upload-button:disabled{background:#ccc;cursor:not-allowed}.file-preview{display:flex;align-items:center;gap:1rem;padding:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-top:1rem}.file-preview__image{width:60px;height:60px;object-fit:cover;border-radius:4px}.file-preview__info{flex:1;text-align:left}.file-preview__name,.file-preview__size{margin:.25rem 0}.photo-preview-large{flex:1;max-width:40%}.photo-preview-container{position:relative;overflow:hidden;max-width:100%;max-height:60vh;border-radius:8px;background:#f5f5f5}.zoomable{display:block;max-width:100%;max-height:60vh;-webkit-user-select:none;user-select:none;touch-action:none;cursor:grab}.zoomable:active{cursor:grabbing}.photo-meta{margin-top:1rem;padding:1rem;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.photo-meta__name,.photo-meta__size{margin:.25rem 0}.data-layout{display:flex;gap:2rem;margin-top:1rem}.data-form-table{flex:1;max-width:50%}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:2rem}.form-group{display:flex;flex-direction:column}.form-label{color:#222;font-weight:600;margin-bottom:.5rem}.form-input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.form-input:focus{outline:none;border-color:#1976d2;box-shadow:0 0 0 2px #1976d233}.table-container{overflow-x:auto;border-radius:8px;box-shadow:0 2px 4px #0000001a}.data-table{width:100%;border-collapse:collapse;font-size:.95em;background:#fff}.table-header{padding:8px 12px;border:1px solid #ccc;background:#f7f7f7;text-align:left}.table-header-input{width:90px;padding:4px 8px;border:none;background:transparent;font-size:inherit;font-weight:600}.table-header-input:focus{outline:1px solid #1976d2;background:#fff}.table-cell{padding:4px 8px;border:1px solid #ddd}.table-cell--center{text-align:center;justify-content:center;align-items:center}.table-cell-input{width:80px;padding:4px 8px;border:none;background:transparent;font-size:inherit}.table-cell-input:focus{outline:1px solid #1976d2;background:#fff}.table-add-row{padding:1rem;text-align:center;background:#fafafa}.btn{border:none;border-radius:4px;cursor:pointer;font-weight:600;transition:all .3s ease;justify-content:center;display:inline-block}.btn-primary{background:#1976d2;color:#fff;padding:.5rem 1rem}.btn-primary:hover{background:#1565c0}.btn-success{background:#388e3c;color:#fff;padding:.5rem 1rem}.btn-success:hover{background:#2e7d32}.btn-danger{background:#d32f2f;color:#fff;padding:.25rem .5rem;font-size:.9em}.btn-danger:hover{background:#c62828}.submit-section{text-align:center;padding:2rem}.submit-button{background:#1976d2;color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.submit-button:hover:not(:disabled){background:#1565c0;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.submit-button:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.loading{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1rem;color:#1976d2;font-weight:600}.spinner{width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #1976d2;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.success{background:#e8f5e8;color:#2e7d32;padding:1rem;border-radius:8px;margin-bottom:1rem;font-weight:600}.error{background:#ffebee;color:#c62828;padding:1rem;border-radius:8px;margin-top:1rem;font-weight:600}.section{margin-bottom:2rem;padding:2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a}.section--disabled{opacity:.5}.section h2{margin-top:0;color:#333;border-bottom:2px solid #1976d2;padding-bottom:.5rem}.section h3{color:#555;margin-bottom:1rem}@media (max-width: 768px){.data-layout{flex-direction:column}.photo-preview-large,.data-form-table{max-width:100%}.form-grid{grid-template-columns:1fr}.table-container{font-size:.8rem}.table-header-input,.table-cell-input{width:60px}}
