* { box-sizing: border-box; }
body {
  font-family: system-ui, sans-serif;
  background: #0a0a14;
  color: #e6e6f0;
  margin: 0;
}
a { color: #6fa8ff; }

/* Login screen */
.login-screen { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 2rem; }
.login-card { background: #14141f; border-radius: 16px; padding: 2.5rem; max-width: 420px; width: 100%; }
.login-card h1 { margin: 0 0 0.25rem; }
.login-card label { display: block; margin: 1rem 0 0.5rem; font-size: 0.85rem; color: #9a9ab0; }
.login-card input { width: 100%; padding: 0.6rem; border-radius: 6px; border: 1px solid #2a2a3a; background: #1a1a28; color: inherit; }
.divider { text-align: center; color: #6a6a80; font-size: 0.8rem; margin: 1.25rem 0 0.75rem; }
.btn-google { display: flex; align-items: center; justify-content: center; gap: 0.6rem; background: white; color: #1a1a28; padding: 0.65rem; border-radius: 8px; text-decoration: none; font-weight: 600; margin-top: 1rem; }

/* Dashboard shell */
.dashboard-screen { display: flex; min-height: 100vh; }
.sidebar { width: 240px; background: #0e0e18; padding: 1.5rem 1rem; display: flex; flex-direction: column; border-right: 1px solid #1e1e2e; }
.sidebar h2 { margin: 0 0 1.5rem; padding-left: 0.5rem; }
.sidebar nav { display: flex; flex-direction: column; gap: 0.25rem; flex: 1; }
.nav-item { text-align: left; background: none; border: none; color: #c0c0d0; padding: 0.7rem 0.8rem; border-radius: 8px; cursor: pointer; font-size: 0.95rem; }
.nav-item:hover { background: #1a1a28; }
.nav-item.active { background: #2f6fed; color: white; }
.btn-logout { background: none; border: 1px solid #2a2a3a; color: #c0c0d0; padding: 0.6rem; border-radius: 8px; cursor: pointer; }

.content { flex: 1; padding: 2rem 2.5rem; overflow-y: auto; }
.content h1 { margin-top: 0; }
.view { max-width: 1000px; }

.section-title { font-size: 1rem; color: #9a9ab0; margin: 1.75rem 0 0.75rem; }
.cards-row { display: flex; gap: 1rem; flex-wrap: wrap; }
.stat-card { background: #14141f; border-radius: 12px; padding: 1.25rem 1.5rem; min-width: 180px; }
.stat-label { display: block; color: #9a9ab0; font-size: 0.8rem; margin-bottom: 0.4rem; }
.stat-value { font-size: 1.4rem; font-weight: 600; }

.card { background: #14141f; border-radius: 12px; padding: 1.5rem; margin-bottom: 1.25rem; }
.card h2 { margin-top: 0; }

.profile-row { display: flex; align-items: center; gap: 1rem; margin-bottom: 1rem; }
.avatar { width: 56px; height: 56px; border-radius: 50%; background: #2a2a3a; }
.profile-name { font-size: 1.1rem; font-weight: 600; }
.profile-email { color: #9a9ab0; font-size: 0.9rem; }

.kv-table { width: 100%; border-collapse: collapse; }
.kv-table td { padding: 0.5rem 0; border-bottom: 1px solid #2a2a3a; }
.kv-table td:first-child { color: #9a9ab0; width: 40%; }

.row { display: flex; gap: 0.5rem; margin-bottom: 0.5rem; }
.row input, .row select { flex: 1; padding: 0.5rem; border-radius: 6px; border: 1px solid #2a2a3a; background: #1a1a28; color: inherit; }
.field-label { display: block; color: #9a9ab0; font-size: 0.8rem; margin: 1rem 0 0.4rem; }
.json-input { width: 100%; font-family: ui-monospace, monospace; font-size: 0.8rem; padding: 0.6rem; border-radius: 6px; border: 1px solid #2a2a3a; background: #0e0e18; color: #c0e8c0; margin-bottom: 0.5rem; }
button { padding: 0.5rem 1rem; border-radius: 6px; border: none; background: #2f6fed; color: white; cursor: pointer; }
button:disabled { opacity: 0.5; cursor: default; }
.btn-secondary { background: #2a2a3a; margin-bottom: 0.75rem; }
.hint { color: #9a9ab0; font-size: 0.85rem; }
.status { font-size: 0.85rem; margin-top: 0.5rem; min-height: 1em; }
.status.error { color: #f0637a; }
.status.ok { color: #7fd1a0; }

.data-table { width: 100%; border-collapse: collapse; margin-top: 0.5rem; }
.data-table th, .data-table td { padding: 0.5rem; border-bottom: 1px solid #2a2a3a; text-align: left; font-size: 0.9rem; }
.data-table th { color: #9a9ab0; font-weight: 500; }
.data-table a { cursor: pointer; }

.subtabs { display: flex; gap: 0.5rem; margin-bottom: 1rem; }
.subtab-item { background: #14141f; color: #c0c0d0; border: 1px solid #2a2a3a; }
.subtab-item.active { background: #2f6fed; color: white; border-color: #2f6fed; }

.viewer-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 0.5rem; }
.viewer-header h2 { margin: 0; }
#dashboardFrame { width: 100%; height: 75vh; border: 1px solid #2a2a3a; border-radius: 8px; background: white; }
