@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--primary:#6366f1;--primary-hover:#4f46e5;--primary-light:#6366f11a;--secondary:#10b981;--background:#0f172a;--surface:#1e293b;--surface-light:#334155;--text-primary:#f8fafc;--text-secondary:#94a3b8;--danger:#ef4444;--border:#ffffff1a;--glass-bg:#1e293bb3;--glass-border:#ffffff14}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--background);color:var(--text-primary);min-height:100vh;font-family:Outfit,sans-serif;overflow-x:hidden}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:16px;box-shadow:0 8px 32px #0000004d}.app-container{height:100vh;display:flex;overflow:hidden}.main-content{background:radial-gradient(circle at 100% 0,#6366f126 0%,#0000 40%),radial-gradient(circle at 0 100%,#10b9810d 0%,#0000 40%);flex-direction:column;flex:1;padding:2rem;display:flex;overflow-y:auto}.btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;font-family:Outfit,sans-serif;font-size:1rem;font-weight:500;transition:all .3s;display:inline-flex}.btn-primary{background:linear-gradient(135deg, var(--primary), var(--primary-hover));color:#fff;box-shadow:0 4px 15px #6366f166}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6366f199}.btn-primary:disabled{opacity:.5;cursor:not-allowed;background:var(--surface-light);box-shadow:none;transform:none}.btn-secondary{background:var(--surface-light);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--surface);transform:translateY(-2px)}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.4s forwards fadeIn}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.animate-slide-down{animation:.3s ease-out forwards slideDown}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--background)}::-webkit-scrollbar-thumb{background:var(--surface-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.sidebar{border-right:1px solid var(--glass-border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:10;background:#1e293bd9;border-top:none;border-bottom:none;border-left:none;border-radius:0;flex-direction:column;width:280px;height:100vh;display:flex}.sidebar-header{border-bottom:1px solid var(--glass-border);padding:2rem 1.5rem}.logo-container{align-items:center;gap:1rem;display:flex}.logo-icon{background:linear-gradient(135deg, var(--primary), var(--secondary));color:#fff;border-radius:10px;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.2rem;font-weight:700;display:flex;box-shadow:0 4px 15px #6366f14d}.logo-container h2{letter-spacing:.5px;font-size:1.4rem;font-weight:700}.logo-container span{color:var(--primary);font-weight:400}.sidebar-nav{flex-direction:column;flex:1;gap:.5rem;padding:1.5rem 1rem;display:flex}.nav-link{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:12px;align-items:center;gap:1rem;width:100%;padding:1rem 1.5rem;font-family:inherit;font-size:1rem;font-weight:500;text-decoration:none;transition:all .3s;display:flex;position:relative;overflow:hidden}.nav-link:hover{color:var(--text-primary);background:#ffffff0d;transform:translate(5px)}.nav-link.active{color:var(--text-primary);background:var(--primary-light)}.active-indicator{background:var(--primary);opacity:0;border-radius:0 4px 4px 0;width:4px;height:100%;transition:opacity .3s;position:absolute;top:0;left:0}.nav-link.active .active-indicator{opacity:1}.nav-link svg{transition:transform .3s}.nav-link:hover svg,.nav-link.active svg{color:var(--primary);transform:scale(1.1)}.sidebar-footer{border-top:1px solid var(--glass-border);padding:1.5rem}.logout-btn{color:var(--danger)}.logout-btn:hover{color:var(--danger);background:#ef44441a}.logout-btn:hover svg{color:var(--danger)}.dashboard-container{flex-direction:column;gap:2rem;display:flex}.page-header{justify-content:space-between;align-items:flex-end;display:flex}.page-header h1{margin-bottom:.5rem;font-size:2rem}.page-header p{color:var(--text-secondary)}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;display:grid}.stat-card{align-items:center;gap:1.5rem;padding:1.5rem;transition:transform .3s;display:flex}.stat-card:hover{transform:translateY(-5px)}.stat-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.stat-content h3{align-items:center;min-height:2.2rem;margin-bottom:.2rem;font-size:1.8rem;font-weight:700;display:flex}.stat-content p{color:var(--text-secondary);font-size:.9rem;font-weight:500}.stat-skeleton{background:linear-gradient(90deg,#ffffff0f 25%,#ffffff24 50%,#ffffff0f 75%) 0 0/200% 100%;border-radius:6px;width:80px;height:1.6rem;animation:1.4s infinite shimmer;display:inline-block}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.dashboard-content{grid-template-columns:1fr;gap:1.5rem;display:grid}.chart-container{flex-direction:column;min-height:160px;padding:1.5rem;display:flex}.chart-container h3{margin-bottom:1.5rem;font-size:1.2rem}.ciclo-selector-wrapper{flex-direction:column;gap:.2rem;display:flex}.ciclo-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);font-size:.7rem;font-weight:600}.ciclo-select-container{align-items:center;display:flex;position:relative}.ciclo-select{appearance:none;background:var(--glass-bg,#ffffff12);border:1px solid var(--glass-border,#ffffff26);color:var(--text-primary,#fff);cursor:pointer;border-radius:10px;min-width:110px;padding:.45rem 2.2rem .45rem .85rem;font-size:.95rem;font-weight:600;transition:border-color .2s,background .2s}.ciclo-select:hover:not(:disabled){border-color:var(--primary,#6366f1);background:#6366f11f}.ciclo-select:focus{border-color:var(--primary,#6366f1);outline:none;box-shadow:0 0 0 3px #6366f133}.ciclo-select:disabled{opacity:.5;cursor:not-allowed}.ciclo-chevron{pointer-events:none;color:var(--text-secondary);position:absolute;right:.6rem}.ciclo-select option{color:#fff;background:#1e1e2e}.upload-container{flex-direction:column;gap:2rem;width:100%;max-width:800px;margin:0 auto;display:flex}.upload-content{flex-direction:column;gap:1.5rem;display:flex}.type-selector{border-radius:12px;gap:1rem;padding:.5rem;display:flex}.type-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:1rem;font-family:inherit;font-size:1rem;font-weight:500;transition:all .3s}.type-btn:hover{color:var(--text-primary);background:#ffffff0d}.type-btn.active{background:var(--primary);color:#fff;box-shadow:0 4px 15px #6366f166}.dropzone{border:2px dashed var(--glass-border);text-align:center;cursor:pointer;justify-content:center;padding:4rem 2rem;transition:all .3s;display:flex}.dropzone:hover{border-color:var(--primary);background:#6366f10d}.dropzone.dragging{border-color:var(--primary);background:#6366f11a;transform:scale(1.02)}.dropzone-content{flex-direction:column;align-items:center;gap:1rem;display:flex}.upload-icon-wrapper{background:var(--surface-light);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:.5rem;transition:all .3s;display:flex}.dropzone:hover .upload-icon-wrapper{background:var(--primary-light);transform:translateY(-5px)}.dropzone-content h3{color:var(--text-primary);font-size:1.4rem}.dropzone-content p{color:var(--text-secondary)}.file-preview{flex-direction:column;gap:1.5rem;padding:1.5rem;animation:.3s fadeIn;display:flex}.file-info-container{justify-content:space-between;align-items:center;width:100%;display:flex}.file-info{align-items:center;gap:1rem;display:flex}.file-info h4{margin-bottom:.2rem;font-size:1.1rem}.file-info p{color:var(--text-secondary);font-size:.9rem}.remove-file-btn{color:var(--danger);cursor:pointer;background:#ef44441a;border:1px solid #ef444433;border-radius:6px;padding:.5rem 1rem;font-family:inherit;font-size:.9rem;transition:all .3s}.remove-file-btn:hover:not(:disabled){background:#ef444433}.remove-file-btn:disabled{opacity:.5;cursor:not-allowed}.process-btn{width:100%}.preview-container{flex-direction:column;gap:2rem;height:100%;display:flex}.back-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.5rem 0;font-family:inherit;font-size:.9rem;transition:color .3s;display:flex}.back-btn:hover{color:var(--primary)}.table-container{flex-direction:column;flex:1;max-height:calc(100vh - 250px);display:flex;overflow:hidden}.table-wrapper{flex:1;overflow:auto}.data-table{border-collapse:collapse;text-align:left;width:100%}.data-table th,.data-table td{border-bottom:1px solid var(--glass-border);white-space:nowrap;padding:1rem 1.5rem}.data-table th{color:#a5b4fc;z-index:1;background:#0003;font-weight:600;position:sticky;top:0}.data-table tr:hover td{background:#ffffff05}.table-footer{color:var(--text-secondary);background:#0000001a;align-items:center;gap:.5rem;padding:1rem 1.5rem;font-size:.9rem;display:flex}.actions-container{justify-content:flex-end;display:flex}.save-btn{padding:1rem 2rem;font-size:1.1rem}.spinner{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.success-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;margin-top:2rem;padding:4rem 2rem;display:flex}.success-icon-wrapper{background:var(--secondary);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:1rem;animation:.5s cubic-bezier(.175,.885,.32,1.275) popIn;display:flex;box-shadow:0 0 30px #10b98166}.success-state h2{color:var(--secondary);font-size:2rem}.success-state p{color:var(--text-secondary);font-size:1.1rem}.redirect-text{opacity:.7;margin-top:2rem;animation:2s infinite pulse;font-size:.9rem!important}.missing-programs-alert{margin-top:1rem;padding:1.5rem;background:#ef44441a!important;border:1px solid #ef44444d!important}.alert-header{align-items:center;gap:.8rem;margin-bottom:.5rem;display:flex}.alert-header h3{color:var(--danger);margin:0;font-size:1.2rem}.missing-programs-alert p{color:#fca5a5;margin-bottom:1rem}.missing-list-interactive{flex-direction:column;gap:.8rem;margin-bottom:1.5rem;padding:0;list-style-type:none;display:flex}.missing-item{color:#fff;border-left:3px solid var(--danger);background:#0003;border-radius:6px;justify-content:space-between;align-items:center;gap:1rem;padding:.8rem 1rem;display:flex}.missing-prog-name{flex:1;font-weight:500}.missing-prog-inputs{align-items:center;gap:.5rem;display:flex}.missing-prog-select{color:#fff;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:4px;outline:none;padding:.6rem;font-family:inherit;font-size:.9rem}.missing-prog-select option{background:var(--surface);color:#fff}.missing-prog-input{color:#fff;background:#ffffff1a;border:1px solid #fff3;border-radius:4px;width:180px;padding:.6rem 1rem;font-family:inherit;font-size:.9rem;transition:all .3s}.missing-prog-input:focus{border-color:var(--primary);background:#ffffff26;outline:none}.missing-actions{justify-content:flex-end;display:flex}@keyframes popIn{0%{transform:scale(0)}80%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes pulse{0%{opacity:.5}50%{opacity:1}to{opacity:.5}}.actions-container{justify-content:flex-end;gap:1rem;margin-top:2rem;display:flex}.sql-preview-container{border-left:4px solid var(--primary);margin-top:2rem;margin-bottom:2rem;padding:1.5rem}.sql-preview-container .alert-header h3{color:var(--primary)}.sql-preview-container p{color:var(--text-secondary);margin-bottom:1rem}.sql-preview-code{color:#a6accd;background:#1e1e2e;border:1px solid #ffffff1a;border-radius:6px;margin-top:1rem;padding:1.5rem;font-family:Consolas,Monaco,monospace;font-size:.9rem;overflow-x:auto;box-shadow:inset 0 2px 4px #0000004d}.login-container{z-index:1000;background:radial-gradient(circle at 100% 0,#6366f126 0%,#0000 40%),radial-gradient(circle at 0 100%,#10b9810d 0%,#0000 40%);background-color:var(--background);justify-content:center;align-items:center;width:100vw;min-height:100vh;display:flex;position:fixed;top:0;left:0}.login-card{flex-direction:column;gap:2rem;width:100%;max-width:400px;padding:3rem 2rem;display:flex}.login-header{text-align:center;flex-direction:column;align-items:center;gap:.5rem;display:flex}.login-header .logo-icon{width:60px;height:60px;margin-bottom:.5rem;font-size:1.5rem}.login-header h2{font-size:1.8rem}.login-header h2 span{color:var(--primary);font-weight:400}.login-header p{color:var(--text-secondary)}.login-form{flex-direction:column;gap:1.5rem;display:flex}.input-group{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-secondary);position:absolute;left:1rem}.input-group input{border:1px solid var(--glass-border);width:100%;color:var(--text-primary);background:#0003;border-radius:8px;outline:none;padding:1rem 1rem 1rem 3rem;font-family:inherit;font-size:1rem;transition:all .3s}.input-group input:focus{border-color:var(--primary);background:#0006}.login-btn{margin-top:1rem;padding:1rem;font-size:1.1rem}.error-message{color:#fca5a5;border-left:4px solid var(--danger);background:#ef44441a;border-radius:8px;padding:1rem;font-size:.9rem}.fotos-container{flex-direction:column;gap:2rem;width:100%;max-width:960px;margin:0 auto;display:flex}.fotos-content{flex-direction:column;gap:1.5rem;display:flex}.foto-dropzone{border:2px dashed var(--glass-border);text-align:center;cursor:default;padding:3rem 2rem;transition:all .3s;position:relative}.foto-dropzone.dragging{border-color:var(--primary);background:#6366f114;transform:scale(1.01)}.foto-dropzone-inner{flex-direction:column;align-items:center;gap:.8rem;display:flex}.foto-upload-icon-wrapper{background:var(--surface-light);border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:.5rem;transition:all .3s;display:flex}.foto-dropzone.dragging .foto-upload-icon-wrapper{background:var(--primary-light);transform:translateY(-4px)}.foto-dropzone-inner h3{color:var(--text-primary);font-size:1.3rem}.foto-dropzone-inner p{color:var(--text-secondary);font-size:.95rem}.foto-btn-row{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:.5rem;display:flex}.foto-hint{color:var(--text-secondary);opacity:.7;font-size:.8rem!important}.error-message{border-left:4px solid var(--danger);color:#fca5a5;background:#ef44441a;align-items:center;gap:.8rem;padding:1rem 1.5rem;display:flex}.fotos-settings-panel{flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.settings-header{align-items:center;gap:.6rem;display:flex}.settings-header h4{color:var(--text-primary);font-size:1rem;font-weight:600}.settings-controls{flex-wrap:wrap;align-items:center;gap:2rem;display:flex}.checkbox-wrapper{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.6rem;display:flex}.checkbox-wrapper input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:var(--primary)}.checkbox-label{color:var(--text-primary);font-size:.95rem}.manual-input-wrapper{border:1px solid var(--glass-border);background:#ffffff0d;border-radius:8px;align-items:center;height:40px;padding:0 .8rem;transition:all .3s;display:flex}.manual-input-wrapper:focus-within{border-color:var(--primary);background:#ffffff14}.input-prefix,.input-suffix{color:var(--text-secondary);opacity:.6;font-family:monospace;font-size:.9rem}.manual-suffix-input{color:var(--primary);background:0 0;border:none;outline:none;width:120px;padding:0 4px;font-family:monospace;font-weight:600}.settings-hint{color:var(--text-secondary);margin:0;font-size:.8rem}.fotos-summary{flex-wrap:wrap;align-items:center;gap:2rem;padding:1.2rem 1.8rem;display:flex}.summary-stat{flex-direction:column;align-items:center;gap:.2rem;display:flex}.stat-num{color:var(--text-primary);font-size:1.6rem;font-weight:700}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:.8rem}.summary-stat.success .stat-num{color:var(--secondary)}.summary-stat.error .stat-num{color:var(--danger)}.summary-stat.pending .stat-num{color:var(--primary)}.summary-actions{flex-wrap:wrap;gap:.8rem;margin-left:auto;display:flex}.fotos-table-wrapper{padding:0;overflow:auto}.fotos-table{border-collapse:collapse;width:100%;font-size:.9rem}.fotos-table thead tr{border-bottom:1px solid var(--glass-border);background:#ffffff0a}.fotos-table th{text-align:left;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;padding:1rem 1.2rem;font-size:.75rem;font-weight:600}.fotos-table td{vertical-align:middle;border-bottom:1px solid #ffffff0a;padding:.8rem 1.2rem}.fotos-table tbody tr:last-child td{border-bottom:none}.fotos-table tbody tr:hover{background:#ffffff05}.fotos-table tbody tr.row-success{background:#10b9810a}.fotos-table tbody tr.row-error{background:#ef44440a}.row-num{color:var(--text-secondary);width:40px;font-size:.8rem}.row-filename{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:240px;overflow:hidden}.row-code .code-badge{background:var(--primary-light);color:var(--primary);border:1px solid #6366f140;border-radius:6px;padding:.2rem .6rem;font-family:monospace;font-size:.85rem;font-weight:600;display:inline-block}.row-size{color:var(--text-secondary);font-size:.85rem}.status-badge{border-radius:99px;align-items:center;gap:.4rem;padding:.25rem .7rem;font-size:.82rem;font-weight:500;display:inline-flex}.status-pending{color:var(--primary);background:#6366f11a}.status-uploading{color:var(--primary);background:#6366f126}.status-success{color:var(--secondary);background:#10b9811f}.status-error{color:var(--danger);white-space:nowrap;text-overflow:ellipsis;background:#ef44441a;max-width:220px;overflow:hidden}.remove-row-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:.3rem;transition:all .2s;display:flex}.remove-row-btn:hover:not(:disabled){color:var(--danger);background:#ef444426}.remove-row-btn:disabled{opacity:.3;cursor:not-allowed}.spin{animation:.8s linear infinite spin}
