*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.container{margin:0 auto;max-width:1200px;padding:20px}.card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px;padding:20px}.btn{border:none;border-radius:4px;cursor:pointer;font-size:14px;padding:10px 20px;transition:all .3s ease}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover{background-color:#0056b3}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}input,select,textarea{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:10px;width:100%}input:focus,select:focus,textarea:focus{border-color:#007bff;outline:none}.loading{min-height:200px}.login-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh}.login-container{max-width:400px;padding:20px;width:100%}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;padding:40px}.login-card h1{color:#333;font-size:28px;margin-bottom:8px;text-align:center}.login-card .subtitle{color:#666;font-size:14px;margin-bottom:30px;text-align:center}.form-group{margin-bottom:20px}.form-group label{color:#333;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-group input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:12px;transition:border-color .3s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.btn-login{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;margin-top:10px;padding:12px;transition:opacity .3s;width:100%}.btn-login:hover:not(:disabled){opacity:.9}.btn-login:disabled{cursor:not-allowed;opacity:.6}.error{color:#dc3545;font-size:12px;margin-top:4px}.dashboard-page{background-color:#f5f5f5;min-height:100vh}.dashboard-header{margin-bottom:30px}.dashboard-header h1{color:#333;font-size:32px;margin-bottom:8px}.dashboard-header p{color:#666;font-size:16px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{align-items:center;gap:15px;padding:20px;transition:transform .3s,box-shadow .3s}.stat-card:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.stat-icon{font-size:40px}.stat-content{flex:1 1}.stat-label{color:#666;font-size:14px;margin-bottom:4px}.stat-value{color:#333;font-size:28px;margin-bottom:4px}.stat-detail{color:#888;font-size:12px;font-style:italic;margin-top:4px}.info-section{margin-top:30px}.text-muted{color:#999;margin-top:10px}.migrations-page{margin:0 auto;max-width:1400px;padding:2rem}.page-header{margin-bottom:2rem}.page-header h1{color:#2c3e50;font-size:2rem;margin-bottom:.5rem}.page-header p{color:#7f8c8d;font-size:1rem}.migrations-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;flex-direction:column;gap:.5rem;padding:1.5rem}.stat-label{color:#7f8c8d;font-size:.875rem;letter-spacing:.5px;text-transform:uppercase}.stat-value{color:#2c3e50;font-size:2rem;font-weight:700}.stat-value.success{color:#27ae60}.stat-value.pending{color:#f39c12}.migrations-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem;overflow:hidden}.migrations-table{border-collapse:collapse;width:100%}.migrations-table thead{background:#f8f9fa;border-bottom:2px solid #e9ecef}.migrations-table th{color:#495057;font-size:.875rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.migrations-table tbody tr{border-bottom:1px solid #e9ecef;transition:background-color .2s}.migrations-table tbody tr:hover{background-color:#f8f9fa}.migrations-table tbody tr.executed{opacity:.8}.migrations-table td{color:#495057;padding:1rem}.migration-name code{background:#f1f3f5;border-radius:4px;color:#e83e8c;font-family:Courier New,monospace;font-size:.875rem;padding:.25rem .5rem}.migration-description{max-width:400px}.migration-date,.migration-duration,.migration-executor{color:#6c757d;font-size:.875rem}.migration-action{text-align:center}.badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.375rem .75rem;text-transform:uppercase}.badge-success{background-color:#d4edda;color:#155724}.badge-error{background-color:#f8d7da;color:#721c24;cursor:help}.badge-pending{background-color:#fff3cd;color:#856404}.badge-recurrent{background-color:#e1f5fe;color:#01579b}.badge-normal{background-color:#f3e5f5;color:#4a148c}.btn-execute,.btn-retry{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.btn-execute{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-execute:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.btn-execute:disabled{cursor:not-allowed;opacity:.6}.btn-execute.executing{background:linear-gradient(135deg,#a8b5e8,#b09bcc)}.btn-retry{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.btn-retry:hover:not(:disabled){box-shadow:0 4px 12px #f5576c66;transform:translateY(-2px)}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:14px;width:14px}@keyframes spin{to{transform:rotate(1turn)}}.migrations-info{background:#e3f2fd;border-left:4px solid #2196f3;border-radius:8px;padding:1.5rem}.migrations-info h3{color:#1565c0;font-size:1.1rem;margin-bottom:1rem;margin-top:0}.migrations-info ul{color:#1565c0;margin:0;padding-left:1.5rem}.migrations-info li{margin-bottom:.5rem}.empty-state{color:#6c757d;font-style:italic;padding:3rem 1rem!important;text-align:center}.text-muted{color:#adb5bd}@media (max-width:768px){.migrations-page{padding:1rem}.migrations-table-container{overflow-x:auto}.migrations-table{min-width:800px}.migrations-stats{grid-template-columns:1fr}}.logs-page{padding:20px}.logs-header{margin-bottom:30px}.logs-header h1{color:#1f2937;font-size:28px;margin-bottom:8px}.logs-header p{color:#6b7280;font-size:14px}.logs-controls{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;gap:20px;margin-bottom:20px;padding:20px}.control-group,.logs-controls{align-items:center;display:flex}.control-group{gap:10px}.control-group label{color:#374151;font-size:14px;font-weight:500}.control-group select{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 12px}.control-group select:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.control-group input[type=checkbox]{cursor:pointer;height:18px;width:18px}.btn-refresh{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;margin-left:auto;padding:8px 16px;transition:all .2s}.btn-refresh:hover{background:#5568d3;transform:translateY(-1px)}.loading{color:#6b7280;padding:40px;text-align:center}.logs-container{background:#1f2937;border-radius:8px;box-shadow:0 1px 3px #0000001a;max-height:calc(100vh - 350px);overflow-y:auto;padding:20px}.no-logs{color:#9ca3af;padding:40px;text-align:center}.logs-list{font-family:Courier New,monospace;font-size:13px}.log-entry{align-items:flex-start;background:#1f293780;border-left:3px solid;border-radius:4px;display:flex;gap:12px;margin-bottom:4px;padding:8px 12px}.log-entry:hover{background:#374151cc}.log-level{border-radius:4px;color:#fff;display:inline-block;flex-shrink:0;font-size:11px;font-weight:600;padding:2px 8px}.log-message{color:#e5e7eb;line-height:1.5;word-break:break-all}.logs-container::-webkit-scrollbar{width:8px}.logs-container::-webkit-scrollbar-track{background:#374151;border-radius:4px}.logs-container::-webkit-scrollbar-thumb{background:#6b7280;border-radius:4px}.logs-container::-webkit-scrollbar-thumb:hover{background:#9ca3af}.navbar{background:#fff;box-shadow:0 2px 4px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:100}.navbar-container{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1200px;padding:15px 20px}.navbar-brand h2{color:#333;font-size:20px;margin:0}.navbar-menu{align-items:center;display:flex;gap:20px}.navbar-admin{align-items:flex-end;display:flex;flex-direction:column}.admin-name{color:#333;font-size:14px;font-weight:600}.admin-role{color:#666;font-size:12px;text-transform:capitalize}.btn-logout{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .3s}.btn-logout:hover{background-color:#c82333}.sidebar{background:#fff;border-right:1px solid #e9ecef;min-height:calc(100vh - 60px);padding:1.5rem 0;width:250px}.sidebar-nav{display:flex;flex-direction:column;gap:.5rem;padding:0 1rem}.sidebar-link{align-items:center;border-radius:8px;color:#495057;display:flex;font-weight:500;gap:1rem;padding:.875rem 1rem;text-decoration:none;transition:all .2s}.sidebar-link:hover{background-color:#f8f9fa;color:#667eea}.sidebar-link.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.sidebar-icon{font-size:1.25rem}.sidebar-label{font-size:.9375rem}@media (max-width:768px){.sidebar{border-bottom:1px solid #e9ecef;border-right:none;min-height:auto;padding:1rem 0;width:100%}.sidebar-nav{flex-direction:row;justify-content:space-around}.sidebar-label{display:none}.sidebar-link{justify-content:center;padding:.75rem}}.App{min-height:100vh}.loading{align-items:center;color:#666;font-size:18px;justify-content:center}.dashboard-layout,.loading{display:flex;min-height:100vh}.dashboard-layout{flex-direction:column}.layout-content{background:#f5f7fa;display:flex;flex:1 1}.main-content{flex:1 1;min-height:calc(100vh - 60px);overflow-y:auto}@media (max-width:768px){.layout-content{flex-direction:column}}