@tailwind base;@tailwind components;@tailwind utilities;:root{--bg-primary:#0f1117;--bg-secondary:#161821;--bg-tertiary:#1c1e2a;--bg-hover:#1f2233;--bg-active:#3b82f614;--border:#ffffff0f;--border-active:#3b82f640;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--text-muted:#475569;--text-accent:#60a5fa;--accent:#3b82f6;--accent-glow:#3b82f626;--sidebar-width:260px;--header-height:52px;--footer-height:44px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}.app-root{width:100vw;height:100vh;display:flex}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;height:100vh;display:flex;overflow:hidden}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:20px 18px 16px;display:flex}.brand-icon{border-radius:var(--radius-md);background:var(--accent);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;box-shadow:0 4px 12px #3b82f640}.brand-name{letter-spacing:-.3px;color:#fff;font-size:16px;font-weight:700}.brand-sub{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);font-size:10px;font-weight:600}.sidebar-search{border-bottom:1px solid var(--border);padding:12px 14px;position:relative}.sidebar-search-icon{color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:24px;transform:translateY(-50%)}.sidebar-search input{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);outline:none;padding:8px 10px 8px 32px;font-size:12px;transition:border-color .2s}.sidebar-search input:focus{border-color:var(--accent)}.sidebar-search input::placeholder{color:var(--text-muted)}.sidebar-nav{flex:1;padding:8px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:0 0}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff0f;border-radius:4px}.nav-group{margin-bottom:4px}.nav-group-header{width:100%;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:8px 10px;font-size:10px;font-weight:700;transition:color .15s;display:flex}.nav-group-header:hover{color:var(--text-secondary)}.nav-group-header .chevron{margin-left:auto;transition:transform .2s}.nav-group-header .chevron.open{transform:rotate(0)}.nav-group-header .chevron:not(.open){transform:rotate(-90deg)}.nav-group-items{padding:2px 0 6px}.nav-item{width:100%;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:7px 12px 7px 26px;font-size:12px;font-weight:500;transition:all .15s;display:flex;position:relative}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.active{background:var(--bg-active);color:var(--text-accent);font-weight:600}.nav-item .active-dot{background:var(--accent);width:5px;height:5px;box-shadow:0 0 6px var(--accent);border-radius:50%;margin-left:auto}.sidebar-footer{border-top:1px solid var(--border);padding:12px 18px}.sidebar-stat{color:var(--text-muted);gap:6px;font-size:11px;display:flex}.content{background:var(--bg-primary);flex-direction:column;flex:1;height:100vh;display:flex;overflow:hidden}.content-header{height:var(--header-height);min-height:var(--header-height);border-bottom:1px solid var(--border);background:var(--bg-secondary);justify-content:space-between;align-items:center;gap:16px;padding:0 20px;display:flex}.header-left{align-items:center;gap:12px;display:flex}.header-breadcrumb{color:var(--text-muted);align-items:center;gap:6px;font-size:13px;display:flex}.header-table-name{color:var(--text-primary);font-weight:600}.header-badge{color:var(--text-muted);background:var(--bg-tertiary);border:1px solid var(--border);border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:11px;font-weight:500;display:flex}.schema-badge{color:var(--text-accent);background:var(--accent-glow);border-color:var(--border-active)}.header-right{align-items:center;gap:8px;display:flex}.header-search{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);align-items:center;gap:6px;padding:0 10px;transition:border-color .2s;display:flex}.header-search:focus-within{border-color:var(--accent)}.header-search input{color:var(--text-primary);background:0 0;border:none;outline:none;width:180px;padding:7px 4px;font-size:12px}.header-search input::placeholder{color:var(--text-muted)}.btn-icon{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;transition:all .15s;display:flex}.btn-icon:hover{background:var(--bg-hover);color:var(--text-primary);border-color:#ffffff1a}.table-wrapper{flex:1;position:relative;overflow:hidden}.table-scroll{width:100%;height:100%;overflow:auto}.table-scroll::-webkit-scrollbar{width:6px;height:6px}.table-scroll::-webkit-scrollbar-track{background:var(--bg-primary)}.table-scroll::-webkit-scrollbar-thumb{background:#ffffff0f;border-radius:4px}.table-scroll::-webkit-scrollbar-thumb:hover{background:#ffffff1f}table{border-collapse:collapse;table-layout:auto;width:100%;font-size:13px}thead{z-index:10;position:sticky;top:0}th{text-align:left;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--bg-tertiary);border-bottom:1px solid var(--border);white-space:nowrap;cursor:pointer;-webkit-user-select:none;user-select:none;padding:10px 14px;font-size:11px;font-weight:600;transition:background .15s}th:hover{background:var(--bg-hover);color:var(--text-secondary)}.th-content{align-items:center;gap:5px;display:flex}.sort-icon{opacity:.2;transition:opacity .15s}th:hover .sort-icon{opacity:.5}.sort-icon.active{opacity:1;color:var(--accent)}td{border-bottom:1px solid var(--border);color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;max-width:300px;padding:9px 14px;overflow:hidden}tr:hover td{background:var(--bg-hover);color:var(--text-primary)}.row-num{color:var(--text-muted);font-variant-numeric:tabular-nums;text-align:center;width:48px;min-width:48px;font-size:11px;font-weight:500}th.row-num{cursor:default}th.row-num:hover{background:var(--bg-tertiary)}.null-val{color:var(--text-muted);opacity:.5;font-size:10px;font-style:italic}.empty-state{text-align:center;color:var(--text-muted);font-size:13px;padding:60px 20px!important}.loading-state{height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:13px;display:flex}.table-footer{height:var(--footer-height);min-height:var(--footer-height);border-top:1px solid var(--border);background:var(--bg-secondary);color:var(--text-muted);justify-content:space-between;align-items:center;padding:0 20px;font-size:12px;display:flex}.pagination{align-items:center;gap:4px;display:flex}.pagination button{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;justify-content:center;align-items:center;transition:all .15s;display:flex}.pagination button:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.pagination button:disabled{opacity:.3;cursor:default}.page-info{color:var(--text-secondary);padding:0 10px;font-size:12px;font-weight:500}.btn{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;align-items:center;gap:6px;padding:6px 14px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:#2563eb;box-shadow:0 2px 8px #3b82f64d}.btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-danger{color:#fff;background:#dc2626;border-color:#dc2626}.btn-danger:hover{background:#b91c1c}.btn-icon-sm{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:4px;display:flex}.btn-icon-sm:hover{color:var(--text-primary);background:var(--bg-hover)}.actions-col{text-align:center;width:60px;min-width:60px;cursor:default!important}.actions-col:hover{background:var(--bg-tertiary)!important}.actions-cell{text-align:center;width:60px}.btn-delete{border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-muted);cursor:pointer;opacity:0;background:0 0;border:1px solid #0000;justify-content:center;align-items:center;transition:all .15s;display:inline-flex}tr:hover .btn-delete{opacity:1}.btn-delete:hover{color:#ef4444;background:#dc26261a;border-color:#dc26264d}.cell-display{cursor:default;align-items:center;gap:6px;min-height:22px;display:flex}.cell-edit-icon{opacity:0;color:var(--text-muted);flex-shrink:0;transition:opacity .15s}tr:hover .cell-edit-icon{opacity:.3}.cell-display:hover .cell-edit-icon{opacity:.7}.cell-input{background:var(--bg-primary);border:1px solid var(--accent);width:100%;min-width:80px;color:var(--text-primary);border-radius:4px;outline:none;padding:4px 8px;font-size:13px;box-shadow:0 0 0 2px #3b82f626}.row-saving td{background:var(--accent-glow)!important}.add-row-panel{border-bottom:1px solid var(--border);background:var(--bg-secondary)}.add-row-header{color:var(--text-primary);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:12px 20px;font-size:13px;font-weight:600;display:flex}.add-row-header .btn-icon-sm{margin-left:auto}.add-row-fields{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;max-height:200px;padding:14px 20px;display:grid;overflow-y:auto}.add-row-fields::-webkit-scrollbar{width:4px}.add-row-fields::-webkit-scrollbar-thumb{background:#ffffff0f;border-radius:4px}.add-row-field label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-bottom:4px;font-size:10px;font-weight:600;display:block}.add-row-field input{background:var(--bg-tertiary);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:4px;outline:none;padding:6px 10px;font-size:12px;transition:border-color .15s}.add-row-field input:focus{border-color:var(--accent)}.add-row-field input::placeholder{color:var(--text-muted)}.add-row-actions{border-top:1px solid var(--border);justify-content:flex-end;gap:8px;padding:10px 20px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;width:380px;padding:28px}.modal-icon{color:#ef4444;background:#dc26261a;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 16px;display:flex}.modal h3{margin-bottom:8px;font-size:16px;font-weight:700}.modal p{color:var(--text-secondary);margin-bottom:24px;font-size:13px;line-height:1.5}.modal-actions{justify-content:center;gap:8px;display:flex}.modal-actions .btn{flex:1;justify-content:center;padding:8px 16px}.toast-container{z-index:200;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;right:20px}.toast{border-radius:var(--radius-md);align-items:center;gap:8px;padding:10px 16px;font-size:12px;font-weight:500;animation:.3s toast-in;display:flex;box-shadow:0 4px 12px #0000004d}.toast-success{color:#d1fae5;background:#065f46;border:1px solid #059669}.toast-error{color:#fecaca;background:#7f1d1d;border:1px solid #dc2626}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.footer-hint{color:var(--text-muted);font-size:11px;font-style:italic}.sidebar-user{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;font-weight:500;display:flex}.sidebar-user .btn-icon-sm{margin-left:auto}.sidebar-user .btn-icon-sm+.btn-icon-sm{margin-left:0}.login-page{background:var(--bg-primary);background-image:radial-gradient(at 20%,#3b82f614 0%,#0000 50%),radial-gradient(at 80% 20%,#8b5cf60f 0%,#0000 50%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);width:380px;overflow:hidden}.login-header{text-align:center;flex-direction:column;align-items:center;padding:36px 28px 20px;display:flex}.login-header h1{letter-spacing:-.5px;margin-top:16px;font-size:22px;font-weight:700}.login-header p{color:var(--text-muted);margin-top:6px;font-size:13px}.login-form{flex-direction:column;gap:14px;padding:0 28px 28px;display:flex}.login-field label{text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);align-items:center;gap:6px;margin-bottom:6px;font-size:11px;font-weight:600;display:flex}.login-field input{background:var(--bg-tertiary);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);outline:none;padding:10px 14px;font-size:13px;transition:border-color .2s}.login-field input:focus{border-color:var(--accent)}.login-field input::placeholder{color:var(--text-muted)}.password-input-wrap{position:relative}.password-input-wrap input{padding-right:40px}.pw-toggle{color:var(--text-muted);cursor:pointer;background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.pw-toggle:hover{color:var(--text-secondary)}.login-btn{background:var(--accent);border-radius:var(--radius-sm);color:#fff;cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;width:100%;margin-top:6px;padding:11px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.login-btn:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 12px #3b82f64d}.login-btn:disabled{opacity:.5;cursor:default}.login-error{border-radius:var(--radius-sm);color:#fca5a5;background:#dc26261a;border:1px solid #dc262633;align-items:center;gap:8px;padding:10px 14px;font-size:12px;font-weight:500;display:flex}.login-footer{border-top:1px solid var(--border);color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;justify-content:center;align-items:center;gap:6px;padding:14px;font-size:10px;display:flex}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}
