.admin-layout{max-width:800px;margin:0 auto;padding:2rem 1rem;width:100%}.dashboard-layout{max-width:1100px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.admin-header h1{font-size:1.5rem;font-weight:600;color:var(--text-heading);display:flex;align-items:center;gap:.5rem}.nav-mascot{width:28px;height:28px;object-fit:contain}.admin-nav{display:flex;align-items:center;gap:.75rem}.nav-link{text-decoration:none;color:var(--text-muted);font-size:.9rem;padding:.4rem .8rem;border-radius:6px;transition:background .15s,color .15s}.nav-link:hover{background:var(--hover-bg);color:var(--text)}.nav-link.active{background:#4f46e5;color:#fff}.admin-card{background:var(--bg-card);border-radius:8px;padding:1.5rem;box-shadow:0 1px 3px var(--shadow)}.admin-card dt{font-size:.85rem;color:var(--text-muted);margin-bottom:.25rem}.admin-card dd{font-size:1.1rem;font-weight:500;margin-bottom:1rem}.admin-card dd:last-child{margin-bottom:0}.btn{display:inline-block;padding:.6rem 1.2rem;border:none;border-radius:6px;font-size:.95rem;cursor:pointer;text-decoration:none;transition:background .15s}.btn-primary{background:#4f46e5;color:#fff}.btn-primary:hover{background:#4338ca}.btn-secondary{background:var(--btn-secondary-bg);color:var(--btn-secondary-text)}.btn-secondary:hover{background:var(--hover-bg)}.btn:disabled{opacity:.5;cursor:not-allowed}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1.5rem}.login-page h1{font-size:1.8rem;font-weight:600;color:var(--text-heading)}.error-message{color:#dc2626;font-size:.9rem}.loading{color:var(--text-muted);font-size:.95rem}.metric-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem;margin-bottom:2rem}.metric-card{background:var(--bg-card);border-radius:8px;padding:1.25rem;box-shadow:0 1px 3px var(--shadow);display:flex;flex-direction:column;gap:.25rem}.metric-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em}.metric-value{font-size:1.6rem;font-weight:700;color:var(--text-heading)}.chart-section{background:var(--bg-card);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 1px 3px var(--shadow)}.chart-section h2{font-size:1rem;font-weight:600;margin-bottom:1rem}.data-table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.85rem}.data-table th,.data-table td{text-align:left;padding:.6rem .75rem;border-bottom:1px solid var(--border);white-space:nowrap;max-width:250px;overflow:hidden;text-overflow:ellipsis}.data-table th{background:var(--table-header-bg);font-weight:600;color:var(--text-muted);position:sticky;top:0;font-size:.8rem;text-transform:uppercase;letter-spacing:.02em}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th.sortable:hover,.data-table tbody tr:hover{background:var(--hover-bg)}.truncate{max-width:200px;overflow:hidden;text-overflow:ellipsis}.null-value{color:var(--null-color);font-style:italic}.fk-link{color:#4f46e5;text-decoration:none;font-family:monospace;font-size:.8rem}.fk-link:hover{text-decoration:underline}.fk-badge{display:inline-block;font-size:.6rem;background:var(--fk-badge-bg);color:#4f46e5;padding:.1rem .3rem;border-radius:3px;margin-left:.3rem;vertical-align:middle}.detail-link{color:#4f46e5;text-decoration:none;font-size:.85rem}.detail-link:hover{text-decoration:underline}.empty-row{text-align:center;color:var(--text-muted);padding:2rem!important}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem}.page-info{font-size:.9rem;color:var(--text-muted)}.table-browser-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.75rem}.table-browser-header h2{font-size:1.1rem;font-weight:600}.row-count{font-weight:400;color:var(--text-muted);font-size:.9rem}.search-input{padding:.5rem .75rem;border:1px solid var(--input-border);border-radius:6px;font-size:.9rem;width:220px;background:var(--input-bg);color:var(--text)}.search-input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e526}.back-link{color:#4f46e5;text-decoration:none}.back-link:hover{text-decoration:underline}.table-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.table-card-link{text-decoration:none;color:inherit}.table-card{background:var(--bg-card);border-radius:8px;padding:1.25rem;box-shadow:0 1px 3px var(--shadow);transition:box-shadow .15s,transform .15s}.table-card:hover{box-shadow:0 4px 12px var(--shadow);transform:translateY(-1px)}.table-card h3{font-size:1rem;font-weight:600;margin-bottom:.25rem}.table-col-count{font-size:.8rem;color:var(--text-muted)}.row-detail dl{margin:0}.detail-row{display:flex;padding:.6rem 0;border-bottom:1px solid var(--border);gap:1rem}.detail-row:last-child{border-bottom:none}.detail-row dt{min-width:160px;font-size:.85rem;color:var(--text-muted);font-weight:500}.detail-row dd{font-size:.9rem;word-break:break-all;margin:0}.theme-toggle{background:none;border:1px solid var(--border);border-radius:6px;padding:.4rem .6rem;cursor:pointer;font-size:1rem;line-height:1;color:var(--text-muted);transition:background .15s,border-color .15s}.theme-toggle:hover{background:var(--hover-bg);border-color:var(--text-muted)}[data-theme=dark]{--bg: #0f1117;--bg-card: #1a1b23;--text: #e4e4e7;--text-muted: #9ca3af;--text-heading: #f4f4f5;--border: #2e2f3a;--hover-bg: #23242f;--shadow: rgba(0, 0, 0, .4);--table-header-bg: #16171f;--input-bg: #1a1b23;--input-border: #3f4050;--null-color: #555;--fk-badge-bg: #2e2b5e;--btn-secondary-bg: #2e2f3a;--btn-secondary-text: #d4d4d8}[data-theme=light]{--bg: #f5f5f7;--bg-card: #fff;--text: #1a1a2e;--text-muted: #666;--text-heading: #1a1a2e;--border: #e0e0e0;--hover-bg: #f0f0f0;--shadow: rgba(0, 0, 0, .1);--table-header-bg: #f9fafb;--input-bg: #fff;--input-border: #d1d5db;--null-color: #ccc;--fk-badge-bg: #e0e7ff;--btn-secondary-bg: #e5e5e5;--btn-secondary-text: #333}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6;color:var(--text);background:var(--bg);min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}
