/* ===== Login Page ===== */

.login-page {
  min-height: 100vh;
  background: var(--bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
}

.login-container {
  width: 100%;
  max-width: 400px;
}

.login-header {
  text-align: center;
  margin-bottom: var(--space-2xl);
}

.login-logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  color: var(--text-primary);
  font-weight: 600;
  font-size: var(--text-lg);
  text-decoration: none;
}

.login-logo-icon { font-size: 20px; }

.login-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  box-shadow: var(--shadow-lg);
}

.login-title {
  font-size: var(--text-2xl);
  font-weight: 700;
  margin-bottom: var(--space-xs);
}

.login-subtitle {
  color: var(--text-secondary);
  font-size: var(--text-sm);
  margin-bottom: var(--space-xl);
}

/* Tabs */
.login-tabs {
  display: flex;
  gap: 0;
  margin-bottom: var(--space-xl);
  background: var(--bg-tertiary);
  border-radius: var(--radius-md);
  padding: 3px;
}

.login-tab {
  flex: 1;
  padding: var(--space-sm) var(--space-md);
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: var(--text-sm);
  font-weight: 500;
  cursor: pointer;
  border-radius: var(--radius-sm);
  transition: all var(--duration-fast) var(--ease-out);
  font-family: var(--font-sans);
}
.login-tab:hover { color: var(--text-primary); }
.login-tab.active {
  background: var(--bg-elevated);
  color: var(--text-primary);
  box-shadow: var(--shadow-sm);
}

/* Form */
.login-form { margin-bottom: 0; }

.login-error {
  color: var(--error);
  font-size: var(--text-sm);
  margin-top: var(--space-md);
  text-align: center;
  min-height: 20px;
}

/* ===== Device Selection Page ===== */

.device-select-page {
  min-height: 100vh;
  background: var(--bg-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-lg);
}

.device-select-container {
  width: 100%;
  max-width: 480px;
}

.device-select-header {
  text-align: center;
  margin-bottom: var(--space-2xl);
}

.device-select-logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  color: var(--text-primary);
  font-weight: 600;
  font-size: var(--text-lg);
  text-decoration: none;
}

.device-select-logo-icon { font-size: 20px; }

.device-select-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: var(--space-2xl);
  box-shadow: var(--shadow-lg);
}

.device-select-title {
  font-size: var(--text-2xl);
  font-weight: 700;
  margin-bottom: var(--space-xs);
}

.device-select-subtitle {
  color: var(--text-secondary);
  font-size: var(--text-sm);
  margin-bottom: var(--space-xl);
}

.device-list { min-height: 100px; }

.device-list-loading {
  text-align: center;
  color: var(--text-secondary);
  font-size: var(--text-sm);
  padding: var(--space-xl);
}

.device-list-empty {
  text-align: center;
  color: var(--text-secondary);
  font-size: var(--text-sm);
  padding: var(--space-xl);
}

.device-list-empty-hint {
  display: block;
  margin-top: var(--space-sm);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}

.device-item {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-sm);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
}

.device-item:hover {
  border-color: var(--accent);
  background: var(--bg-elevated);
}

.device-item-icon {
  font-size: 24px;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-tertiary);
  border-radius: var(--radius-sm);
}

.device-item-info { flex: 1; min-width: 0; }

.device-item-name {
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--text-primary);
}

.device-item-meta {
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  margin-top: 2px;
}

.device-item-status {
  font-size: var(--text-xs);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
}

.device-item-status.online {
  color: var(--success);
  background: rgba(16, 185, 129, 0.1);
}
